2011-12-27 19:04:35 +00:00
|
|
|
,
|
|
|
|
/ \,,_ .'|
|
2011-12-27 19:10:00 +00:00
|
|
|
,{{| /}}}}/_.' _____________________________________________
|
2011-12-27 19:04:35 +00:00
|
|
|
}}}}` '{{' '. / \
|
2012-11-14 19:36:24 +00:00
|
|
|
{{{{{ _ ;, \ / Ladies and Gentlemen, \
|
2011-12-27 19:04:35 +00:00
|
|
|
,}}}}}} /o`\ ` ;) | |
|
|
|
|
{{{{{{ / ( | this is ... |
|
|
|
|
}}}}}} | \ | |
|
|
|
|
{{{{{{{{ \ \ | |
|
|
|
|
}}}}}}}}} '.__ _ | | _____ __ __ _ |
|
|
|
|
{{{{{{{{ /`._ (_\ / | / ___/__ ______ / /_____ ______/ /_(_)____ |
|
|
|
|
}}}}}}' | //___/ --=: \__ \/ / / / __ \/ __/ __ `/ ___/ __/ / ___/ |
|
|
|
|
jgs `{{{{` | '--' | ___/ / /_/ / / / / /_/ /_/ (__ ) /_/ / /__ |
|
|
|
|
}}}` | /____/\__, /_/ /_/\__/\__,_/____/\__/_/\___/ |
|
|
|
|
| /____/ |
|
2011-12-27 19:10:00 +00:00
|
|
|
| /
|
|
|
|
\_____________________________________________/
|
2011-12-27 19:04:35 +00:00
|
|
|
|
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
- - -
|
|
|
|
1\. [Introduction](#introduction)
|
|
|
|
2\. [Installation](#installation)
|
|
|
|
3\. [FAQ](#faq)
|
|
|
|
4\. [Other resources](#otherresources)
|
|
|
|
- - -
|
2011-12-27 19:04:35 +00:00
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="introduction"></a>
|
|
|
|
|
|
|
|
## 1\. Introduction
|
2011-12-27 19:04:35 +00:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
Syntastic is a syntax checking plugin for Vim that runs files through external
|
|
|
|
syntax checkers and displays any resulting errors to the user. This can be done
|
|
|
|
on demand, or automatically as files are saved. If syntax errors are detected,
|
|
|
|
the user is notified and is happy because they didn't have to compile their
|
|
|
|
code or execute their script to find them.
|
2011-12-27 19:04:35 +00:00
|
|
|
|
2014-01-03 08:25:24 +02:00
|
|
|
At the time of this writing, syntax checking plugins exist for ActionScript,
|
2014-07-15 08:57:37 +03:00
|
|
|
Ada, AppleScript, Arduino, AsciiDoc, ASM, BEMHTML, Bro, Bourne shell, C,
|
2014-10-06 19:09:25 +03:00
|
|
|
C++, C#, Cabal, Chef, CoffeeScript, Coco, Coq, CSS, Cucumber, CUDA, D,
|
|
|
|
Dart, DocBook, Dust, Elixir, Erlang, eRuby, Fortran, Gentoo metadata, GLSL,
|
|
|
|
Go, Haml, Haskell, Haxe, Handlebars, HSS, HTML, Java, JavaScript, JSON,
|
|
|
|
JSX, LESS, Lex, Limbo, LISP, LLVM intermediate language, Lua, Markdown,
|
|
|
|
MATLAB, NASM, Objective-C, Objective-C++, OCaml, Perl, Perl POD, PHP, gettext
|
|
|
|
Portable Object, OS X and iOS property lists, Puppet, Python, Racket, R,
|
|
|
|
reStructuredText, RPM spec, Ruby, SASS/SCSS, Scala, Slim, Tcl, TeX, Texinfo,
|
|
|
|
Twig, TypeScript, Vala, Verilog, VHDL, VimL, xHtml, XML, XSLT, YACC, YAML,
|
|
|
|
z80, Zope page templates, and zsh. See the [wiki][3] for details about the
|
|
|
|
corresponding supported checkers.
|
2011-12-27 19:04:35 +00:00
|
|
|
|
|
|
|
Below is a screenshot showing the methods that Syntastic uses to display syntax
|
|
|
|
errors. Note that, in practise, you will only have a subset of these methods
|
|
|
|
enabled.
|
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
![Screenshot 1][0]
|
2011-12-27 19:04:35 +00:00
|
|
|
|
2011-12-27 19:13:27 +00:00
|
|
|
1. Errors are loaded into the location list for the corresponding window.
|
|
|
|
2. When the cursor is on a line containing an error, the error message is echoed in the command window.
|
|
|
|
3. Signs are placed beside lines with errors - note that warnings are displayed in a different color.
|
|
|
|
4. There is a configurable statusline flag you can include in your statusline config.
|
|
|
|
5. Hover the mouse over a line containing an error and the error message is displayed as a balloon.
|
|
|
|
6. (not shown) Highlighting errors with syntax highlighting. Erroneous parts of lines can be highlighted.
|
2011-11-30 20:56:43 +00:00
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="installation"></a>
|
|
|
|
|
|
|
|
## 2\. Installation
|
2011-11-30 20:56:43 +00:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
Installing syntastic is easy but first you need to have the [pathogen][1]
|
|
|
|
plugin installed. If you already have [pathogen][1] working then skip
|
|
|
|
[Step 1](#step1) and go to [Step 2](#step2).
|
|
|
|
|
2012-09-03 09:43:05 -07:00
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="step1"></a>
|
|
|
|
|
|
|
|
### 2.1\. Step 1: Install pathogen.vim
|
2012-09-03 09:43:05 -07:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
First I'll show you how to install Tim Pope's [pathogen][1] so that it's easy to
|
|
|
|
install syntastic. Do this in your terminal so that you get the `pathogen.vim`
|
|
|
|
file and the directories it needs:
|
|
|
|
```sh
|
2014-05-27 11:40:15 +03:00
|
|
|
mkdir -p ~/.vim/autoload ~/.vim/bundle && \
|
|
|
|
curl -LSso ~/.vim/autoload/pathogen.vim https://tpo.pe/pathogen.vim
|
2014-03-04 11:13:43 +02:00
|
|
|
```
|
|
|
|
Next you *need* to add this to your `~/.vimrc`:
|
|
|
|
```vim
|
|
|
|
execute pathogen#infect()
|
|
|
|
```
|
2012-09-03 09:43:05 -07:00
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="step2"></a>
|
|
|
|
|
|
|
|
### 2.2\. Step 2: Install syntastic as a pathogen bundle
|
2012-09-03 09:43:05 -07:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
You now have pathogen installed and can put syntastic into `~/.vim/bundle` like
|
|
|
|
this:
|
|
|
|
```sh
|
2014-05-27 11:40:15 +03:00
|
|
|
cd ~/.vim/bundle && \
|
2014-03-04 11:13:43 +02:00
|
|
|
git clone https://github.com/scrooloose/syntastic.git
|
|
|
|
```
|
2012-09-03 09:43:05 -07:00
|
|
|
Quit vim and start it back up to reload it, then type:
|
2014-03-04 11:13:43 +02:00
|
|
|
```vim
|
|
|
|
:Helptags
|
|
|
|
```
|
|
|
|
If you get an error when you do this, then you probably didn't install
|
|
|
|
[pathogen][1] right. Go back to [Step 1](#step1) and make sure you did the following:
|
2012-09-03 09:43:05 -07:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
1. Created both the `~/.vim/autoload` and `~/.vim/bundle` directories.
|
|
|
|
2. Added the `call pathogen#infect()` line to your `~/.vimrc` file
|
|
|
|
3. Did the `git clone` of syntastic inside `~/.vim/bundle`
|
2012-09-03 09:43:05 -07:00
|
|
|
4. Have permissions to access all of these directories.
|
2011-12-13 08:54:12 +00:00
|
|
|
|
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="faq"></a>
|
|
|
|
|
|
|
|
## 3\. FAQ
|
2012-03-01 16:54:05 +00:00
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqinfo"></a>
|
|
|
|
|
2013-05-28 10:26:30 +03:00
|
|
|
__Q. I installed syntastic but it isn't reporting any errors...__
|
2012-03-01 16:54:05 +00:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
A. The most likely reason is that none of the syntax checkers that it requires
|
2014-03-04 14:29:13 +02:00
|
|
|
is installed. For example: by default, python requires either `flake8` or
|
2014-03-04 11:13:43 +02:00
|
|
|
`pylint` to be installed and in your `$PATH`. To see which executables are
|
|
|
|
supported, look at the [wiki][3]. Note that aliases do not work; the actual
|
|
|
|
executables must be available in your `$PATH`. Symbolic links are okay though.
|
|
|
|
You can see syntastic's idea of available checkers by running `:SyntasticInfo`.
|
2012-03-01 16:54:05 +00:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
Another reason it could fail is that either the command line options or the
|
|
|
|
error output for a syntax checker may have changed. In this case, make sure you
|
|
|
|
have the latest version of the syntax checker installed. If it still fails then
|
|
|
|
create an issue - or better yet, create a pull request.
|
2012-03-01 16:54:05 +00:00
|
|
|
|
2014-08-24 20:44:07 +03:00
|
|
|
<a name="faqpython3"></a>
|
|
|
|
|
|
|
|
__Q. The `python` checker complains about syntactically valid Python 3 constructs...__
|
|
|
|
|
2014-08-24 20:45:24 +03:00
|
|
|
A. Configure the `python` checker to call a Python 3 interpreter rather than
|
2014-08-24 20:44:07 +03:00
|
|
|
Python 2, e.g:
|
|
|
|
```vim
|
|
|
|
let g:syntastic_python_python_exec = '/path/to/python3'
|
|
|
|
```
|
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqperl"></a>
|
|
|
|
|
2014-03-03 09:43:14 +02:00
|
|
|
__Q. The `perl` checker has stopped working...__
|
|
|
|
|
|
|
|
A. The `perl` checker runs `perl -c` against your file, which in turn
|
|
|
|
__executes__ any `BEGIN`, `UNITCHECK`, and `CHECK` blocks, and any `use`
|
|
|
|
statements in your file (cf. [perlrun][10]). This is probably fine if you
|
2014-03-04 11:13:43 +02:00
|
|
|
wrote the file yourself, but it's a security problem if you're checking third
|
2014-03-03 09:43:14 +02:00
|
|
|
party files. Since there is currently no way to disable this behaviour while
|
|
|
|
still producing useful results, the checker is now disabled by default. To
|
2014-07-11 18:23:00 +03:00
|
|
|
(re-)enable it, make sure the `g:syntastic_perl_checkers` list includes `perl`,
|
|
|
|
and set `g:syntastic_enable_perl_checker` to 1 in your vimrc:
|
2014-03-03 09:43:14 +02:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_enable_perl_checker = 1
|
2014-03-03 09:43:14 +02:00
|
|
|
```
|
2013-02-14 14:58:47 +00:00
|
|
|
|
2014-06-13 00:23:10 +03:00
|
|
|
<a name="faqrust"></a>
|
|
|
|
|
|
|
|
__Q. What happened to the `rustc` checker?__
|
|
|
|
|
2014-06-17 08:35:29 +03:00
|
|
|
A. It has been included in the [Rust compiler package][12]. If you have
|
|
|
|
a recent version of the Rust compiler, the checker should be picked up
|
|
|
|
automatically by syntastic.
|
2014-06-13 00:23:10 +03:00
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqloclist"></a>
|
|
|
|
|
2014-09-20 19:48:12 +03:00
|
|
|
__Q. I run a checker and the location list is not updated...__
|
|
|
|
__Q. I run`:lopen` or `:lwindow` and the error window is empty...__
|
2013-02-21 18:04:25 -08:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
A. By default the location list is changed only when you run the `:Errors`
|
2014-01-20 10:29:06 +02:00
|
|
|
command, in order to minimise conflicts with other plugins. If you want the
|
|
|
|
location list to always be updated when you run the checkers, add this line to
|
|
|
|
your vimrc:
|
2013-05-27 10:20:44 +03:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_always_populate_loc_list = 1
|
2013-05-27 10:20:44 +03:00
|
|
|
```
|
2013-02-21 18:04:25 -08:00
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqargs"></a>
|
|
|
|
|
2013-05-28 10:26:30 +03:00
|
|
|
__Q. How can I pass additional arguments to a checker?__
|
2013-02-21 18:04:25 -08:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
A. Almost all syntax checkers use the `makeprgBuild()` function. Those checkers
|
|
|
|
that do can be configured using global variables. The general form of the
|
2014-03-04 11:13:43 +02:00
|
|
|
global `args` variables is `syntastic_<filetype>_<checker>_args`.
|
2013-02-21 18:04:25 -08:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
So, If you wanted to pass "--my --args --here" to the ruby mri checker you
|
|
|
|
would add this line to your vimrc:
|
2013-05-27 10:20:44 +03:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_ruby_mri_args = "--my --args --here"
|
2013-05-27 10:20:44 +03:00
|
|
|
```
|
2013-02-21 18:04:25 -08:00
|
|
|
|
|
|
|
See `:help syntastic-checker-options` for more information.
|
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqcheckers"></a>
|
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
__Q. Syntastic supports several checkers for my filetype - how do I tell it
|
|
|
|
which one(s) to use?__
|
2013-02-10 16:51:02 +00:00
|
|
|
|
|
|
|
A. Stick a line like this in your vimrc:
|
2013-05-27 10:20:44 +03:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_<filetype>_checkers = ['<checker-name>']
|
2013-05-27 10:20:44 +03:00
|
|
|
```
|
2013-02-10 16:51:02 +00:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
To see the list of supported checkers for your filetype look at the
|
|
|
|
[wiki][3].
|
2013-02-10 16:51:02 +00:00
|
|
|
|
2014-03-04 11:13:43 +02:00
|
|
|
e.g. Python has the following checkers, among others: `flake8`, `pyflakes`,
|
|
|
|
`pylint` and a native `python` checker.
|
2013-02-10 16:51:02 +00:00
|
|
|
|
|
|
|
To tell syntastic to use `pylint`, you would use this setting:
|
2013-05-27 10:20:44 +03:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_python_checkers = ['pylint']
|
2013-05-27 10:20:44 +03:00
|
|
|
```
|
2013-02-10 16:51:02 +00:00
|
|
|
|
2014-09-17 20:22:28 +03:00
|
|
|
Checkers can be chained together like this:
|
2013-05-27 10:20:44 +03:00
|
|
|
```vim
|
2014-03-04 11:13:43 +02:00
|
|
|
let g:syntastic_php_checkers = ['php', 'phpcs', 'phpmd']
|
2013-05-27 10:20:44 +03:00
|
|
|
```
|
2013-02-10 16:51:02 +00:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
This is telling syntastic to run the `php` checker first, and if no errors are
|
|
|
|
found, run `phpcs`, and then `phpmd`.
|
2013-02-10 16:51:02 +00:00
|
|
|
|
2014-04-14 08:43:12 +03:00
|
|
|
You can also run checkers explicitly by calling `:SyntasticCheck <checker>`.
|
|
|
|
|
|
|
|
e.g. to run `phpcs` and `phpmd`:
|
|
|
|
```vim
|
|
|
|
:SyntasticCheck phpcs phpmd
|
|
|
|
```
|
|
|
|
|
|
|
|
This works for any checkers available for the current filetype, even if they
|
|
|
|
aren't listed in `g:syntastic_<filetype>_checkers`. You can't run checkers for
|
|
|
|
"foreign" filetypes though (e.g. you can't run, say, a Python checker if the
|
2014-09-17 20:22:28 +03:00
|
|
|
filetype of the current file is `php`).
|
|
|
|
|
|
|
|
<a name="faqstyle"></a>
|
|
|
|
|
|
|
|
__Q. What is the difference between syntax checkers and style checkers?__
|
|
|
|
|
2014-09-17 23:19:04 +03:00
|
|
|
A. The errors and warnings they produce are highlighted differently and can
|
2014-09-17 20:22:28 +03:00
|
|
|
be filtered by different rules, but otherwise the distinction is pretty much
|
2014-09-19 08:20:30 +03:00
|
|
|
arbitrary. There is an ongoing effort to keep things consistent, so you can
|
|
|
|
_generally_ expect messages produced by syntax checkers to be _mostly_ related
|
|
|
|
to syntax, and messages produced by style checkers to be _mostly_ about style.
|
|
|
|
But there can be no formal guarantee that, say, a style checker that runs into
|
|
|
|
a syntax error wouldn't die with a fatal message, nor that a syntax checker
|
|
|
|
wouldn't give you warnings against using some constructs as being bad practice.
|
|
|
|
There is also no guarantee that messages marked as "style" are less severe than
|
|
|
|
the ones marked as "syntax" (whatever that might mean). And there are even a
|
|
|
|
few Frankenstein checkers (for example `flake8` and `pylama`) that, by their
|
|
|
|
nature, produce both kinds of messages. Syntastic is not smart enough to be
|
|
|
|
able to sort out these things by itself.
|
|
|
|
|
|
|
|
In fact it's more useful to look at this from the perspective of filtering
|
|
|
|
unwanted messages, rather than as an indicator of severity levels. The
|
|
|
|
distinction between syntax and style is orthogonal to the distinction between
|
|
|
|
errors and warnings, and thus you can turn off messages based on level, on
|
|
|
|
type, or both.
|
|
|
|
|
|
|
|
e.g. To disable all style messages:
|
2014-09-17 20:22:28 +03:00
|
|
|
```vim
|
|
|
|
let g:syntastic_quiet_messages = { "type": "style" }
|
|
|
|
```
|
|
|
|
See `:help syntastic_quiet_messages` for details.
|
2014-04-14 08:43:12 +03:00
|
|
|
|
|
|
|
<a name="faqaggregate"></a>
|
|
|
|
|
2014-09-30 14:31:26 +03:00
|
|
|
__Q. I have enabled multiple checkers for the current filetype. How can I
|
|
|
|
display all of the errors from all of the checkers together?__
|
2014-04-14 08:43:12 +03:00
|
|
|
|
|
|
|
A. Set `g:syntastic_aggregate_errors` to 1 in your vimrc:
|
|
|
|
```vim
|
|
|
|
let g:syntastic_aggregate_errors = 1
|
|
|
|
```
|
|
|
|
|
|
|
|
See `:help syntastic-aggregating-errors` for more details.
|
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqlnext"></a>
|
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
__Q. How can I jump between the different errors without using the location
|
|
|
|
list at the bottom of the window?__
|
2012-09-05 10:13:30 +01:00
|
|
|
|
2014-09-19 08:20:30 +03:00
|
|
|
A. Vim provides several built-in commands for this. See `:help :lnext` and
|
2014-01-20 10:29:06 +02:00
|
|
|
`:help :lprev`.
|
2012-09-05 10:13:30 +01:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
If you use these commands a lot then you may want to add shortcut mappings to
|
|
|
|
your vimrc, or install something like [unimpaired][2], which provides such
|
|
|
|
mappings (among other things).
|
2012-03-01 16:54:05 +00:00
|
|
|
|
2014-04-02 22:47:09 +03:00
|
|
|
<a name="faqbdelete"></a>
|
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
__Q. The error window is closed automatically when I :quit the current buffer
|
|
|
|
but not when I :bdelete it?__
|
2013-04-29 09:24:32 +03:00
|
|
|
|
2014-01-20 10:29:06 +02:00
|
|
|
A. There is no safe way to handle that situation automatically, but you can
|
|
|
|
work around it:
|
2013-04-29 09:24:32 +03:00
|
|
|
|
|
|
|
```vim
|
|
|
|
nnoremap <silent> <C-d> :lclose<CR>:bdelete<CR>
|
|
|
|
cabbrev <silent> bd lclose\|bdelete
|
|
|
|
```
|
2014-01-20 10:29:06 +02:00
|
|
|
|
|
|
|
|
2014-02-03 08:23:00 +02:00
|
|
|
<a name="otherresources"></a>
|
|
|
|
|
|
|
|
## 4\. Other resources
|
2014-01-20 10:29:06 +02:00
|
|
|
|
|
|
|
The preferred place for posting suggestions, reporting bugs, and general
|
2014-04-26 08:09:03 +03:00
|
|
|
discussions related to syntastic is the [issue tracker at GitHub][4].
|
|
|
|
A guide for writing syntax checkers can be found in the [wiki][11].
|
|
|
|
There are also a dedicated [google group][5], and a
|
|
|
|
[syntastic tag at StackOverflow][6].
|
2014-01-20 10:29:06 +02:00
|
|
|
|
|
|
|
Syntastic aims to provide a common interface to syntax checkers for as many
|
|
|
|
languages as possible. For particular languages, there are, of course, other
|
|
|
|
plugins that provide more functionality than syntastic. You might want to take
|
|
|
|
a look at [jedi-vim][7], [python-mode][8], or [YouCompleteMe][9].
|
|
|
|
|
|
|
|
[0]: https://github.com/scrooloose/syntastic/raw/master/_assets/screenshot_1.png
|
|
|
|
[1]: https://github.com/tpope/vim-pathogen
|
|
|
|
[2]: https://github.com/tpope/vim-unimpaired
|
|
|
|
[3]: https://github.com/scrooloose/syntastic/wiki/Syntax-Checkers
|
|
|
|
[4]: https://github.com/scrooloose/syntastic/issues
|
|
|
|
[5]: https://groups.google.com/group/vim-syntastic
|
|
|
|
[6]: http://stackoverflow.com/questions/tagged/syntastic
|
|
|
|
[7]: https://github.com/davidhalter/jedi-vim
|
|
|
|
[8]: https://github.com/klen/python-mode
|
2014-03-30 21:11:39 +03:00
|
|
|
[9]: http://valloric.github.io/YouCompleteMe/
|
2014-03-03 09:43:14 +02:00
|
|
|
[10]: http://perldoc.perl.org/perlrun.html#*-c*
|
2014-04-26 08:09:03 +03:00
|
|
|
[11]: https://github.com/scrooloose/syntastic/wiki/Syntax-Checker-Guide
|
2014-06-17 08:35:29 +03:00
|
|
|
[12]: https://github.com/rust-lang/rust/
|
2014-09-19 08:20:30 +03:00
|
|
|
|
|
|
|
<!--
|
|
|
|
vim:tw=79:sw=4:
|
|
|
|
-->
|