cSvn-UI for SVN Repositories

cGit-UI – is a web interface for Subversion (SVN) Repositories. cSvn CGI script is writen in C and therefore it's fast enough

15 Commits   0 Branches   1 Tag
Index: csvn-ui-0.1.5/.gitignore
===================================================================
--- csvn-ui-0.1.5/.gitignore	(nonexistent)
+++ csvn-ui-0.1.5/.gitignore	(revision 12)
@@ -0,0 +1,36 @@
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/.svnignore
===================================================================
--- csvn-ui-0.1.5/.svnignore	(nonexistent)
+++ csvn-ui-0.1.5/.svnignore	(revision 12)
@@ -0,0 +1,36 @@
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/ABOUT-NLS
===================================================================
--- csvn-ui-0.1.5/ABOUT-NLS	(nonexistent)
+++ csvn-ui-0.1.5/ABOUT-NLS	(revision 12)
@@ -0,0 +1,1379 @@
+1 Notes on the Free Translation Project
+***************************************
+
+Free software is going international!  The Free Translation Project is a
+way to get maintainers of free software, translators, and users all
+together, so that free software will gradually become able to speak many
+languages.  A few packages already provide translations for their
+messages.
+
+   If you found this 'ABOUT-NLS' file inside a distribution, you may
+assume that the distributed package does use GNU 'gettext' internally,
+itself available at your nearest GNU archive site.  But you do _not_
+need to install GNU 'gettext' prior to configuring, installing or using
+this package with messages translated.
+
+   Installers will find here some useful hints.  These notes also
+explain how users should proceed for getting the programs to use the
+available translations.  They tell how people wanting to contribute and
+work on translations can contact the appropriate team.
+
+1.1 INSTALL Matters
+===================
+
+Some packages are "localizable" when properly installed; the programs
+they contain can be made to speak your own native language.  Most such
+packages use GNU 'gettext'.  Other packages have their own ways to
+internationalization, predating GNU 'gettext'.
+
+   By default, this package will be installed to allow translation of
+messages.  It will automatically detect whether the system already
+provides the GNU 'gettext' functions.  Installers may use special
+options at configuration time for changing the default behaviour.  The
+command:
+
+     ./configure --disable-nls
+
+will _totally_ disable translation of messages.
+
+   When you already have GNU 'gettext' installed on your system and run
+configure without an option for your new package, 'configure' will
+probably detect the previously built and installed 'libintl' library and
+will decide to use it.  If not, you may have to to use the
+'--with-libintl-prefix' option to tell 'configure' where to look for it.
+
+   Internationalized packages usually have many 'po/LL.po' files, where
+LL gives an ISO 639 two-letter code identifying the language.  Unless
+translations have been forbidden at 'configure' time by using the
+'--disable-nls' switch, all available translations are installed
+together with the package.  However, the environment variable 'LINGUAS'
+may be set, prior to configuration, to limit the installed set.
+'LINGUAS' should then contain a space separated list of two-letter
+codes, stating which languages are allowed.
+
+1.2 Using This Package
+======================
+
+As a user, if your language has been installed for this package, you
+only have to set the 'LANG' environment variable to the appropriate
+'LL_CC' combination.  If you happen to have the 'LC_ALL' or some other
+'LC_xxx' environment variables set, you should unset them before setting
+'LANG', otherwise the setting of 'LANG' will not have the desired
+effect.  Here 'LL' is an ISO 639 two-letter language code, and 'CC' is
+an ISO 3166 two-letter country code.  For example, let's suppose that
+you speak German and live in Germany.  At the shell prompt, merely
+execute 'setenv LANG de_DE' (in 'csh'), 'export LANG; LANG=de_DE' (in
+'sh') or 'export LANG=de_DE' (in 'bash').  This can be done from your
+'.login' or '.profile' file, once and for all.
+
+   You might think that the country code specification is redundant.
+But in fact, some languages have dialects in different countries.  For
+example, 'de_AT' is used for Austria, and 'pt_BR' for Brazil.  The
+country code serves to distinguish the dialects.
+
+   The locale naming convention of 'LL_CC', with 'LL' denoting the
+language and 'CC' denoting the country, is the one use on systems based
+on GNU libc.  On other systems, some variations of this scheme are used,
+such as 'LL' or 'LL_CC.ENCODING'.  You can get the list of locales
+supported by your system for your language by running the command
+'locale -a | grep '^LL''.
+
+   Not all programs have translations for all languages.  By default, an
+English message is shown in place of a nonexistent translation.  If you
+understand other languages, you can set up a priority list of languages.
+This is done through a different environment variable, called
+'LANGUAGE'.  GNU 'gettext' gives preference to 'LANGUAGE' over 'LANG'
+for the purpose of message handling, but you still need to have 'LANG'
+set to the primary language; this is required by other parts of the
+system libraries.  For example, some Swedish users who would rather read
+translations in German than English for when Swedish is not available,
+set 'LANGUAGE' to 'sv:de' while leaving 'LANG' to 'sv_SE'.
+
+   Special advice for Norwegian users: The language code for Norwegian
+bokma*l changed from 'no' to 'nb' recently (in 2003).  During the
+transition period, while some message catalogs for this language are
+installed under 'nb' and some older ones under 'no', it's recommended
+for Norwegian users to set 'LANGUAGE' to 'nb:no' so that both newer and
+older translations are used.
+
+   In the 'LANGUAGE' environment variable, but not in the 'LANG'
+environment variable, 'LL_CC' combinations can be abbreviated as 'LL' to
+denote the language's main dialect.  For example, 'de' is equivalent to
+'de_DE' (German as spoken in Germany), and 'pt' to 'pt_PT' (Portuguese
+as spoken in Portugal) in this context.
+
+1.3 Translating Teams
+=====================
+
+For the Free Translation Project to be a success, we need interested
+people who like their own language and write it well, and who are also
+able to synergize with other translators speaking the same language.
+Each translation team has its own mailing list.  The up-to-date list of
+teams can be found at the Free Translation Project's homepage,
+'http://translationproject.org/', in the "Teams" area.
+
+   If you'd like to volunteer to _work_ at translating messages, you
+should become a member of the translating team for your own language.
+The subscribing address is _not_ the same as the list itself, it has
+'-request' appended.  For example, speakers of Swedish can send a
+message to 'sv-request@li.org', having this message body:
+
+     subscribe
+
+   Keep in mind that team members are expected to participate _actively_
+in translations, or at solving translational difficulties, rather than
+merely lurking around.  If your team does not exist yet and you want to
+start one, or if you are unsure about what to do or how to get started,
+please write to 'coordinator@translationproject.org' to reach the
+coordinator for all translator teams.
+
+   The English team is special.  It works at improving and uniformizing
+the terminology in use.  Proven linguistic skills are praised more than
+programming skills, here.
+
+1.4 Available Packages
+======================
+
+Languages are not equally supported in all packages.  The following
+matrix shows the current state of internationalization, as of Jun 2014.
+The matrix shows, in regard of each package, for which languages PO
+files have been submitted to translation coordination, with a
+translation percentage of at least 50%.
+
+     Ready PO files       af am an ar as ast az be bg bn bn_IN bs ca crh cs
+                        +---------------------------------------------------+
+     a2ps               |                       []                []     [] |
+     aegis              |                                                   |
+     anubis             |                                                   |
+     aspell             |                []                       []     [] |
+     bash               |                          []             []     [] |
+     bfd                |                                                   |
+     binutils           |                                         []        |
+     bison              |                                                   |
+     bison-runtime      |                []                                 |
+     buzztrax           |                                                [] |
+     ccd2cue            |                                                   |
+     ccide              |                                                   |
+     cflow              |                                                   |
+     clisp              |                                                   |
+     coreutils          |                                         []     [] |
+     cpio               |                                                   |
+     cppi               |                                                   |
+     cpplib             |                                         []        |
+     cryptsetup         |                                                [] |
+     datamash           |                                                   |
+     denemo             |                                         []     [] |
+     dfarc              |                                         []        |
+     dialog             |       []                                []     [] |
+     dico               |                                                   |
+     diffutils          |                                                [] |
+     dink               |                                         []        |
+     direvent           |                                                   |
+     doodle             |                                                [] |
+     dos2unix           |                                                   |
+     dos2unix-man       |                                                   |
+     e2fsprogs          |                                         []     [] |
+     enscript           |                                         []        |
+     exif               |                                                [] |
+     fetchmail          |                                         []     [] |
+     findutils          |                                                [] |
+     flex               |                                         []        |
+     freedink           |                                         []     [] |
+     fusionforge        |                                                   |
+     gas                |                                                   |
+     gawk               |                                         []        |
+     gcal               |                                         []        |
+     gcc                |                                                   |
+     gdbm               |                                                   |
+     gettext-examples   | []             []        []             []     [] |
+     gettext-runtime    |                          []             []     [] |
+     gettext-tools      |                          []             []        |
+     gjay               |                                                   |
+     glunarclock        |                []        []                    [] |
+     gnubiff            |                                                [] |
+     gnubik             |          []                                       |
+     gnucash            |          ()              ()             []        |
+     gnuchess           |                                                   |
+     gnulib             |                                                [] |
+     gnunet             |                                                   |
+     gnunet-gtk         |                                                   |
+     gold               |                                                   |
+     gphoto2            |                                                [] |
+     gprof              |                          []                       |
+     gramadoir          |                                                   |
+     grep               |                          []             []     [] |
+     grub               |                                         []        |
+     gsasl              |                                                   |
+     gss                |                                                   |
+     gst-plugins-bad    |                          []                    [] |
+     gst-plugins-base   |                          []             []     [] |
+     gst-plugins-good   |                          []             []     [] |
+     gst-plugins-ugly   |                          []             []     [] |
+     gstreamer          |                []        []             []     [] |
+     gtick              |                                                [] |
+     gtkam              |                       []                       [] |
+     gtkspell           | []             []     []                []     [] |
+     guix               |                                                   |
+     guix-packages      |                                                   |
+     gutenprint         |                                         []        |
+     hello              |                                         []        |
+     help2man           |                                                   |
+     help2man-texi      |                                                   |
+     hylafax            |                                                   |
+     idutils            |                                                   |
+     iso_15924          |                                                [] |
+     iso_3166           | []          []        [] [] []  []   [] [] []  [] |
+     iso_3166_2         |                                                   |
+     iso_4217           |                                                [] |
+     iso_639            |             [] []     [] [] []  []      [] []  [] |
+     iso_639_3          |                []                          []     |
+     iso_639_5          |                                                   |
+     jwhois             |                                                   |
+     kbd                |                                                [] |
+     klavaro            |          []              [] []          []     [] |
+     ld                 |                          []                       |
+     leafpad            |                       [] []             []     [] |
+     libc               |                          []             []     [] |
+     libexif            |                       ()                          |
+     libextractor       |                                                   |
+     libgnutls          |                                                [] |
+     libgphoto2         |                                                [] |
+     libgphoto2_port    |                                                [] |
+     libgsasl           |                                                   |
+     libiconv           |                          []                    [] |
+     libidn             |                                                [] |
+     liferea            |          []    []                       []     [] |
+     lilypond           |                                         []     [] |
+     lordsawar          |                                         []        |
+     lprng              |                                                   |
+     lynx               |                                         []     [] |
+     m4                 |                                                [] |
+     mailfromd          |                                                   |
+     mailutils          |                                                   |
+     make               |                                                [] |
+     man-db             |                                         []     [] |
+     man-db-manpages    |                                                   |
+     midi-instruments   |          []                             []     [] |
+     minicom            |                                                [] |
+     mkisofs            |                                                [] |
+     myserver           |                                                [] |
+     nano               |                          []             []     [] |
+     opcodes            |                                                   |
+     parted             |                                                [] |
+     pies               |                                                   |
+     pnmixer            |                                                   |
+     popt               |                                                [] |
+     procps-ng          |                                                   |
+     procps-ng-man      |                                                   |
+     psmisc             |                                                [] |
+     pspp               |                                         []        |
+     pushover           |                                                [] |
+     pwdutils           |                                                   |
+     pyspread           |                                                   |
+     radius             |                                         []        |
+     recode             |                       []                []     [] |
+     recutils           |                                                   |
+     rpm                |                                                   |
+     rush               |                                                   |
+     sarg               |                                                   |
+     sed                |                []        []             []     [] |
+     sharutils          |                                                [] |
+     shishi             |                                                   |
+     skribilo           |                                                   |
+     solfege            |                                         []     [] |
+     solfege-manual     |                                                   |
+     spotmachine        |                                                   |
+     sudo               |                                         []     [] |
+     sudoers            |                                         []     [] |
+     sysstat            |                                                [] |
+     tar                |                          []             []     [] |
+     texinfo            |                                         []     [] |
+     texinfo_document   |                                         []     [] |
+     tigervnc           |                          []                       |
+     tin                |                                                   |
+     tin-man            |                                                   |
+     tracgoogleappsa... |                                                   |
+     trader             |                                                   |
+     util-linux         |                                                [] |
+     ve                 |                                                   |
+     vice               |                                                   |
+     vmm                |                                                   |
+     vorbis-tools       |                                                [] |
+     wastesedge         |                                                   |
+     wcd                |                                                   |
+     wcd-man            |                                                   |
+     wdiff              |                                         []     [] |
+     wget               |                                                [] |
+     wyslij-po          |                                                   |
+     xboard             |                                                   |
+     xdg-user-dirs      | []    []    [] []     [] []     []      [] []  [] |
+     xkeyboard-config   |                          []             []     [] |
+                        +---------------------------------------------------+
+                          af am an ar as ast az be bg bn bn_IN bs ca crh cs
+                           4  0  2  5  3 11   0  8 25  3   3    1 55  4  74
+
+                          da  de  el en en_GB en_ZA eo es et eu fa fi  fr 
+                        +--------------------------------------------------+
+     a2ps               | []  []  []     []         [] [] []       []  []  |
+     aegis              | []  []                       []              []  |
+     anubis             | []  []                       []          []  []  |
+     aspell             | []  []         []         [] []          []  []  |
+     bash               |                           [] []              []  |
+     bfd                | []                           []          []  []  |
+     binutils           |                              []          []  []  |
+     bison              | []  []  []                [] [] []       []  []  |
+     bison-runtime      | []  []  []                [] [] []       []  []  |
+     buzztrax           | []  []                                   []  []  |
+     ccd2cue            | []  []                    []                 []  |
+     ccide              | []  []                    [] []          []  []  |
+     cflow              | []  []                    []             []  []  |
+     clisp              | []  []     []                []              []  |
+     coreutils          | []  []                       [] []           []  |
+     cpio               | []  []                       []          []  []  |
+     cppi               | []  []                    []             []  []  |
+     cpplib             | []  []                    [] []          []  []  |
+     cryptsetup         | []  []                       []          []  []  |
+     datamash           | []  []                    []                 []  |
+     denemo             | []                                               |
+     dfarc              | []  []                    [] []          []  []  |
+     dialog             | []  []  []                [] []    [] [] []  []  |
+     dico               | []  []                                   []  []  |
+     diffutils          | []  []  []                [] []              []  |
+     dink               | []  []                    [] []          []  []  |
+     direvent           | []  []                    []                 []  |
+     doodle             | []  []                    []             []      |
+     dos2unix           | []  []                    [] []              []  |
+     dos2unix-man       |     []                       []              []  |
+     e2fsprogs          | []  []                    [] []              []  |
+     enscript           | []  []         []         []             []  []  |
+     exif               | []  []                    [] []          []  []  |
+     fetchmail          | []  ()  []     []         [] []              []  |
+     findutils          | []  []  []                [] [] []       []  []  |
+     flex               | []  []                    [] []          []  []  |
+     freedink           | []  []  []                [] []    []    []  []  |
+     fusionforge        |     []                       []              []  |
+     gas                |                              []          []  []  |
+     gawk               | []  []                       []          []  []  |
+     gcal               | []  []                       []              []  |
+     gcc                |     []                                           |
+     gdbm               | []  []                    []             []  []  |
+     gettext-examples   | []  []  []                [] []          []  []  |
+     gettext-runtime    | []  []                    [] []          []  []  |
+     gettext-tools      | []  []                       []          []  []  |
+     gjay               |     []                    []             []  []  |
+     glunarclock        | []  []                    []             []  []  |
+     gnubiff            |     ()                    []             []  ()  |
+     gnubik             | []  []                    []             []  []  |
+     gnucash            | []  ()  ()     ()            ()          ()  ()  |
+     gnuchess           |     []                    [] []              []  |
+     gnulib             | []  []                    [] [] []       []  []  |
+     gnunet             |                              []                  |
+     gnunet-gtk         |     []                                           |
+     gold               |                              []          []  []  |
+     gphoto2            | []  ()                    []                 []  |
+     gprof              | []  []                    [] []          []  []  |
+     gramadoir          | []  []                    []             []  []  |
+     grep               | []  []                    [] [] []       []  []  |
+     grub               | []  []                       []          []  []  |
+     gsasl              | []  []                    []             []  []  |
+     gss                | []  []                    []             []  []  |
+     gst-plugins-bad    | []  []                                       []  |
+     gst-plugins-base   | []  []  []                   []          []  []  |
+     gst-plugins-good   | []  []  []                   []    []    []  []  |
+     gst-plugins-ugly   | []  []  []                [] []    []    []  []  |
+     gstreamer          | []  []  []                   []    []    []  []  |
+     gtick              | []  ()                    []             []  []  |
+     gtkam              | []  ()                    [] []          []  []  |
+     gtkspell           | []  []  []                [] []    []    []  []  |
+     guix               | []                        []                     |
+     guix-packages      |                                                  |
+     gutenprint         | []  []                                   []  []  |
+     hello              | []  []  []                [] [] []       []  []  |
+     help2man           | []  []  []                [] []          []  []  |
+     help2man-texi      |     []                       []              []  |
+     hylafax            |     []                       []                  |
+     idutils            | []  []                    []             []  []  |
+     iso_15924          | []  ()                    [] []    ()    []  ()  |
+     iso_3166           | []  ()  []                [] [] [] ()    []  ()  |
+     iso_3166_2         | []  ()                             ()        ()  |
+     iso_4217           | []  ()  []                   [] [] ()    []  ()  |
+     iso_639            | []  ()                    [] []    ()    []  ()  |
+     iso_639_3          |     ()                             ()        ()  |
+     iso_639_5          |     ()                             ()        ()  |
+     jwhois             |     []                    [] []          []  []  |
+     kbd                | []  []  []                [] []              []  |
+     klavaro            | []  []  []                [] []    []        []  |
+     ld                 | []                           []          []  []  |
+     leafpad            | []  []  []                [] []    []    []  []  |
+     libc               | []  []                       []          []  []  |
+     libexif            | []  []         ()            []              []  |
+     libextractor       |     []                                           |
+     libgnutls          |     []                    []             []  []  |
+     libgphoto2         | []  ()                                       []  |
+     libgphoto2_port    | []  ()                       []    []    []  []  |
+     libgsasl           | []  []                    []             []  []  |
+     libiconv           | []  []                    [] [] []       []  []  |
+     libidn             | []  []                    []             []  []  |
+     liferea            | []  ()  []                   []    []    []  []  |
+     lilypond           | []  []  []                [] []              []  |
+     lordsawar          | []  []                                           |
+     lprng              |                                                  |
+     lynx               | []  []                    []    []       []  []  |
+     m4                 | []  []  []                []             []  []  |
+     mailfromd          |                                              []  |
+     mailutils          |     []                       []          []  []  |
+     make               | []  []                       []          []  []  |
+     man-db             | []  []                    []                 []  |
+     man-db-manpages    |     []                                       []  |
+     midi-instruments   | []  []  []                [] [] []    [] []  []  |
+     minicom            | []  []                       []          []  []  |
+     mkisofs            |                           []             []  []  |
+     myserver           |     []                    []             []  []  |
+     nano               | []  []                    [] []    []    []  []  |
+     opcodes            | []  []                       []          []  []  |
+     parted             | []  []                                       []  |
+     pies               |     []                                           |
+     pnmixer            |     []                                       []  |
+     popt               | []  []                    [] []          []  []  |
+     procps-ng          |     []                                       []  |
+     procps-ng-man      |     []                                       []  |
+     psmisc             | []  []  []                []       []    []  []  |
+     pspp               |     []                       []              []  |
+     pushover           |     ()                    [] []              []  |
+     pwdutils           | []  []                                       []  |
+     pyspread           | []  []                                       []  |
+     radius             |                              []              []  |
+     recode             | []  []  []                [] []          []  []  |
+     recutils           |     []                       []          []  []  |
+     rpm                | []  []                    []             []  []  |
+     rush               |     []                                   []  []  |
+     sarg               | []                                           []  |
+     sed                | []  []  []                [] [] []       []  []  |
+     sharutils          |     []                    []    []           []  |
+     shishi             |     []                                   []  []  |
+     skribilo           | []                           []              []  |
+     solfege            | []  []                    [] [] []    [] []  []  |
+     solfege-manual     |     []                    [] [] []           []  |
+     spotmachine        | []  []                    []             []  []  |
+     sudo               | []  []                    [] []          []  []  |
+     sudoers            | []  []  []                []             []  []  |
+     sysstat            | []  []                    [] []          []  []  |
+     tar                | []  []                    [] [] []       []  []  |
+     texinfo            | []  []                    [] []              []  |
+     texinfo_document   |     []                    [] []              []  |
+     tigervnc           | []  []  []                []             []  []  |
+     tin                | []  []                          []           []  |
+     tin-man            |                []                                |
+     tracgoogleappsa... | []  []                    []             []  []  |
+     trader             | []  []         []         []             []  []  |
+     util-linux         | []  []                       []              []  |
+     ve                 |     []                    [] []          []  []  |
+     vice               | ()  ()                                       ()  |
+     vmm                |     []                                   []      |
+     vorbis-tools       | []  []                    []                 []  |
+     wastesedge         | []                                               |
+     wcd                |     []                    [] []          []      |
+     wcd-man            |     []                                           |
+     wdiff              | []  []                    [] [] []       []  []  |
+     wget               |     []                    [] [] []       []  []  |
+     wyslij-po          |     []                    []             []  []  |
+     xboard             | []  []                       []              []  |
+     xdg-user-dirs      | []  []  []                [] [] [] [] [] []  []  |
+     xkeyboard-config   | []  []  []                [] []          []  []  |
+                        +--------------------------------------------------+
+                          da  de  el en en_GB en_ZA eo es et eu fa fi  fr 
+                          119 131 32  1   6     0   94 95 22 13  4 102 139
+
+                          ga gd gl gu he hi hr hu hy ia id is it ja ka kk
+                        +-------------------------------------------------+
+     a2ps               |                   []          []    [] []       |
+     aegis              |                                     []          |
+     anubis             |                   [] []       []    []          |
+     aspell             | []                []          []    [] []       |
+     bash               |                      []       []    [] []       |
+     bfd                |                               []       []       |
+     binutils           |                               []    [] []       |
+     bison              |                   []                            |
+     bison-runtime      | []    []          [] []    [] []    [] []       |
+     buzztrax           |                                                 |
+     ccd2cue            |                      []                         |
+     ccide              |                   [] []                         |
+     cflow              | []                []          []                |
+     clisp              |                                                 |
+     coreutils          |                      []                []       |
+     cpio               | []                [] []       []    [] []       |
+     cppi               |       []          [] []             [] []       |
+     cpplib             |                               []       []       |
+     cryptsetup         |                                     []          |
+     datamash           |                                                 |
+     denemo             |                                     []          |
+     dfarc              |                   [] []             []          |
+     dialog             | [] [] []          [] []    [] [] [] [] []       |
+     dico               |                                                 |
+     diffutils          |                      []       []    [] []       |
+     dink               |                      []                         |
+     direvent           |                      []                         |
+     doodle             | []                                  []          |
+     dos2unix           |                      []                []       |
+     dos2unix-man       |                                                 |
+     e2fsprogs          |                      []       []                |
+     enscript           | []                []          []                |
+     exif               |       []          []          [] [] [] []       |
+     fetchmail          |                               []    [] []       |
+     findutils          | []    []          [] []       []    [] []       |
+     flex               | []                                              |
+     freedink           |                   [] []       []    []          |
+     fusionforge        |                                                 |
+     gas                |                               []                |
+     gawk               |                               []    () []       |
+     gcal               |                                                 |
+     gcc                |                                                 |
+     gdbm               |                                                 |
+     gettext-examples   | []    []          [] []       []    [] []       |
+     gettext-runtime    | []    []          [] []       []    [] []       |
+     gettext-tools      |                               []    [] []       |
+     gjay               |       []                                        |
+     glunarclock        | []    []          [] []       []    []          |
+     gnubiff            |                      []       []    ()          |
+     gnubik             |       []          []                []          |
+     gnucash            |          () () ()    ()             ()          |
+     gnuchess           |                                                 |
+     gnulib             | []    []             []             [] []       |
+     gnunet             |                                                 |
+     gnunet-gtk         |                                                 |
+     gold               |                               []    []          |
+     gphoto2            |                      []       []    [] []       |
+     gprof              | []                   []       []    []          |
+     gramadoir          | []                   []       []                |
+     grep               | []    []          [] []       []    [] []       |
+     grub               |       []             []             []          |
+     gsasl              | []                [] []       []    []          |
+     gss                | []                [] []       []    []          |
+     gst-plugins-bad    |                   [] []       []                |
+     gst-plugins-base   |       []          [] []       []                |
+     gst-plugins-good   |       []          [] []       []    [] []       |
+     gst-plugins-ugly   |       []          [] []       []    [] []       |
+     gstreamer          |       []          [] []       []    []          |
+     gtick              | []    []             []       []    []          |
+     gtkam              |                      []       [] [] [] []       |
+     gtkspell           | []    []    []    [] [] []    [] [] [] []       |
+     guix               |                                                 |
+     guix-packages      |                                                 |
+     gutenprint         |       []             []             []          |
+     hello              | []    []          [] []       []                |
+     help2man           |                   []                [] []       |
+     help2man-texi      |                                                 |
+     hylafax            |                               []                |
+     idutils            |                      []       []                |
+     iso_15924          |       []             []    [] [] [] []          |
+     iso_3166           | []    [] [] [] [] [] []    [] [] [] [] []    [] |
+     iso_3166_2         |                               []    []          |
+     iso_4217           |                   [] []       [] [] [] []       |
+     iso_639            | []    [] []       [] []       [] [] [] []       |
+     iso_639_3          |       []                            []          |
+     iso_639_5          |                                                 |
+     jwhois             |       []             []       []    []          |
+     kbd                |                      []       []    []          |
+     klavaro            |       []          [] []             []       [] |
+     ld                 | []                            []    [] []       |
+     leafpad            | []    []    []    [] []       []    [] ()       |
+     libc               |       []          []          []    [] []       |
+     libexif            |                                     []          |
+     libextractor       |                                                 |
+     libgnutls          |                                     []          |
+     libgphoto2         |                                     [] []       |
+     libgphoto2_port    |                                     [] []       |
+     libgsasl           | []                   []       []    []          |
+     libiconv           | []    []          [] []       []    [] []       |
+     libidn             |                   [] []       []    []          |
+     liferea            |       []    []       []             [] []       |
+     lilypond           |                                     []          |
+     lordsawar          |                                                 |
+     lprng              |                               []                |
+     lynx               |                      []       []    [] []       |
+     m4                 | []    []          []          []       []       |
+     mailfromd          |                                                 |
+     mailutils          |                                                 |
+     make               |                   []          []    [] []       |
+     man-db             |                               []       []       |
+     man-db-manpages    |                               []       []       |
+     midi-instruments   |       []    []    [] [] []    [] [] [] []       |
+     minicom            |                      []       []       []       |
+     mkisofs            |                               []    []          |
+     myserver           |                                     []          |
+     nano               | []    []          [] []             [] []       |
+     opcodes            | []                            []    []          |
+     parted             |       []             []       []    [] []       |
+     pies               |                                                 |
+     pnmixer            |                   []                []          |
+     popt               | []    [] []       [] []    [] [] [] [] []       |
+     procps-ng          |                                                 |
+     procps-ng-man      |                                                 |
+     psmisc             |                   [] []       []    []          |
+     pspp               |       []                               []       |
+     pushover           |                                     []          |
+     pwdutils           |                               []                |
+     pyspread           |                                                 |
+     radius             |                               []                |
+     recode             | []    []    []    [] []       []    []          |
+     recutils           |                                                 |
+     rpm                |                               []                |
+     rush               |       []                                        |
+     sarg               |                                                 |
+     sed                | []    []          [] []       []    [] []       |
+     sharutils          |                                                 |
+     shishi             |                                                 |
+     skribilo           |                      []                         |
+     solfege            |       []                            []          |
+     solfege-manual     |                                                 |
+     spotmachine        |                                                 |
+     sudo               |       []          []                [] []       |
+     sudoers            |                   []                [] []       |
+     sysstat            |                   [] []       []       []       |
+     tar                | []                [] []       []    [] []       |
+     texinfo            |                   []          []    []          |
+     texinfo_document   |                   [] []             []          |
+     tigervnc           |                                                 |
+     tin                |                                                 |
+     tin-man            |                                                 |
+     tracgoogleappsa... |       []    []    [] []                         |
+     trader             |                   [] []                         |
+     util-linux         |                                        []       |
+     ve                 |                                     []          |
+     vice               |                      ()             ()          |
+     vmm                |                                                 |
+     vorbis-tools       |                   []          []                |
+     wastesedge         |                                     []          |
+     wcd                |                                                 |
+     wcd-man            |                                                 |
+     wdiff              |       []             []             []          |
+     wget               |                   [] []             [] []       |
+     wyslij-po          |       []          []          []                |
+     xboard             |                                                 |
+     xdg-user-dirs      | [] [] [] [] [] [] [] []    [] [] [] [] []    [] |
+     xkeyboard-config   |       []          [] []       []    [] []       |
+                        +-------------------------------------------------+
+                          ga gd gl gu he hi hr hu hy ia id is it ja ka kk
+                          35  2 47  4  8  2 60 71  2  6 81 11 87 57  0  3
+
+                          kn ko ku ky lg lt lv mk ml mn mr ms mt nb ne nl 
+                        +--------------------------------------------------+
+     a2ps               |                                  []          []  |
+     aegis              |                                              []  |
+     anubis             |                                  []    []    []  |
+     aspell             |                            []                []  |
+     bash               |                                        []    []  |
+     bfd                |                                                  |
+     binutils           |                                                  |
+     bison              |                                              []  |
+     bison-runtime      |          []    [] []             []    []    []  |
+     buzztrax           |                                                  |
+     ccd2cue            |                                                  |
+     ccide              |                   []                         []  |
+     cflow              |                                              []  |
+     clisp              |                                              []  |
+     coreutils          |                                        []    []  |
+     cpio               |                                              []  |
+     cppi               |                                                  |
+     cpplib             |                                              []  |
+     cryptsetup         |                                              []  |
+     datamash           |                                        []    []  |
+     denemo             |                                                  |
+     dfarc              |                      []                      []  |
+     dialog             |       []       [] []             []    []    []  |
+     dico               |                                                  |
+     diffutils          |                   []                   []    []  |
+     dink               |                                              []  |
+     direvent           |                                              []  |
+     doodle             |                                              []  |
+     dos2unix           |                                        []    []  |
+     dos2unix-man       |                                              []  |
+     e2fsprogs          |                                              []  |
+     enscript           |                                              []  |
+     exif               |    []             []                         []  |
+     fetchmail          |                                              []  |
+     findutils          |                                        []    []  |
+     flex               |                                              []  |
+     freedink           |                                        []    []  |
+     fusionforge        |                                                  |
+     gas                |                                                  |
+     gawk               |                                              []  |
+     gcal               |                                                  |
+     gcc                |                                                  |
+     gdbm               |                                                  |
+     gettext-examples   |          []       []             [] [] []    []  |
+     gettext-runtime    |    []                                  []    []  |
+     gettext-tools      |    []                                            |
+     gjay               |                                                  |
+     glunarclock        |                   []                         []  |
+     gnubiff            |                                              []  |
+     gnubik             |                                        []    []  |
+     gnucash            | () ()          () ()          ()       () () []  |
+     gnuchess           |                                        []    []  |
+     gnulib             |                                              []  |
+     gnunet             |                                                  |
+     gnunet-gtk         |                                                  |
+     gold               |                                                  |
+     gphoto2            |                                              []  |
+     gprof              |                                  []          []  |
+     gramadoir          |                                              []  |
+     grep               |                                        []    []  |
+     grub               |                []                      []    []  |
+     gsasl              |                                              []  |
+     gss                |                                                  |
+     gst-plugins-bad    |                   []                   []    []  |
+     gst-plugins-base   |                   []                   []    []  |
+     gst-plugins-good   |                [] []                   []    []  |
+     gst-plugins-ugly   |                   []             [] [] []    []  |
+     gstreamer          |                []                      []    []  |
+     gtick              |                                              []  |
+     gtkam              |                                        []    []  |
+     gtkspell           |          []    [] []       []    []    []    []  |
+     guix               |                                                  |
+     guix-packages      |                                                  |
+     gutenprint         |                                              []  |
+     hello              |                   []                   []    []  |
+     help2man           |                                        []        |
+     help2man-texi      |                                                  |
+     hylafax            |                                              []  |
+     idutils            |                                              []  |
+     iso_15924          |                () []                         []  |
+     iso_3166           | [] [] []       () [] [] []    []       []    []  |
+     iso_3166_2         |                ()                            []  |
+     iso_4217           |                () []                   []    []  |
+     iso_639            | [] []          () []    []    []             []  |
+     iso_639_3          | []             ()             []                 |
+     iso_639_5          |                ()                                |
+     jwhois             |                   []                         []  |
+     kbd                |                                              []  |
+     klavaro            |                                        []    []  |
+     ld                 |                                                  |
+     leafpad            |    []    []    [] []                         []  |
+     libc               |    []                                        []  |
+     libexif            |                                              []  |
+     libextractor       |                                              []  |
+     libgnutls          |                                  []          []  |
+     libgphoto2         |                                              []  |
+     libgphoto2_port    |                                              []  |
+     libgsasl           |                                              []  |
+     libiconv           |                []                            []  |
+     libidn             |                                              []  |
+     liferea            |                [] []                         []  |
+     lilypond           |                                              []  |
+     lordsawar          |                                                  |
+     lprng              |                                                  |
+     lynx               |                                              []  |
+     m4                 |                                              []  |
+     mailfromd          |                                                  |
+     mailutils          |                                                  |
+     make               |    []                                        []  |
+     man-db             |                                              []  |
+     man-db-manpages    |                                              []  |
+     midi-instruments   |    [] []       []          []    []       [] []  |
+     minicom            |                                        []        |
+     mkisofs            |                                              []  |
+     myserver           |                                                  |
+     nano               |                                  []    []    []  |
+     opcodes            |                                              []  |
+     parted             |    []                                        []  |
+     pies               |                                                  |
+     pnmixer            |                                              []  |
+     popt               | [] []             []                   []    []  |
+     procps-ng          |                                                  |
+     procps-ng-man      |                                                  |
+     psmisc             |                                              []  |
+     pspp               |                []                            []  |
+     pushover           |                                                  |
+     pwdutils           |                                              []  |
+     pyspread           |                                                  |
+     radius             |                                              []  |
+     recode             |                                        []    []  |
+     recutils           |                                              []  |
+     rpm                |                                              []  |
+     rush               |                                              []  |
+     sarg               |                                                  |
+     sed                |                                        []    []  |
+     sharutils          |                                              []  |
+     shishi             |                                                  |
+     skribilo           |                                                  |
+     solfege            |                                        []    []  |
+     solfege-manual     |                                              []  |
+     spotmachine        |                                              []  |
+     sudo               |    []                                  []    []  |
+     sudoers            |    []                                  []    []  |
+     sysstat            |                                        []    []  |
+     tar                |          []                            []    []  |
+     texinfo            |                                              []  |
+     texinfo_document   |                                              []  |
+     tigervnc           |                                              []  |
+     tin                |                                                  |
+     tin-man            |                                                  |
+     tracgoogleappsa... |                   []                   []    []  |
+     trader             |                                        []        |
+     util-linux         |                                              []  |
+     ve                 |                                              []  |
+     vice               |                                              []  |
+     vmm                |                                              []  |
+     vorbis-tools       |                                              []  |
+     wastesedge         |                                              []  |
+     wcd                |                                              []  |
+     wcd-man            |                                              []  |
+     wdiff              |                                              []  |
+     wget               |                                        []    []  |
+     wyslij-po          |                                              []  |
+     xboard             |                                              []  |
+     xdg-user-dirs      | [] [] [] []    [] [] [] []    []       []    []  |
+     xkeyboard-config   |    []          []                            []  |
+                        +--------------------------------------------------+
+                          kn ko ku ky lg lt lv mk ml mn mr ms mt nb ne nl 
+                           5 15  4  6  0 13 23  3  3  3  4 11  2 42  1 125
+
+                          nn or pa pl  ps pt pt_BR ro ru rw sk sl sq sr 
+                        +------------------------------------------------+
+     a2ps               |          []     []  []   [] []       []    []  |
+     aegis              |                     []      []                 |
+     anubis             |          []                 []             []  |
+     aspell             |          []         []   [] []    [] []    []  |
+     bash               |          []         []      []    [] []    []  |
+     bfd                |                             []             []  |
+     binutils           |                             []             []  |
+     bison              |          []         []                     []  |
+     bison-runtime      |          []     []  []   [] []       [] [] []  |
+     buzztrax           |                     []                         |
+     ccd2cue            |                     []                     []  |
+     ccide              |          []                 []             []  |
+     cflow              |          []         []                     []  |
+     clisp              |                             []                 |
+     coreutils          |          []                 []       []    []  |
+     cpio               |          []                 []             []  |
+     cppi               |          []         []                     []  |
+     cpplib             |                     []      []             []  |
+     cryptsetup         |          []         []                     []  |
+     datamash           |                     []                     []  |
+     denemo             |                                                |
+     dfarc              |          []         []                     []  |
+     dialog             |          []         []   [] []    [] []    []  |
+     dico               |          []                                    |
+     diffutils          |          []         []                     []  |
+     dink               |                                                |
+     direvent           |          []         []                     []  |
+     doodle             |                                         [] []  |
+     dos2unix           |          []         []      []             []  |
+     dos2unix-man       |          []         []                         |
+     e2fsprogs          |          []                                    |
+     enscript           |          []         []   [] []       []    []  |
+     exif               |          []         []   [] []    []       []  |
+     fetchmail          |          []                 []          []     |
+     findutils          |          []         []      []    [] []    []  |
+     flex               |          []         []   [] []             []  |
+     freedink           |          []         []      []       []    []  |
+     fusionforge        |                                                |
+     gas                |                                                |
+     gawk               |          []                                    |
+     gcal               |                                                |
+     gcc                |                                                |
+     gdbm               |          []         []                     []  |
+     gettext-examples   |          []     []  []   [] []    [] []    []  |
+     gettext-runtime    | []       []     []  []   [] []    [] []    []  |
+     gettext-tools      |          []         []   [] []    [] []    []  |
+     gjay               |                                            []  |
+     glunarclock        |          []         []   []       [] []    []  |
+     gnubiff            |                                            []  |
+     gnubik             |          []         []               []    []  |
+     gnucash            |          ()     ()  ()   () ()             []  |
+     gnuchess           |                     []                     []  |
+     gnulib             |          []         []      []       []    []  |
+     gnunet             |                                                |
+     gnunet-gtk         |                                                |
+     gold               |                                                |
+     gphoto2            |          []         []   [] []             []  |
+     gprof              |                     []   [] []             []  |
+     gramadoir          |                                   []       []  |
+     grep               |          []         []      []    [] []    []  |
+     grub               |          []         []      []       []    []  |
+     gsasl              |          []                       []       []  |
+     gss                |          []              []       []       []  |
+     gst-plugins-bad    |          []         []      []    []       []  |
+     gst-plugins-base   |          []         []      []    [] []    []  |
+     gst-plugins-good   |          []         []   [] []    [] []    []  |
+     gst-plugins-ugly   |          []         []   [] []    [] []    []  |
+     gstreamer          |          []         []   [] []    [] []    []  |
+     gtick              |          []         []      []    []       []  |
+     gtkam              |       [] []         []      []    []       []  |
+     gtkspell           |          []     []  []   [] []    [] [] [] []  |
+     guix               |                                                |
+     guix-packages      |                                                |
+     gutenprint         |                                   [] []        |
+     hello              |          []         []      []    [] []    []  |
+     help2man           |          []         []      []             []  |
+     help2man-texi      |          []                                    |
+     hylafax            |                                                |
+     idutils            |          []                 []             []  |
+     iso_15924          |          []     ()       [] []       []    []  |
+     iso_3166           | [] [] [] []     ()  []   [] [] [] [] [] [] []  |
+     iso_3166_2         |          []     ()                         []  |
+     iso_4217           | []       []     ()       [] [] []    []    []  |
+     iso_639            |    [] [] []     ()       [] [] [] [] []    []  |
+     iso_639_3          |       []        ()                             |
+     iso_639_5          |                 ()                         []  |
+     jwhois             |          []         []   []                []  |
+     kbd                |          []                 []                 |
+     klavaro            |       [] []         []      []       []        |
+     ld                 |                                                |
+     leafpad            | []       []     []  []      []    [] []    []  |
+     libc               |          []                 []    []           |
+     libexif            |          []         ()            []           |
+     libextractor       |          []                                    |
+     libgnutls          |          []                                    |
+     libgphoto2         |          []                                    |
+     libgphoto2_port    |          []         []      []    []       []  |
+     libgsasl           |          []              []       []       []  |
+     libiconv           |          []         []            [] []    []  |
+     libidn             |          []         []                     []  |
+     liferea            |          []     []  []   [] ()    []    []     |
+     lilypond           |                                                |
+     lordsawar          |                                                |
+     lprng              |          []                                    |
+     lynx               |                     []      []                 |
+     m4                 |          []         []   [] []             []  |
+     mailfromd          |          []                                    |
+     mailutils          |          []                                    |
+     make               |          []         []      []                 |
+     man-db             |          []                 []             []  |
+     man-db-manpages    |          []                 []             []  |
+     midi-instruments   |          []     []  []   [] []    [] []    []  |
+     minicom            |          []         []   [] []                 |
+     mkisofs            |          []                 []             []  |
+     myserver           |                                      []    []  |
+     nano               |          []         []   [] []       []    []  |
+     opcodes            |                                                |
+     parted             |          []         []      []    [] []    []  |
+     pies               |          []                                    |
+     pnmixer            |                             []                 |
+     popt               |          []     []  []      []       []    []  |
+     procps-ng          |          []                                    |
+     procps-ng-man      |          []                                    |
+     psmisc             |          []         []      []             []  |
+     pspp               |          []                 []                 |
+     pushover           |                                                |
+     pwdutils           |          []                                    |
+     pyspread           | []                  []                         |
+     radius             |          []                 []                 |
+     recode             |          []     []  []   [] []    [] []    []  |
+     recutils           |                     []                     []  |
+     rpm                |          []                                    |
+     rush               |          []         []                     []  |
+     sarg               |                     []      []                 |
+     sed                |          []     []  []   [] []    [] []    []  |
+     sharutils          |          []         []                     []  |
+     shishi             |          []                                []  |
+     skribilo           |                                            []  |
+     solfege            |          []         []      []                 |
+     solfege-manual     |          []         []                         |
+     spotmachine        |                     []                     []  |
+     sudo               |          []         []      []    [] []    []  |
+     sudoers            |          []         []               []    []  |
+     sysstat            |          []         []      []    []       []  |
+     tar                |          []         []      []       []    []  |
+     texinfo            |          []         []      []                 |
+     texinfo_document   |          []         []                         |
+     tigervnc           |                     []      []             []  |
+     tin                |                             []                 |
+     tin-man            |                                                |
+     tracgoogleappsa... |          []         []      []             []  |
+     trader             |                             []             []  |
+     util-linux         |          []         []                         |
+     ve                 |          []         []                     []  |
+     vice               |                                                |
+     vmm                |                                                |
+     vorbis-tools       |          []                          []    []  |
+     wastesedge         |                                                |
+     wcd                |                                                |
+     wcd-man            |                                                |
+     wdiff              |          []         []      []       []    []  |
+     wget               |          []         []      []    []       []  |
+     wyslij-po          | []       []         []                     []  |
+     xboard             |          []                 []             []  |
+     xdg-user-dirs      | [] [] [] []  [] []  []   [] []    [] [] [] []  |
+     xkeyboard-config   |          []         []      []       []        |
+                        +------------------------------------------------+
+                          nn or pa pl  ps pt pt_BR ro ru rw sk sl sq sr 
+                           7  3  6 114  1 12  88   32 82  3 40 45  7 101
+
+                          sv  sw ta te tg th tr uk  ur vi  wa wo zh_CN
+                        +----------------------------------------------+
+     a2ps               | []              [] [] []     []              |
+     aegis              |                              []              |
+     anubis             | []                 [] []     []              |
+     aspell             | []                    []     []  []     []   |
+     bash               | []                    []     []         []   |
+     bfd                | []                    []     []              |
+     binutils           | []                    []     []              |
+     bison              | []                    []     []         []   |
+     bison-runtime      | []              [] [] []     []         []   |
+     buzztrax           | []                           []         []   |
+     ccd2cue            |                       []     []         []   |
+     ccide              | []                    []     []         []   |
+     cflow              | []                    []     []         []   |
+     clisp              |                                              |
+     coreutils          | []                    []     []              |
+     cpio               | []                 [] []     []         []   |
+     cppi               | []                    []     []         []   |
+     cpplib             | []                 [] []     []         []   |
+     cryptsetup         |                       []     []         []   |
+     datamash           | []                    []     []              |
+     denemo             |                                         []   |
+     dfarc              | []                           []              |
+     dialog             | []  []          []           []  []     []   |
+     dico               |                       []                     |
+     diffutils          | []                 [] []     []         []   |
+     dink               | []                                           |
+     direvent           |                       []     []              |
+     doodle             | []                           []              |
+     dos2unix           | []                    []     []         []   |
+     dos2unix-man       | []                    []                []   |
+     e2fsprogs          | []                    []     []         []   |
+     enscript           | []                 [] []     []              |
+     exif               | []                 [] []     []         []   |
+     fetchmail          | []                 []        []         []   |
+     findutils          | []                 [] []     []         []   |
+     flex               | []                 []        []         []   |
+     freedink           | []              []           []              |
+     fusionforge        |                                              |
+     gas                |                       []                     |
+     gawk               | []                           []         []   |
+     gcal               | []                 []                   []   |
+     gcc                | []                                           |
+     gdbm               |                       []     []              |
+     gettext-examples   | []                 [] []     []         []   |
+     gettext-runtime    | []                 [] []     []         []   |
+     gettext-tools      | []                 [] []     []         []   |
+     gjay               |                 []           []         []   |
+     glunarclock        | []                           []  []     []   |
+     gnubiff            | []                           []              |
+     gnubik             | []                    []     []         []   |
+     gnucash            |        () ()              () ()         []   |
+     gnuchess           |                       []     []         []   |
+     gnulib             | []                    []     []         []   |
+     gnunet             |                                              |
+     gnunet-gtk         |                                              |
+     gold               |                       []     []              |
+     gphoto2            | []                    []     []         []   |
+     gprof              | []                 [] []     []              |
+     gramadoir          | []                           []         []   |
+     grep               | []              []    []     []         []   |
+     grub               | []                 [] []     []              |
+     gsasl              | []                    []     []         []   |
+     gss                | []                           []         []   |
+     gst-plugins-bad    | []                 [] []     []         []   |
+     gst-plugins-base   | []                 [] []     []         []   |
+     gst-plugins-good   | []                 [] []     []         []   |
+     gst-plugins-ugly   | []                 [] []     []         []   |
+     gstreamer          | []                 [] []     []         []   |
+     gtick              |                       []     []         []   |
+     gtkam              | []                    []     []         []   |
+     gtkspell           | []              [] [] []     []  []     []   |
+     guix               |                                              |
+     guix-packages      |                                              |
+     gutenprint         |                    [] []     []         []   |
+     hello              | []              [] [] []     []         []   |
+     help2man           |                       []     []         []   |
+     help2man-texi      |                       []                     |
+     hylafax            |                              []              |
+     idutils            |                       []     []         []   |
+     iso_15924          | []              () [] []     ()         []   |
+     iso_3166           | []        []    () [] []     ()  []     []   |
+     iso_3166_2         |                 () [] []     ()         []   |
+     iso_4217           | []              () [] []     ()         []   |
+     iso_639            | []     [] []    () [] []     ()  []     []   |
+     iso_639_3          |        []       () [] []     ()              |
+     iso_639_5          |                 ()    []     ()              |
+     jwhois             | []                 []        []         []   |
+     kbd                | []                    []     []         []   |
+     klavaro            | []                    []  [] []     []  []   |
+     ld                 | []                 [] []     []         []   |
+     leafpad            | []              [] [] []     []         []   |
+     libc               | []                 [] []     []         []   |
+     libexif            | []                           []         ()   |
+     libextractor       |                       []     []              |
+     libgnutls          | []                    []     []         []   |
+     libgphoto2         | []                    []     []              |
+     libgphoto2_port    | []                    []     []         []   |
+     libgsasl           | []                    []     []         []   |
+     libiconv           | []                    []     []  []     []   |
+     libidn             | ()                    []     []         []   |
+     liferea            | []                 [] []     []         []   |
+     lilypond           |                              []              |
+     lordsawar          |                                              |
+     lprng              |                              []              |
+     lynx               | []                 [] []     []              |
+     m4                 | []                           []         []   |
+     mailfromd          |                       []     []              |
+     mailutils          |                              []              |
+     make               | []                    []     []         []   |
+     man-db             | []                           []         []   |
+     man-db-manpages    | []                                      []   |
+     midi-instruments   | []              [] [] []     []         []   |
+     minicom            | []                           []              |
+     mkisofs            |                       []     []         []   |
+     myserver           |                              []              |
+     nano               | []                    []     []         []   |
+     opcodes            |                       []     []         []   |
+     parted             | []                 [] []     []         []   |
+     pies               |                       []     []              |
+     pnmixer            |                       []     []         []   |
+     popt               | []     []       [] [] []     []         []   |
+     procps-ng          |                       []     []              |
+     procps-ng-man      |                       []                     |
+     psmisc             | []                    []     []         []   |
+     pspp               |                    [] []                []   |
+     pushover           | []                                           |
+     pwdutils           | []                           []              |
+     pyspread           |                       []                     |
+     radius             |                       []     []              |
+     recode             | []                 []        []         []   |
+     recutils           | []                    []     []              |
+     rpm                | []                    []     []         []   |
+     rush               |                       []     []              |
+     sarg               |                                              |
+     sed                | []                 [] []     []         []   |
+     sharutils          | []                    []     []         []   |
+     shishi             |                              []         []   |
+     skribilo           | []                    []                     |
+     solfege            | []                 []        []         []   |
+     solfege-manual     |                    []                        |
+     spotmachine        | []                    []     []              |
+     sudo               | []                 [] []     []         []   |
+     sudoers            | []                    []     []         []   |
+     sysstat            | []                 [] []     []         []   |
+     tar                | []                 [] []     []         []   |
+     texinfo            |                    [] []     []              |
+     texinfo_document   |                       []                     |
+     tigervnc           | []                    []                []   |
+     tin                |                                         []   |
+     tin-man            |                                              |
+     tracgoogleappsa... | []              []    []     []         []   |
+     trader             | []                                           |
+     util-linux         | []                    []     []         []   |
+     ve                 | []                    []     []         []   |
+     vice               | ()                 ()                        |
+     vmm                |                                              |
+     vorbis-tools       | []                           []              |
+     wastesedge         |                                              |
+     wcd                |                       []     []         []   |
+     wcd-man            |                       []                     |
+     wdiff              | []                    []     []         []   |
+     wget               |                       []     []         []   |
+     wyslij-po          |                       []     []              |
+     xboard             |                       []                []   |
+     xdg-user-dirs      | []     [] []    [] [] []     []         []   |
+     xkeyboard-config   | []                 [] []     []              |
+                        +----------------------------------------------+
+                          sv  sw ta te tg th tr uk  ur vi  wa wo zh_CN
+                          106  1  4  3  0 13 51 115  1 125  7  1  100 
+
+                          zh_HK zh_TW
+                        +-------------+
+     a2ps               |             | 30
+     aegis              |             |  9
+     anubis             |             | 19
+     aspell             |             | 29
+     bash               |        []   | 23
+     bfd                |             | 11
+     binutils           |             | 12
+     bison              |        []   | 18
+     bison-runtime      |        []   | 38
+     buzztrax           |             |  9
+     ccd2cue            |             | 10
+     ccide              |             | 17
+     cflow              |             | 16
+     clisp              |             | 10
+     coreutils          |             | 18
+     cpio               |             | 20
+     cppi               |             | 17
+     cpplib             |        []   | 19
+     cryptsetup         |             | 14
+     datamash           |             | 11
+     denemo             |             |  5
+     dfarc              |             | 17
+     dialog             |        []   | 42
+     dico               |             |  6
+     diffutils          |             | 22
+     dink               |             | 10
+     direvent           |             | 11
+     doodle             |             | 12
+     dos2unix           |        []   | 18
+     dos2unix-man       |             |  9
+     e2fsprogs          |             | 15
+     enscript           |             | 21
+     exif               |             | 27
+     fetchmail          |             | 19
+     findutils          |             | 29
+     flex               |        []   | 19
+     freedink           |             | 24
+     fusionforge        |             |  3
+     gas                |             |  5
+     gawk               |             | 13
+     gcal               |             |  8
+     gcc                |             |  2
+     gdbm               |             | 10
+     gettext-examples   |  []    []   | 40
+     gettext-runtime    |  []    []   | 35
+     gettext-tools      |        []   | 24
+     gjay               |             |  9
+     glunarclock        |        []   | 27
+     gnubiff            |             |  9
+     gnubik             |             | 19
+     gnucash            |        ()   |  6
+     gnuchess           |             | 11
+     gnulib             |             | 23
+     gnunet             |             |  1
+     gnunet-gtk         |             |  1
+     gold               |             |  7
+     gphoto2            |        []   | 19
+     gprof              |             | 21
+     gramadoir          |             | 14
+     grep               |        []   | 31
+     grub               |             | 21
+     gsasl              |        []   | 19
+     gss                |             | 17
+     gst-plugins-bad    |             | 21
+     gst-plugins-base   |             | 27
+     gst-plugins-good   |             | 32
+     gst-plugins-ugly   |             | 34
+     gstreamer          |        []   | 32
+     gtick              |             | 19
+     gtkam              |             | 24
+     gtkspell           |  []    []   | 48
+     guix               |             |  2
+     guix-packages      |             |  0
+     gutenprint         |             | 15
+     hello              |        []   | 30
+     help2man           |             | 18
+     help2man-texi      |             |  5
+     hylafax            |             |  5
+     idutils            |             | 14
+     iso_15924          |        []   | 23
+     iso_3166           |  []    []   | 58
+     iso_3166_2         |             |  9
+     iso_4217           |  []    []   | 28
+     iso_639            |  []    []   | 46
+     iso_639_3          |             | 10
+     iso_639_5          |             |  2
+     jwhois             |        []   | 20
+     kbd                |             | 17
+     klavaro            |             | 30
+     ld                 |        []   | 15
+     leafpad            |        []   | 39
+     libc               |        []   | 24
+     libexif            |             | 10
+     libextractor       |             |  5
+     libgnutls          |             | 13
+     libgphoto2         |             | 10
+     libgphoto2_port    |        []   | 19
+     libgsasl           |             | 18
+     libiconv           |        []   | 29
+     libidn             |             | 17
+     liferea            |             | 29
+     lilypond           |             | 11
+     lordsawar          |             |  3
+     lprng              |             |  3
+     lynx               |             | 19
+     m4                 |        []   | 22
+     mailfromd          |             |  4
+     mailutils          |             |  6
+     make               |             | 19
+     man-db             |             | 15
+     man-db-manpages    |             | 10
+     midi-instruments   |        []   | 43
+     minicom            |        []   | 17
+     mkisofs            |             | 13
+     myserver           |             |  9
+     nano               |        []   | 30
+     opcodes            |             | 12
+     parted             |        []   | 23
+     pies               |             |  4
+     pnmixer            |             |  9
+     popt               |        []   | 36
+     procps-ng          |             |  5
+     procps-ng-man      |             |  4
+     psmisc             |        []   | 22
+     pspp               |             | 13
+     pushover           |             |  6
+     pwdutils           |             |  8
+     pyspread           |             |  6
+     radius             |             |  9
+     recode             |             | 31
+     recutils           |             | 10
+     rpm                |        []   | 13
+     rush               |             | 10
+     sarg               |             |  4
+     sed                |        []   | 35
+     sharutils          |             | 13
+     shishi             |             |  7
+     skribilo           |             |  7
+     solfege            |             | 21
+     solfege-manual     |             |  9
+     spotmachine        |             | 11
+     sudo               |             | 26
+     sudoers            |             | 22
+     sysstat            |             | 23
+     tar                |        []   | 30
+     texinfo            |             | 17
+     texinfo_document   |             | 13
+     tigervnc           |             | 14
+     tin                |        []   |  7
+     tin-man            |             |  1
+     tracgoogleappsa... |        []   | 22
+     trader             |             | 12
+     util-linux         |             | 13
+     ve                 |             | 14
+     vice               |             |  1
+     vmm                |             |  3
+     vorbis-tools       |             | 13
+     wastesedge         |             |  3
+     wcd                |             |  8
+     wcd-man            |             |  3
+     wdiff              |        []   | 23
+     wget               |             | 21
+     wyslij-po          |             | 14
+     xboard             |             | 10
+     xdg-user-dirs      |  []    []   | 68
+     xkeyboard-config   |        []   | 28
+                        +-------------+
+       89 teams           zh_HK zh_TW
+      166 domains           7    42    2809
+
+   Some counters in the preceding matrix are higher than the number of
+visible blocks let us expect.  This is because a few extra PO files are
+used for implementing regional variants of languages, or language
+dialects.
+
+   For a PO file in the matrix above to be effective, the package to
+which it applies should also have been internationalized and distributed
+as such by its maintainer.  There might be an observable lag between the
+mere existence a PO file and its wide availability in a distribution.
+
+   If Jun 2014 seems to be old, you may fetch a more recent copy of this
+'ABOUT-NLS' file on most GNU archive sites.  The most up-to-date matrix
+with full percentage details can be found at
+'http://translationproject.org/extra/matrix.html'.
+
+1.5 Using 'gettext' in new packages
+===================================
+
+If you are writing a freely available program and want to
+internationalize it you are welcome to use GNU 'gettext' in your
+package.  Of course you have to respect the GNU Lesser General Public
+License which covers the use of the GNU 'gettext' library.  This means
+in particular that even non-free programs can use 'libintl' as a shared
+library, whereas only free software can use 'libintl' as a static
+library or use modified versions of 'libintl'.
+
+   Once the sources are changed appropriately and the setup can handle
+the use of 'gettext' the only thing missing are the translations.  The
+Free Translation Project is also available for packages which are not
+developed inside the GNU project.  Therefore the information given above
+applies also for every other Free Software Project.  Contact
+'coordinator@translationproject.org' to make the '.pot' files available
+to the translation teams.
Index: csvn-ui-0.1.5/ChangeLog
===================================================================
--- csvn-ui-0.1.5/ChangeLog	(nonexistent)
+++ csvn-ui-0.1.5/ChangeLog	(revision 12)
@@ -0,0 +1,6 @@
+2020-10-09  gettextize  <bug-gnu-gettext@gnu.org>
+
+	* Makefile.am (SUBDIRS): Add po.
+	(EXTRA_DIST): Add config.rpath, m4/ChangeLog.
+	* configure.ac (AC_CONFIG_FILES): Add po/Makefile.in.
+
Index: csvn-ui-0.1.5/LICENSE
===================================================================
--- csvn-ui-0.1.5/LICENSE	(nonexistent)
+++ csvn-ui-0.1.5/LICENSE	(revision 12)
@@ -0,0 +1,268 @@
+
+
+                                 Radix.pro License
+                              Version 1.0, March 2016
+                  https://radix.pro/licenses/LICENSE-1.0-en_US.txt
+
+
+1. Definitions
+
+   1.1. "License"
+
+        means the terms and conditions for use, reproduction, and distribution
+        as defined by this document.
+
+
+   1.2. "Licensor"
+
+        means the copyright owner or entity authorized by the copyright owner that is
+        granting the License.
+
+
+   1.3. "Legal Entity"
+
+        means the union of the acting entity and all other entities that control, are
+        controlled by, or are under common control with that entity. For the purposes
+        of this definition, "control" means:
+          a. the power, direct or indirect, to cause the direction or management of such
+             entity, whether by contract or otherwise, or
+          b. ownership of fifty percent (50%) or more of the outstanding shares, or
+          c. beneficial ownership of such entity.
+
+
+   1.4. "You" (or "Your")
+
+        means an individual or Legal Entity exercising permissions granted by this License.
+
+
+   1.5. “Licensable”
+
+        means having the right to grant, to the maximum extent possible, whether at the
+        time of the initial grant or subsequently, any and all of the rights conveyed
+        by this License.
+
+
+   1.6. "Source Form"
+
+        means the form of the Work preferred for making Modifications, including but not limited
+        to software source code, documentation source, and configuration files.
+
+
+   1.7. "Object Form"
+
+        means any form resulting from mechanical  transformation or translation of a Source form,
+        including but not limited to compiled object code, generated documentation, and conversions
+        to other media types.
+
+
+   1.8. "Work"
+
+        means the work of authorship, whether in Source or Object Form, made available under
+        the License, as indicated by a copyright notice that is included in or attached to the work
+        (an example is provided in the Appendix below).
+
+
+   1.9. "Derivative Works"
+
+        means any work, whether in Source or Object Form, that is based on (or derived from) the Work
+        and for which the editorial revisions, annotations, elaborations, or other modifications
+        represent, as a whole, an original work of authorship. For the purposes of this License,
+        Derivative Works shall not include works that remain separable from, or merely link
+        (or bind by name) to the interfaces of, the Work and Derivative Works thereof.
+
+
+  1.10. "Contribution"
+
+        means any work of authorship, including the original version of the Work and any modifications
+        or additions to that Work or Derivative Works thereof, that is intentionally submitted to
+        Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity
+        authorized to submit on behalf of the copyright owner. For the purposes of this definition,
+        "submitted" means any form of electronic, verbal, or written communication sent to the Licensor
+        or its representatives, including but not limited to communication on electronic mailing lists,
+        source code control systems, and issue tracking systems that are managed by, or on behalf of,
+        the Licensor for the purpose of discussing and improving the Work, but excluding communication
+        that is conspicuously marked or otherwise designated in writing by the copyright owner
+        as "Not a Contribution."
+
+
+  1.11. "Contributor"
+
+        means Licensor and any individual or Legal Entity on behalf of whom a Contribution has been
+        received by Licensor and subsequently incorporated within the Work.
+
+
+  1.12. “Patent Claims” of a Contributor
+
+        means any patent claim(s), including without limitation, method, process, and apparatus claims,
+        in any patent Licensable by such Contributor that would be infringed, but for the grant of the
+        License, by the making, using, selling, offering for sale, having made, import, or transfer
+        of either its Contributions or its Contributor Version.
+
+
+
+2. Grant of Copyright License
+
+   Subject to the terms and conditions of this License, each Contributor hereby grants to You
+   a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license
+   to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense,
+   and distribute the Work and such Derivative Works in Source or Object Form.
+
+
+3. Grant of Patent License
+
+   Subject to the terms and conditions of this License, each Contributor hereby grants
+   to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+   (except as stated in this section) patent license to make, have made, use, offer to
+   sell, sell, import, and otherwise transfer the Work, where such license applies only
+   to those patent claims Licensable by such Contributor that are necessarily infringed
+   by their Contribution(s) alone or by combination of their Contribution(s) with the
+   Work to which such Contribution(s) was submitted. If You institute patent litigation
+   against any entity (including a cross-claim or counterclaim in a lawsuit) alleging
+   that the Work or a Contribution incorporated within the Work constitutes direct
+   or contributory patent infringement, then any patent licenses granted to You under
+   this License for that Work shall terminate as of the date such litigation is filed.
+
+
+4. Redistribution
+
+   You may reproduce and distribute copies of the Work or Derivative Works thereof
+   in any medium, with or without modifications, and in Source or Object Form, provided
+   that You meet the following conditions:
+
+     a. You must give any other recipients of the Work or  Derivative Works
+        a copy of this License; and
+     b. You must cause any modified files to carry prominent notices stating that
+        You changed the files; and
+     c. You must retain, in the Source form of any Derivative Works that You distribute,
+        all copyright, patent, trademark, and attribution notices from the Source form
+        of the Work, excluding those notices that do not pertain to any part of the
+        Derivative Works; and
+     d. If the Work includes a "PRINCIPLE" text file as part of its distribution, then
+        any Derivative Works that You distribute must include a readable copy of the
+        fundamental ideas, truths or propositions contained within such PRINCIPLE file.
+        You may add Your own fundamental ideas, truths or propositions that serves as
+        the foundation for understanding the internal structure and principles of
+        Derivative works or Contributions.
+
+   You may add Your own copyright statement to Your modifications and may provide additional
+   or different license terms and conditions for use, reproduction, or distribution of Your
+   modifications, or for any such Derivative Works as a whole, provided Your use, reproduction,
+   and distribution of the Work otherwise complies with the conditions stated in this License.
+
+
+5. Submission of Contributions
+
+   Unless You explicitly state otherwise,  any Contribution intentionally submitted for
+   inclusion in the Work by You to the Licensor shall be under the terms and conditions
+   of this License, without any additional terms or conditions. Notwithstanding the above,
+   nothing herein shall supersede or modify the terms of any separate license agreement
+   you may have executed with Licensor regarding such Contributions.
+
+
+6. Trademarks
+
+   This License does not grant permission to use the trade names, trademarks, service marks,
+   or product names of the Licensor, except as required for reasonable and customary use in
+   describing the origin of the Work and reproducing the content of the PRINCIPLE file.
+
+
+7. Disclaimer of Warranty
+
+   Unless required by applicable law or agreed to in writing, Licensor provides the Work
+   (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES
+   OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any
+   warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+   PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of
+   using or redistributing the Work and assume any risks associated with Your exercise of
+   permissions under this License.
+
+
+8. Limitation of Liability
+
+   In no event and under no legal theory, whether in tort (including negligence), contract,
+   or otherwise, unless required by applicable law (such as deliberate and grossly negligent
+   acts) or agreed to in writing, shall any Contributor be liable to You for damages, including
+   any direct, indirect, special, incidental, or consequential damages of any character arising
+   as a result of this License or out of the use or inability to use the Work (including but not
+   limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or
+   any and all other commercial damages or losses), even if such Contributor has been advised
+   of the possibility of such damages.
+
+
+9. Accepting Warranty or Additional Liability
+
+   While redistributing the Work or Derivative Works thereof, You may choose to offer,
+   and charge a fee for, acceptance of support, warranty, indemnity,  or other liability
+   obligations and/or rights consistent with this License. However, in accepting such
+   obligations, You may act only on Your own behalf and on Your sole responsibility, not
+   on behalf of any other Contributor, and only if You agree to indemnify, defend, and
+   hold each Contributor harmless for any liability incurred by, or claims asserted
+   against, such Contributor by reason of your accepting any such warranty or additional
+   liability.
+
+
+APPENDICES
+
+APPENDIX 1: How to apply the Radix.pro License to your work
+
+      To apply the Radix.pro License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+      Copyright [yyyy] [name of copyright owner]
+
+      Licensed under the Radix.pro License, Version 1.0 (the "License");
+      you may not use this file except in compliance with the License.
+      You may obtain a copy of the License at
+
+          https://radix.pro/licenses/LICENSE-1.0-en_US.txt
+
+      Unless required by applicable law or agreed to in writing, software
+      distributed under the License is distributed on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied.
+
+
+APPENDIX 2: Examples of comments
+
+/**********************************************************************
+
+  Copyright 2016 Andrey V.Kosteltsev
+
+  Licensed under the Radix.pro License, Version 1.0 (the "License");
+  you may not use this file  except  in compliance with the License.
+  You may obtain a copy of the License at
+
+     https://radix.pro/licenses/LICENSE-1.0-en_US.txt
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+  implied.
+
+ **********************************************************************/
+
+
+#!/bin/sh
+#######################################################################
+#
+# Copyright 2016 Andrey V.Kosteltsev
+#
+# Licensed under the Radix.pro License, Version 1.0 (the "License");
+# you may not use this file  except  in compliance with the License.
+# You may obtain a copy of the License at
+#
+#    https://radix.pro/licenses/LICENSE-1.0-en_US.txt
+#
+#  Unless required by applicable law or agreed to in writing, software
+#  distributed under the License is distributed on an "AS IS" BASIS,
+#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+#  implied.
+#
+#######################################################################
+
Index: csvn-ui-0.1.5/Makefile.am
===================================================================
--- csvn-ui-0.1.5/Makefile.am	(nonexistent)
+++ csvn-ui-0.1.5/Makefile.am	(revision 12)
@@ -0,0 +1,15 @@
+
+ACLOCAL_AMFLAGS = -I m4
+
+#
+# In build order:
+# ==============
+#
+SUBDIRS = po csvncgi
+
+EXTRA_DIST = config.rpath m4/ChangeLog  \
+             doc l10n LICENSE README.md acsite.m4 auto-clean bootstrap \
+             csvncgi/robots.txt csvncgi/.csvn \
+             .svnignore .gitignore
+
+noinst_HEADERS = defs.h gettext.h nls.h
Index: csvn-ui-0.1.5/README
===================================================================
--- csvn-ui-0.1.5/README	(nonexistent)
+++ csvn-ui-0.1.5/README	(revision 12)
@@ -0,0 +1,2 @@
+
+see README.md instead
Index: csvn-ui-0.1.5/README.md
===================================================================
--- csvn-ui-0.1.5/README.md	(nonexistent)
+++ csvn-ui-0.1.5/README.md	(revision 12)
@@ -0,0 +1,390 @@
+
+# cSvn-UI for SVN Repositories
+
+**cSvn-UI** &#8211; is a web interface for Subversion (SVN) Repositories. **cSvn** CGI script is writen in **C**
+and therefore it&#39;s fast enough.
+
+
+## Table of Contents
+
+* [Reqired packages](#reqired-packages)
+* [Installation](#installation)
+    * [Bootstrap Script](#bootstrap-script)
+    * [Configuring Sources](#configuring-sources)
+    * [Post Install](#post-install)
+* [uWsgi Configuration](#uwsgi)
+* [Nginx Configuration](#nginx)
+* [Configuring SVN Repositories](#configuring-svn-repositories)
+* [See Also](#see-also)
+* [Copyright and License](#copyright-and-license)
+
+
+## Reqired packages
+
+**cSvn-ui** depends of following libraries: [libpcre2-8](https://www.pcre.org/),
+[librt](https://www.gnu.org/software/libc/), [libm](https://www.gnu.org/software/libc/),
+[libmd4c](https://github.com/mity/md4c/), [libmd4c-html](https://github.com/mity/md4c/),
+[libmagic](http://darwinsys.com/file/), and [libxml2](http://www.xmlsoft.org/).
+
+From the moment when the **cSvn** package was split into two, so as do not produce
+unnecessary entities, **cSvn-ui** depends on the **cScm** package. Therefore, before
+installing **cSvn-ui**, you have to install and configure
+[**cScm Configuration Daemon**](https://csvn.radix.pro/scm-tools/cscm/trunk/README.md).
+
+To use **cSvn-ui** a web server must be installed and configured on the system. We recommend
+the [Nginx](https://nginx.org/en/) with [uWsgi](https://uwsgi-docs.readthedocs.io/en/latest/)
+application server. Of course [Apache Subversion](https://subversion.apache.org/) SCM system
+should be installed too.
+
+
+## Installation
+
+To obtain sources we have to checkout its from SVN repository:
+
+```Bash
+svn checkout svn://radix.pro/scm-tools/csvn-ui/tags/csvn-ui-0.1.3 csvn-ui-0.1.3
+```
+and run the bootstrap script:
+
+```Bash
+cd csvn-ui-0.1.3
+./bootstrap
+```
+Also **cSvn-ui** source packages are available for download on the
+[Radix.pro FTP-server](https://ftp.radix.pro/pub/csvn-ui/).
+
+
+### Bootstrap Script
+
+The *bootstrap* script especialy created for *Autotools* install automation. To install
+*Autotools* into sourse directory on build machine (i.e. when **build** == **host**) the *bootstrap*
+script can be run without arguments.
+
+```Bash
+./bootstrap
+```
+
+I this case *Autotools* will be installed from current root file system.
+
+For the cross environment the `--target-dest-dir` option allows to install some stuff from
+development root file system:
+
+```Bash
+TARGET_DEST_DIR=/home/developer/prog/trunk-672/dist/.s9xx-glibc/enybox-x2 \
+       ./bootstrap --target-dest-dir=${TARGET_DEST_DIR}
+```
+
+For example, in this case the *aclocal.m4* script will be collected from the
+`${TARGET_DEST_DIR}/usr/share/aclocal` directory.
+
+
+### Configuring Sources
+
+```Bash
+./configure --prefix=/usr \
+            --with-scriptdir=/var/www/htdocs/csvn
+```
+
+
+#### Install on the Build Machine
+
+```Bash
+make
+make install
+```
+
+
+#### Cross Compilation Example
+
+```Bash
+#!/bin/sh
+
+TARGET_DEST_DIR=/home/developer/prog/trunk-672/dist/.s9xx-glibc/enybox-x2
+TOOLCHAIN_PATH=/opt/toolchains/aarch64-S9XX-linux-glibc/1.1.4/bin
+TARGET=aarch64-s9xx-linux-gnu
+
+./bootstrap --target-dest-dir=${TARGET_DEST_DIR}
+
+PKG_CONFIG=/usr/bin/pkg-config \
+PKG_CONFIG_PATH=${TARGET_DEST_DIR}/usr/lib${LIBDIRSUFFIX}/pkgconfig:${TARGET_DEST_DIR}/usr/share/pkgconfig \
+PKG_CONFIG_LIBDIR=${TARGET_DEST_DIR}/usr/lib${LIBDIRSUFFIX}/pkgconfig:${TARGET_DEST_DIR}/usr/share/pkgconfig \
+STRIP="${TOOLCHAIN_PATH}/${TARGET}-strip" \
+CC="${TOOLCHAIN_PATH}/${TARGET}-gcc --sysroot=${TARGET_DEST_DIR}" \
+./configure --prefix=/usr
+  --build=x86_64-pc-linux-gnu \
+  --host=${TARGET} \
+  --with-scriptdir=/var/www/htdocs/csvn
+
+make
+make install DESTDIR=${TARGET_DEST_DIR}
+```
+
+Also we can make use of additional variables such as `CFLAGS`, `LDFLAGS`:
+
+```Bash
+LDFLAGS="-L${TARGET_DEST_DIR}/lib -L${TARGET_DEST_DIR}/usr/lib"
+TARGET_INCPATH="-L${TARGET_DEST_DIR}/usr/include"
+CFLAGS="${TARGET_INCPATH}"
+CPPFLAGS="${TARGET_INCPATH}"
+```
+
+
+### Post Install
+
+The system user, on whose behalf the **Nginx** server is launched, must have permissions to access
+the directory in which the **cSvn-ui CGI script** was installed:
+
+```Bash
+chown -R nginx:nginx /var/www/htdocs/csvn
+```
+
+
+## uWsgi
+
+Since we used the *--with-scriptdir=/var/www/htdocs/csvn* option on configuring stage,
+the **cSvn-ui** CGI script installed in the */var/www/htdocs/csvn/* directory. In this case,
+the */etc/uwsgi/csvn-ui.ini* file should look like this:
+
+**/etc/uwsgi/csvn-ui.ini:**
+
+```ini
+[uwsgi]
+master          = true
+plugins         = cgi
+socket          = /run/uwsgi/%n.sock
+uid             = nginx
+gid             = nginx
+procname-master = uwsgi csvn-ui
+processes       = 1
+threads         = 2
+cgi             = /var/www/htdocs/csvn/csvn-ui.cgi
+```
+
+Where */var/www/htdocs/csvn/csvn-ui.cgi* is the full name of installed **cSvn-ui** CGI script.
+
+To run the **uWSGI** daemon for **cSvn-ui** backend we can make use following start/stop script:
+
+**/ets/rc.d/rc.csvn-ui-uwsgi:**
+
+```Bash
+#!/bin/sh
+#
+# uWSGI daemon control script.
+#
+
+CONF=csvn-ui
+BIN=/usr/bin/uwsgi
+CONFDIR=/etc/uwsgi
+PID=/var/run/$CONF-uwsgi.pid
+
+uwsgi_start() {
+  # Sanity checks.
+  if [ ! -r $CONFDIR/csvn-ui.ini ]; then # no config files, exit:
+    echo "There are config files in $CONFDIR directory. Abort."
+    exit 1
+  fi
+
+  if [ -s $PID ]; then
+    echo "uWSGI for cSvn-ui appears to already be running?"
+    exit 1
+  fi
+
+  echo "Starting uWSGI for cSvn-ui server daemon..."
+  if [ -x $BIN ]; then
+    /bin/mkdir -p /run/uwsgi
+    /bin/chown nginx:nginx /run/uwsgi
+    /bin/chmod 0755 /run/uwsgi
+    $BIN --thunder-lock --pidfile $PID --daemonize /var/log/csvn-ui-uwsgi.log --ini $CONFDIR/$CONF.ini
+  fi
+}
+
+uwsgi_stop() {
+  echo "Shutdown uWSGI for cSvn-ui gracefully..."
+  /bin/kill -INT $(cat $PID)
+  /bin/rm -f $PID
+}
+
+uwsgi_reload() {
+  echo "Reloading uWSGI for cSvn-ui configuration..."
+  kill -HUP $(cat $PID)
+}
+
+uwsgi_restart() {
+  uwsgi_stop
+  sleep 3
+  uwsgi_start
+}
+
+case "$1" in
+  start)
+    uwsgi_start
+    ;;
+  stop)
+    uwsgi_stop
+    ;;
+  reload)
+    uwsgi_reload
+    ;;
+  restart)
+    uwsgi_restart
+    ;;
+  *)
+  echo "usage: `basename $0` {start|stop|reload|restart}"
+esac
+```
+
+To run this daemon on systems with BSD-like initialization such as **Slackware**
+we have to add following lines to the */etc/rc.d/rc.M* and */etc/rc.d/rc.6* scripts
+correspondingly.
+
+**/etc/rc.d/rc.M:**
+
+```Bash
+# Start uWSGI for cSvn-ui server:
+if [ -x /etc/rc.d/rc.csvn-ui-uwsgi ]; then
+  /etc/rc.d/rc.csvn-ui-uwsgi start
+fi
+```
+
+**/etc/rc.d/rc.6:**
+
+```Bash
+# Stop uWSGI for cSvn-ui server:
+if [ -x /etc/rc.d/rc.csvn-ui-uwsgi ]; then
+  /etc/rc.d/rc.csvn-ui-uwsgi stop
+fi
+```
+
+
+## Nginx
+
+First of all we have to add virtual server to the main **Nginx** config file:
+
+**/etc/nginx/nginx.conf:**
+
+```Nginx
+    include /etc/nginx/vhosts/csvn.example.org.conf;
+```
+
+The following configuration used **uWsgi** and will serve **cSvn-ui** on a subdomain
+like *csvn.example.org*:
+
+**/etc/nginx/vhosts/csvn.example.org.conf:**
+
+```Nginx
+#
+# cSvn server:
+#
+
+    server {
+        listen 80;
+        server_name csvn.example.org;
+        return 301 https://csvn.example.org$request_uri;
+    }
+
+    server {
+        listen 443 ssl;
+        server_name csvn.example.org;
+        root /var/www/htdocs/csvn;
+
+        charset UTF-8;
+
+        #
+        # see:
+        #   https://developer.mozilla.org/en-US/docs/Web/Security/HTTP_strict_transport_security ,
+        #   https://raymii.org/s/tutorials/HTTP_Strict_Transport_Security_for_Apache_NGINX_and_Lighttpd.html
+        #
+        # see also: http://classically.me/blogs/how-clear-hsts-settings-major-browsers
+        # and do not include includeSubdomains; parameter into line:
+        #
+        add_header Strict-Transport-Security "max-age=63072000; preload";
+
+        error_log /var/log/nginx/csvn.example.org-error.log;
+        access_log /var/log/nginx/csvn.example.org-access.log;
+
+        keepalive_timeout        60;
+        ssl_certificate          /etc/letsencrypt/live/csvn.example.org/fullchain.pem;
+        ssl_certificate_key      /etc/letsencrypt/live/csvn.example.org/privkey.pem;
+        ssl_trusted_certificate  /etc/letsencrypt/live/csvn.example.org/chain.pem;
+        ssl_protocols            SSLv3 TLSv1 TLSv1.1 TLSv1.2;
+        ssl_ciphers              "RC4:HIGH:!aNULL:!MD5:!kEDH";
+
+        gzip on;
+        gzip_disable "msie6";
+        gzip_comp_level 6;
+        gzip_min_length 1100;
+        gzip_buffers 16 8k;
+        gzip_proxied any;
+        gzip_types text/plain text/css text/js text/xml text/javascript
+                   image/svg+xml image/gif image/jpeg image/png
+                   application/json application/x-javascript application/xml application/xml+rss application/javascript
+                   font/truetype font/opentype application/font-woff application/font-woff2
+                   application/x-font-ttf application/x-font-opentype application/vnd.ms-fontobject application/font-sfnt;
+
+
+        location ~* ^.+(favicon.ico|robots.txt) {
+            root /var/www/htdocs/csvn;
+            expires 30d;
+        }
+
+        location = /robots.txt {
+            allow all;
+            log_not_found off;
+            access_log off;
+        }
+
+        location / {
+            try_files $uri @csvn-ui;
+        }
+
+        location @csvn-ui {
+            gzip off;
+            include uwsgi_params;
+            uwsgi_modifier1 9;
+            uwsgi_pass unix:/run/uwsgi/csvn-ui.sock;
+        }
+    }
+```
+
+
+## Configuring SVN Repositories
+
+A detailed description of the configuration file format can be found in the
+[**csvn-ui.rc(5)**](https://csvn.radix.pro/scm-tools/csvn-ui/trunk/doc/csvn-ui.rc.5.md) manual page:
+
+```Bash
+man 5 csvn-ui.rc
+```
+
+Here we will give an example of a description of the
+[Apache Subversion repository](https://svn.apache.org/viewvc/subversion/trunk/).
+Please note that the Apache server responds very slowly to HTTP requests.
+
+```dts
+/**************************
+  Apache's SVN repository:
+ */
+home-page = "https://svn.apache.org/";
+
+section "Subversion" {
+  repo 'subversion' {
+    owner = "Apache";
+    description = "Source repository of the Subversion.";
+    checkout-prefix-readonly = 'https://svn.apache.org/repos/asf';
+  }
+}
+```
+
+To access your own repositories, we recommend the **svn+ssh** protocol.
+
+
+## See Also
+
+> [**cscmd(8)**](https://csvn.radix.pro/scm-tools/cscm/trunk/doc/cscmd.8.md),&nbsp;
+> [**csvn-ui.rc(5)**](https://csvn.radix.pro/scm-tools/csvn-ui/trunk/doc/csvn-ui.rc.5.md)
+
+
+## Copyright and License
+
+&#169; Andrey V. Kosteltsev, 2019 &#8211; 2020.<br/>
+Code and documentation released under [the **Radix.pro** License](https://csvn.radix.pro/csvn-ui/trunk/LICENSE).
Index: csvn-ui-0.1.5/acsite.m4
===================================================================
--- csvn-ui-0.1.5/acsite.m4	(nonexistent)
+++ csvn-ui-0.1.5/acsite.m4	(revision 12)
@@ -0,0 +1,55 @@
+
+dnl ============================================================
+dnl Display Configuration Headers
+dnl 
+dnl    configure.in:
+dnl       AC_MSG_CFG_PART(<text>)
+dnl ============================================================
+
+define(AC_MSG_CFG_PART,[dnl
+  AC_MSG_RESULT()
+  AC_MSG_RESULT(${TB}$1:${TN})
+])dnl
+
+AC_DEFUN(AC_CSVN_HEADLINE,[dnl
+  # Use a `Quadrigaph'. @<:@ gives you [ and @:>@ gives you ] :
+  TB=`echo -n -e '\033@<:@1m'`
+  TN=`echo -n -e '\033@<:@0m'`
+  echo ""
+  echo "Configuring ${TB}$1${TN} ($2), Version ${TB}${PACKAGE_VERSION}${TN}"
+  echo "$3"
+])dnl
+
+
+dnl ============================================================
+dnl  Test for build_host `ln -s' .
+dnl  ============================
+dnl
+dnl Usage:
+dnl -----
+dnl    AC_PATH_PROG_LN_S
+dnl    AC_SUBST(LN)
+dnl    AC_SUBST(LN_S)
+dnl
+dnl ============================================================
+AC_DEFUN(AC_PATH_PROG_LN_S,
+[AC_PATH_PROG(LN, ln, no, /usr/local/bin:/usr/bin:/bin:$PATH)
+AC_MSG_CHECKING(whether ln -s works on build host)
+AC_CACHE_VAL(ac_cv_path_prog_LN_S,
+[rm -f conftestdata
+if $LN -s X conftestdata 2>/dev/null
+then
+  rm -f conftestdata
+  ac_cv_path_prog_LN_S="$LN -s"
+else
+  ac_cv_path_prog_LN_S="$LN"
+fi])dnl
+LN_S="$ac_cv_path_prog_LN_S"
+if test "$ac_cv_path_prog_LN_S" = "$LN -s"; then
+  AC_MSG_RESULT(yes)
+else
+  AC_MSG_RESULT(no)
+fi
+AC_SUBST(LN)dnl
+AC_SUBST(LN_S)dnl
+])
Index: csvn-ui-0.1.5/auto-clean
===================================================================
--- csvn-ui-0.1.5/auto-clean	(nonexistent)
+++ csvn-ui-0.1.5/auto-clean	(revision 12)
@@ -0,0 +1,40 @@
+#!/bin/bash
+
+CWD=`pwd`
+
+program=`basename $0`
+
+usage() {
+  cat << EOF
+
+Usage: $program [options]
+
+Options:
+  -h,--help                  Display this message.
+
+EOF
+}
+
+if [ -f "${CWD}/Makefile" ] ; then
+  make distclean
+fi
+
+svnignore='.svnignore'
+
+while read ln; do
+  line=`echo "${ln}" | sed 's,^[ \t],,' | sed 's,[ \t]$,,'`
+  if [ "x$line" != "x" -a "${line:0:1}" != "#" ] ; then
+    if `echo "${line}" | grep -q '\*~$'` ; then
+      find "`dirname "${line}"`" -type f -iname '*~' -print0 | while IFS= read -r -d '' file ; do
+        rm -f "$file"
+      done
+    elif `echo "${line}" | grep -q '\*'` ; then
+      find "`dirname "${line}"`" -type f -iname "`basename "${line}"`" -print0 | while IFS= read -r -d '' file ; do
+        rm -f "$file"
+      done
+    else
+      if [ -d "${line}" ] ; then rm -rf "${line}" ; fi
+      if [ -f "${line}" ] ; then rm  -f "${line}" ; fi
+    fi
+  fi
+done < ${CWD}/${svnignore}

Property changes on: csvn-ui-0.1.5/auto-clean
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/bootstrap
===================================================================
--- csvn-ui-0.1.5/bootstrap	(nonexistent)
+++ csvn-ui-0.1.5/bootstrap	(revision 12)
@@ -0,0 +1,99 @@
+#!/bin/sh
+
+CWD=`pwd`
+
+program=`basename $0`
+
+usage() {
+  cat << EOF
+
+Usage: $program [options]
+
+Options:
+  -h,--help                  Display this message.
+  -d,--target-dest-dir=DIR   The target ROOTFS directory
+                             [default: DIR=/].
+
+EOF
+}
+
+TARGET_DEST_DIR=/
+ACDIR=usr/share/aclocal
+INCDIR=usr/include
+SYSTEM_ACDIR=
+SYSTEM_INCDIR=
+
+while [ 0 ] ; do
+  if [ "$1" = "-h" -o "$1" = "--help" ] ; then
+    usage
+    exit 0
+  elif [ "$1" = "-d" -o "$1" = "--target-dest-dir" ] ; then
+    if [ "$2" = "" ] ; then
+      echo -e "\n${program}: ERROR: --target-dest-dir is not specified.\n"
+      usage
+      exit 1
+    fi
+    TARGET_DEST_DIR="$2"
+    shift 2
+  elif [[ $1 == --target-dest-dir=* ]] ; then
+    TARGET_DEST_DIR="`echo $1 | cut -f2 -d'='`"
+    shift 1
+  else
+    if [ "$1" != "" ] ; then
+      echo -e "\n${program}: ERROR: Unknown argument: $1.\n"
+      usage
+      exit 1
+    fi
+    break
+  fi
+done
+
+if [ ! -d "${TARGET_DEST_DIR}" ] ; then
+  echo -e "\n${program}: ERROR: --target-dest-dir is not a directory.\n"
+  usage
+  exit 1
+fi
+
+#
+# Absolute path:
+#
+if [ "${TARGET_DEST_DIR:0:1}" != "/" ] ; then
+  TARGET_DEST_DIR=${CWD}/${TARGET_DEST_DIR}
+fi
+
+#
+# Remove last '/' char:
+#
+if [ "${TARGET_DEST_DIR: -1}" = "/" ] ; then
+  len=${#TARGET_DEST_DIR}
+  let "len = len - 1"
+  tmp="${TARGET_DEST_DIR:0:$len}"
+  TARGET_DEST_DIR=${tmp}
+fi
+
+SYSTEM_ACDIR="${TARGET_DEST_DIR}/${ACDIR}"
+SYSTEM_INCDIR="${TARGET_DEST_DIR}/${INCDIR}"
+
+
+aclocal --install -I m4 --force --system-acdir=${SYSTEM_ACDIR}
+autoheader --include=${SYSTEM_INCDIR}
+automake --foreign --add-missing --copy --force-missing
+autoconf --force
+
+#
+# Add 'cSvn Features' header to split help output:
+#
+cat >csvn-features <<_CSVN
+_ACEOF
+
+  cat <<\\_ACEOF
+
+cSvn-ui Features:
+_CSVN
+
+sed -i '/^[ ]*\-\-with\-scriptdir=DIR/ {
+r csvn-features
+N
+}' configure
+
+rm -f csvn-features

Property changes on: csvn-ui-0.1.5/bootstrap
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/config.rpath
===================================================================
--- csvn-ui-0.1.5/config.rpath	(nonexistent)
+++ csvn-ui-0.1.5/config.rpath	(revision 12)
@@ -0,0 +1,684 @@
+#! /bin/sh
+# Output a system dependent set of variables, describing how to set the
+# run time search path of shared libraries in an executable.
+#
+#   Copyright 1996-2016 Free Software Foundation, Inc.
+#   Taken from GNU libtool, 2001
+#   Originally by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
+#
+#   This file is free software; the Free Software Foundation gives
+#   unlimited permission to copy and/or distribute it, with or without
+#   modifications, as long as this notice is preserved.
+#
+# The first argument passed to this file is the canonical host specification,
+#    CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
+# or
+#    CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
+# The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld
+# should be set by the caller.
+#
+# The set of defined variables is at the end of this script.
+
+# Known limitations:
+# - On IRIX 6.5 with CC="cc", the run time search patch must not be longer
+#   than 256 bytes, otherwise the compiler driver will dump core. The only
+#   known workaround is to choose shorter directory names for the build
+#   directory and/or the installation directory.
+
+# All known linkers require a '.a' archive for static linking (except MSVC,
+# which needs '.lib').
+libext=a
+shrext=.so
+
+host="$1"
+host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'`
+host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'`
+host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'`
+
+# Code taken from libtool.m4's _LT_CC_BASENAME.
+
+for cc_temp in $CC""; do
+  case $cc_temp in
+    compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+    distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+    \-*) ;;
+    *) break;;
+  esac
+done
+cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'`
+
+# Code taken from libtool.m4's _LT_COMPILER_PIC.
+
+wl=
+if test "$GCC" = yes; then
+  wl='-Wl,'
+else
+  case "$host_os" in
+    aix*)
+      wl='-Wl,'
+      ;;
+    mingw* | cygwin* | pw32* | os2* | cegcc*)
+      ;;
+    hpux9* | hpux10* | hpux11*)
+      wl='-Wl,'
+      ;;
+    irix5* | irix6* | nonstopux*)
+      wl='-Wl,'
+      ;;
+    linux* | k*bsd*-gnu | kopensolaris*-gnu)
+      case $cc_basename in
+        ecc*)
+          wl='-Wl,'
+          ;;
+        icc* | ifort*)
+          wl='-Wl,'
+          ;;
+        lf95*)
+          wl='-Wl,'
+          ;;
+        nagfor*)
+          wl='-Wl,-Wl,,'
+          ;;
+        pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*)
+          wl='-Wl,'
+          ;;
+        ccc*)
+          wl='-Wl,'
+          ;;
+        xl* | bgxl* | bgf* | mpixl*)
+          wl='-Wl,'
+          ;;
+        como)
+          wl='-lopt='
+          ;;
+        *)
+          case `$CC -V 2>&1 | sed 5q` in
+            *Sun\ F* | *Sun*Fortran*)
+              wl=
+              ;;
+            *Sun\ C*)
+              wl='-Wl,'
+              ;;
+          esac
+          ;;
+      esac
+      ;;
+    newsos6)
+      ;;
+    *nto* | *qnx*)
+      ;;
+    osf3* | osf4* | osf5*)
+      wl='-Wl,'
+      ;;
+    rdos*)
+      ;;
+    solaris*)
+      case $cc_basename in
+        f77* | f90* | f95* | sunf77* | sunf90* | sunf95*)
+          wl='-Qoption ld '
+          ;;
+        *)
+          wl='-Wl,'
+          ;;
+      esac
+      ;;
+    sunos4*)
+      wl='-Qoption ld '
+      ;;
+    sysv4 | sysv4.2uw2* | sysv4.3*)
+      wl='-Wl,'
+      ;;
+    sysv4*MP*)
+      ;;
+    sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*)
+      wl='-Wl,'
+      ;;
+    unicos*)
+      wl='-Wl,'
+      ;;
+    uts4*)
+      ;;
+  esac
+fi
+
+# Code taken from libtool.m4's _LT_LINKER_SHLIBS.
+
+hardcode_libdir_flag_spec=
+hardcode_libdir_separator=
+hardcode_direct=no
+hardcode_minus_L=no
+
+case "$host_os" in
+  cygwin* | mingw* | pw32* | cegcc*)
+    # FIXME: the MSVC++ port hasn't been tested in a loooong time
+    # When not using gcc, we currently assume that we are using
+    # Microsoft Visual C++.
+    if test "$GCC" != yes; then
+      with_gnu_ld=no
+    fi
+    ;;
+  interix*)
+    # we just hope/assume this is gcc and not c89 (= MSVC++)
+    with_gnu_ld=yes
+    ;;
+  openbsd*)
+    with_gnu_ld=no
+    ;;
+esac
+
+ld_shlibs=yes
+if test "$with_gnu_ld" = yes; then
+  # Set some defaults for GNU ld with shared library support. These
+  # are reset later if shared libraries are not supported. Putting them
+  # here allows them to be overridden if necessary.
+  # Unlike libtool, we use -rpath here, not --rpath, since the documented
+  # option of GNU ld is called -rpath, not --rpath.
+  hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+  case "$host_os" in
+    aix[3-9]*)
+      # On AIX/PPC, the GNU linker is very broken
+      if test "$host_cpu" != ia64; then
+        ld_shlibs=no
+      fi
+      ;;
+    amigaos*)
+      case "$host_cpu" in
+        powerpc)
+          ;;
+        m68k)
+          hardcode_libdir_flag_spec='-L$libdir'
+          hardcode_minus_L=yes
+          ;;
+      esac
+      ;;
+    beos*)
+      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    cygwin* | mingw* | pw32* | cegcc*)
+      # hardcode_libdir_flag_spec is actually meaningless, as there is
+      # no search path for DLLs.
+      hardcode_libdir_flag_spec='-L$libdir'
+      if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    haiku*)
+      ;;
+    interix[3-9]*)
+      hardcode_direct=no
+      hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+      ;;
+    gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu)
+      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    netbsd*)
+      ;;
+    solaris*)
+      if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then
+        ld_shlibs=no
+      elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*)
+      case `$LD -v 2>&1` in
+        *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*)
+          ld_shlibs=no
+          ;;
+        *)
+          if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
+            hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`'
+          else
+            ld_shlibs=no
+          fi
+          ;;
+      esac
+      ;;
+    sunos4*)
+      hardcode_direct=yes
+      ;;
+    *)
+      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+  esac
+  if test "$ld_shlibs" = no; then
+    hardcode_libdir_flag_spec=
+  fi
+else
+  case "$host_os" in
+    aix3*)
+      # Note: this linker hardcodes the directories in LIBPATH if there
+      # are no directories specified by -L.
+      hardcode_minus_L=yes
+      if test "$GCC" = yes; then
+        # Neither direct hardcoding nor static linking is supported with a
+        # broken collect2.
+        hardcode_direct=unsupported
+      fi
+      ;;
+    aix[4-9]*)
+      if test "$host_cpu" = ia64; then
+        # On IA64, the linker does run time linking by default, so we don't
+        # have to do anything special.
+        aix_use_runtimelinking=no
+      else
+        aix_use_runtimelinking=no
+        # Test if we are trying to use run time linking or normal
+        # AIX style linking. If -brtl is somewhere in LDFLAGS, we
+        # need to do runtime linking.
+        case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*)
+          for ld_flag in $LDFLAGS; do
+            if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+              aix_use_runtimelinking=yes
+              break
+            fi
+          done
+          ;;
+        esac
+      fi
+      hardcode_direct=yes
+      hardcode_libdir_separator=':'
+      if test "$GCC" = yes; then
+        case $host_os in aix4.[012]|aix4.[012].*)
+          collect2name=`${CC} -print-prog-name=collect2`
+          if test -f "$collect2name" && \
+            strings "$collect2name" | grep resolve_lib_name >/dev/null
+          then
+            # We have reworked collect2
+            :
+          else
+            # We have old collect2
+            hardcode_direct=unsupported
+            hardcode_minus_L=yes
+            hardcode_libdir_flag_spec='-L$libdir'
+            hardcode_libdir_separator=
+          fi
+          ;;
+        esac
+      fi
+      # Begin _LT_AC_SYS_LIBPATH_AIX.
+      echo 'int main () { return 0; }' > conftest.c
+      ${CC} ${LDFLAGS} conftest.c -o conftest
+      aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; }
+}'`
+      if test -z "$aix_libpath"; then
+        aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; }
+}'`
+      fi
+      if test -z "$aix_libpath"; then
+        aix_libpath="/usr/lib:/lib"
+      fi
+      rm -f conftest.c conftest
+      # End _LT_AC_SYS_LIBPATH_AIX.
+      if test "$aix_use_runtimelinking" = yes; then
+        hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+      else
+        if test "$host_cpu" = ia64; then
+          hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib'
+        else
+          hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+        fi
+      fi
+      ;;
+    amigaos*)
+      case "$host_cpu" in
+        powerpc)
+          ;;
+        m68k)
+          hardcode_libdir_flag_spec='-L$libdir'
+          hardcode_minus_L=yes
+          ;;
+      esac
+      ;;
+    bsdi[45]*)
+      ;;
+    cygwin* | mingw* | pw32* | cegcc*)
+      # When not using gcc, we currently assume that we are using
+      # Microsoft Visual C++.
+      # hardcode_libdir_flag_spec is actually meaningless, as there is
+      # no search path for DLLs.
+      hardcode_libdir_flag_spec=' '
+      libext=lib
+      ;;
+    darwin* | rhapsody*)
+      hardcode_direct=no
+      if { case $cc_basename in ifort*) true;; *) test "$GCC" = yes;; esac; }; then
+        :
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    dgux*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      ;;
+    freebsd2.[01]*)
+      hardcode_direct=yes
+      hardcode_minus_L=yes
+      ;;
+    freebsd* | dragonfly*)
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_direct=yes
+      ;;
+    hpux9*)
+      hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+      hardcode_libdir_separator=:
+      hardcode_direct=yes
+      # hardcode_minus_L: Not really in the search PATH,
+      # but as the default location of the library.
+      hardcode_minus_L=yes
+      ;;
+    hpux10*)
+      if test "$with_gnu_ld" = no; then
+        hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+        hardcode_libdir_separator=:
+        hardcode_direct=yes
+        # hardcode_minus_L: Not really in the search PATH,
+        # but as the default location of the library.
+        hardcode_minus_L=yes
+      fi
+      ;;
+    hpux11*)
+      if test "$with_gnu_ld" = no; then
+        hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+        hardcode_libdir_separator=:
+        case $host_cpu in
+          hppa*64*|ia64*)
+            hardcode_direct=no
+            ;;
+          *)
+            hardcode_direct=yes
+            # hardcode_minus_L: Not really in the search PATH,
+            # but as the default location of the library.
+            hardcode_minus_L=yes
+            ;;
+        esac
+      fi
+      ;;
+    irix5* | irix6* | nonstopux*)
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      ;;
+    netbsd*)
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_direct=yes
+      ;;
+    newsos6)
+      hardcode_direct=yes
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      ;;
+    *nto* | *qnx*)
+      ;;
+    openbsd*)
+      if test -f /usr/libexec/ld.so; then
+        hardcode_direct=yes
+        if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+          hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+        else
+          case "$host_os" in
+            openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
+              hardcode_libdir_flag_spec='-R$libdir'
+              ;;
+            *)
+              hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+              ;;
+          esac
+        fi
+      else
+        ld_shlibs=no
+      fi
+      ;;
+    os2*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_minus_L=yes
+      ;;
+    osf3*)
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      ;;
+    osf4* | osf5*)
+      if test "$GCC" = yes; then
+        hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      else
+        # Both cc and cxx compiler support -rpath directly
+        hardcode_libdir_flag_spec='-rpath $libdir'
+      fi
+      hardcode_libdir_separator=:
+      ;;
+    solaris*)
+      hardcode_libdir_flag_spec='-R$libdir'
+      ;;
+    sunos4*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_direct=yes
+      hardcode_minus_L=yes
+      ;;
+    sysv4)
+      case $host_vendor in
+        sni)
+          hardcode_direct=yes # is this really true???
+          ;;
+        siemens)
+          hardcode_direct=no
+          ;;
+        motorola)
+          hardcode_direct=no #Motorola manual says yes, but my tests say they lie
+          ;;
+      esac
+      ;;
+    sysv4.3*)
+      ;;
+    sysv4*MP*)
+      if test -d /usr/nec; then
+        ld_shlibs=yes
+      fi
+      ;;
+    sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
+      ;;
+    sysv5* | sco3.2v5* | sco5v6*)
+      hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`'
+      hardcode_libdir_separator=':'
+      ;;
+    uts4*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      ;;
+    *)
+      ld_shlibs=no
+      ;;
+  esac
+fi
+
+# Check dynamic linker characteristics
+# Code taken from libtool.m4's _LT_SYS_DYNAMIC_LINKER.
+# Unlike libtool.m4, here we don't care about _all_ names of the library, but
+# only about the one the linker finds when passed -lNAME. This is the last
+# element of library_names_spec in libtool.m4, or possibly two of them if the
+# linker has special search rules.
+library_names_spec=      # the last element of library_names_spec in libtool.m4
+libname_spec='lib$name'
+case "$host_os" in
+  aix3*)
+    library_names_spec='$libname.a'
+    ;;
+  aix[4-9]*)
+    library_names_spec='$libname$shrext'
+    ;;
+  amigaos*)
+    case "$host_cpu" in
+      powerpc*)
+        library_names_spec='$libname$shrext' ;;
+      m68k)
+        library_names_spec='$libname.a' ;;
+    esac
+    ;;
+  beos*)
+    library_names_spec='$libname$shrext'
+    ;;
+  bsdi[45]*)
+    library_names_spec='$libname$shrext'
+    ;;
+  cygwin* | mingw* | pw32* | cegcc*)
+    shrext=.dll
+    library_names_spec='$libname.dll.a $libname.lib'
+    ;;
+  darwin* | rhapsody*)
+    shrext=.dylib
+    library_names_spec='$libname$shrext'
+    ;;
+  dgux*)
+    library_names_spec='$libname$shrext'
+    ;;
+  freebsd[23].*)
+    library_names_spec='$libname$shrext$versuffix'
+    ;;
+  freebsd* | dragonfly*)
+    library_names_spec='$libname$shrext'
+    ;;
+  gnu*)
+    library_names_spec='$libname$shrext'
+    ;;
+  haiku*)
+    library_names_spec='$libname$shrext'
+    ;;
+  hpux9* | hpux10* | hpux11*)
+    case $host_cpu in
+      ia64*)
+        shrext=.so
+        ;;
+      hppa*64*)
+        shrext=.sl
+        ;;
+      *)
+        shrext=.sl
+        ;;
+    esac
+    library_names_spec='$libname$shrext'
+    ;;
+  interix[3-9]*)
+    library_names_spec='$libname$shrext'
+    ;;
+  irix5* | irix6* | nonstopux*)
+    library_names_spec='$libname$shrext'
+    case "$host_os" in
+      irix5* | nonstopux*)
+        libsuff= shlibsuff=
+        ;;
+      *)
+        case $LD in
+          *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;;
+          *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;;
+          *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;;
+          *) libsuff= shlibsuff= ;;
+        esac
+        ;;
+    esac
+    ;;
+  linux*oldld* | linux*aout* | linux*coff*)
+    ;;
+  linux* | k*bsd*-gnu | kopensolaris*-gnu)
+    library_names_spec='$libname$shrext'
+    ;;
+  knetbsd*-gnu)
+    library_names_spec='$libname$shrext'
+    ;;
+  netbsd*)
+    library_names_spec='$libname$shrext'
+    ;;
+  newsos6)
+    library_names_spec='$libname$shrext'
+    ;;
+  *nto* | *qnx*)
+    library_names_spec='$libname$shrext'
+    ;;
+  openbsd*)
+    library_names_spec='$libname$shrext$versuffix'
+    ;;
+  os2*)
+    libname_spec='$name'
+    shrext=.dll
+    library_names_spec='$libname.a'
+    ;;
+  osf3* | osf4* | osf5*)
+    library_names_spec='$libname$shrext'
+    ;;
+  rdos*)
+    ;;
+  solaris*)
+    library_names_spec='$libname$shrext'
+    ;;
+  sunos4*)
+    library_names_spec='$libname$shrext$versuffix'
+    ;;
+  sysv4 | sysv4.3*)
+    library_names_spec='$libname$shrext'
+    ;;
+  sysv4*MP*)
+    library_names_spec='$libname$shrext'
+    ;;
+  sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+    library_names_spec='$libname$shrext'
+    ;;
+  tpf*)
+    library_names_spec='$libname$shrext'
+    ;;
+  uts4*)
+    library_names_spec='$libname$shrext'
+    ;;
+esac
+
+sed_quote_subst='s/\(["`$\\]\)/\\\1/g'
+escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"`
+shlibext=`echo "$shrext" | sed -e 's,^\.,,'`
+escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
+escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
+escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
+
+LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <<EOF
+
+# How to pass a linker flag through the compiler.
+wl="$escaped_wl"
+
+# Static library suffix (normally "a").
+libext="$libext"
+
+# Shared library suffix (normally "so").
+shlibext="$shlibext"
+
+# Format of library name prefix.
+libname_spec="$escaped_libname_spec"
+
+# Library names that the linker finds when passed -lNAME.
+library_names_spec="$escaped_library_names_spec"
+
+# Flag to hardcode \$libdir into a binary during linking.
+# This must work even if \$libdir does not exist.
+hardcode_libdir_flag_spec="$escaped_hardcode_libdir_flag_spec"
+
+# Whether we need a single -rpath flag with a separated argument.
+hardcode_libdir_separator="$hardcode_libdir_separator"
+
+# Set to yes if using DIR/libNAME.so during linking hardcodes DIR into the
+# resulting binary.
+hardcode_direct="$hardcode_direct"
+
+# Set to yes if using the -LDIR flag during linking hardcodes DIR into the
+# resulting binary.
+hardcode_minus_L="$hardcode_minus_L"
+
+EOF

Property changes on: csvn-ui-0.1.5/config.rpath
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/configure.ac
===================================================================
--- csvn-ui-0.1.5/configure.ac	(nonexistent)
+++ csvn-ui-0.1.5/configure.ac	(revision 12)
@@ -0,0 +1,232 @@
+
+dnl ============================================================
+dnl  Process this file with autoconf to produce
+dnl  a configure script.
+dnl ============================================================
+
+AC_PREREQ(2.71)dnl        dnl Minimum Autoconf version required.
+
+
+AC_INIT([csvn-ui], [0.1.5],
+  [support@radix.pro], [csvn-ui], [https://radix.pro])
+
+dnl ============================================================
+dnl m4's diversions:
+dnl ---------------
+dnl
+dnl see: /use/share/autoconf/autoconf/general.m4
+dnl ============================================================
+m4_divert_push([M4SH-INIT])
+PACKAGE_CGI=csvn-ui.cgi
+PACKAGE_LICENSE=Radix-1.0
+CSVN_SCRIPT_DIR=/var/www/htdocs/csvn
+m4_divert_pop([M4SH-INIT])
+
+AC_CSVN_HEADLINE([csvn-ui], [cSvn-ui], [Copyright (c) 2019-2020 Andrey V.Kosteltsev])
+
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: Init Automake environment                        $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(Init Automake environment)
+
+AC_CANONICAL_TARGET
+
+AM_INIT_AUTOMAKE([subdir-objects foreign no-dist-gzip dist-xz tar-pax])
+
+AC_CONFIG_HEADERS([config.h])
+
+AC_PREFIX_DEFAULT(/usr/local)
+
+AC_MSG_CFG_PART(Test for GNU Gettext)
+AM_GNU_GETTEXT([external])
+AM_GNU_GETTEXT_VERSION
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: Test for Build Tools                             $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(Test for build tools)
+AC_CHECK_TOOL([GCC], [gcc], [:])
+AC_PATH_PROG([BISON], [bison], [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+test "$BISON" = "no" && AC_MSG_ERROR([Unable to find required program 'bison'])
+
+
+AC_MSG_CFG_PART(Test for Header files)
+dnl
+dnl  Check for system header files.
+dnl  =============================
+dnl  /* GetText частично проверил. Но мы делаем для себя. */
+AC_CHECK_HEADERS( locale.h )
+AC_CHECK_HEADERS( sys/types.h sys/stat.h stdlib.h stddef.h )
+AC_CHECK_HEADERS( memory.h string.h strings.h )
+AC_CHECK_HEADERS( inntypes.h stdint.h unistd.h )
+AC_CHECK_HEADERS( fcntl.h errno.h )
+AC_CHECK_HEADERS( sys/file.h )
+AC_CHECK_HEADERS( sys/uio.h )
+AC_CHECK_HEADERS( stdarg.h )
+AC_CHECK_HEADERS( sys/time.h )
+AC_CHECK_HEADERS( limits.h )
+AC_CHECK_HEADERS( endian.h )
+AC_CHECK_HEADERS( pcre2.h )
+AC_CHECK_HEADERS( wchar.h )
+AC_CHECK_HEADERS( wctype.h )
+AC_CHECK_HEADERS( math.h )
+AC_CHECK_HEADERS( md4c.h md4c-html.h )
+AC_CHECK_HEADERS( magic.h )
+
+AC_MSG_CFG_PART(Test for cScm Configuration Daemon)
+dnl  Check for system header file <cscm/bcf.h> provided by cScm package:
+dnl  ==================================================================
+AC_CHECK_HEADER([cscm/bcf.h],[AC_DEFINE(HAVE_CSCM_BCF_H, 1, [Define to 1 if you have the <cscm/bcf.h> header file.])],
+                             [AC_MSG_ERROR([cscm/bcf.h not found. Please install cScm package.])])
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: Test for Libraries                               $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(Test for libraries)
+AC_CHECK_LIB([pcre2-8],[pcre2_compile_8],[],[AC_MSG_ERROR([Unable to find required libpcre2-8])])
+AC_CHECK_LIB([rt],[aio_suspend],[],[AC_MSG_ERROR([Unable to find required librt])])
+AC_CHECK_LIB([m],[round],[],[AC_MSG_ERROR([Unable to find required libm])])
+AC_CHECK_LIB([md4c],[md_parse],[],[AC_MSG_ERROR([Unable to find required libmd4c])])
+AC_CHECK_LIB([md4c-html],[md_html],[],[AC_MSG_ERROR([Unable to find required libmd4c-html])])
+AC_CHECK_LIB([magic],[magic_version],[],[AC_MSG_ERROR([Unable to find required libmagic])])
+
+PKG_CHECK_MODULES([XML], [libxml-2.0 >= 2.9.7],
+                  [AC_DEFINE([HAVE_LIBXML2],[1],[Define to 1 if you have the `xml2' library (-lxml2).])],
+                  [AC_MSG_ERROR([Unable to find required libxml2])])
+
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: Test for Runtime Tools                           $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(Test for runtime tools)
+AC_PATH_PROG([SVN], [svn], [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+test "$SVN" = "no" && AC_MSG_ERROR([Unable to find required program 'svn'])
+
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: cSvn Features                                    $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_ARG_WITH([scriptdir],
+  [AS_HELP_STRING([--with-scriptdir=DIR], [cSvn-ui CGI script directory @<:@default=/var/www/htdocs/csvn@:>@],[26],[84])],
+  [scriptdir=$withval],
+  [scriptdir="/var/www/htdocs/csvn"])
+AC_SUBST([scriptdir], [$scriptdir])
+AC_SUBST([CSVN_SCRIPT_DIR], [$scriptdir])
+AC_DEFINE_UNQUOTED([CSVN_SCRIPT_DIR], ["$CSVN_SCRIPT_DIR"], [Define the CGI script directory])
+
+AC_SUBST(PROGRAM_CGI,[${PACKAGE_CGI}])
+AC_SUBST(PROGRAM_VERSION,[${PACKAGE_VERSION}])
+AC_SUBST(PROGRAM_LICENSE,[${PACKAGE_LICENSE}])
+
+AC_DEFINE_UNQUOTED([PROGRAM_CGI], ["$PROGRAM_CGI"], [Define the CGI script name])
+AC_DEFINE_UNQUOTED([PROGRAM_VERSION], ["$PROGRAM_VERSION"], [Define the version of all programs in this package])
+AC_DEFINE_UNQUOTED([PROGRAM_LICENSE], ["$PROGRAM_LICENSE"], [Define the License of all programs in this package])
+
+
+dnl ============================================================
+dnl Environment Variables:
+dnl ---------------------
+dnl  For 'Some influential environment variables:' help section
+dnl ============================================================
+AC_ARG_VAR([STRIP], [strip command])
+
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: Test for Auxiliary (my be version sensitive)     $$
+dnl $$       programs                                         $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(Test for aux programs)
+AC_PATH_PROG_LN_S
+AC_PATH_PROG([CAT],       [cat],       [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([CHMOD],     [chmod],     [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([CP],        [cp],        [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([FIND],      [find],      [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([GZIP],      [gzip],      [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([MV],        [mv],        [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([RM],        [rm],        [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([SED],       [sed],       [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([TAR],       [tar],       [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+AC_PATH_PROG([XZ],        [xz],        [no], [/usr/local/bin:/usr/bin:/bin:$PATH])
+
+
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl $$                                                        $$
+dnl $$ PART: OUTPUT Substitution                              $$
+dnl $$                                                        $$
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+dnl ============================================================
+AC_MSG_CFG_PART(OUTPUT)
+
+AC_CONFIG_FILES([ po/Makefile.in
+csvncgi/Makefile
+Makefile
+])
+AC_OUTPUT
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/_csvn.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/_csvn.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/_csvn.css	(revision 12)
@@ -0,0 +1,175 @@
+
+/***************************************************
+  cSvn style (c) Andrey V.Kosteltsev <kx@radix.pro>
+ */
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em 0.5em 0.5em 1.5em;
+  color: #424242;
+  background: #fcfcfc;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+}
+
+/******************
+  General-purpose:
+ */
+.hljs-subst {
+  color: #545454;
+}
+.hljs-keyword {
+  color: #005faf !important; /* color 25 */
+}
+.hljs-built_in {
+  color: #005f87 !important; /* color 24 */
+}
+.hljs-type {
+  color: #008787 !important; /* color 30 */
+}
+.hljs-literal {
+  color: #8700af !important; /* color 91 */
+}
+.hljs-number {
+  color: #870000 !important; /* color 88 */
+}
+.hljs-regexp {
+  color: #af0000 !important; /* color 97 */
+}
+.hljs-string {
+  color: #005f00; /* color 22 */
+}
+.hljs-symbol {
+  color: #000087 !important; /* color 18 */
+}
+/* .hljs-class {} is a parent of 'keyword > title' */
+/* .hljs-function {} is a parent of keyword > title > params' */
+.hljs-title {
+  color: #00005f !important; /* color 17 */
+}
+
+/*******
+  Meta:
+ */
+.hljs-comment {
+  color: #8a8a8a !important; /* color 245 */
+}
+.hljs-doctag {
+  color: #444444 !important; /* color 238 */
+}
+/* Meta color: #include <stdlib.h> */
+.hljs-meta {
+  color: #5f0000; /* color 52 */
+}
+.hljs-meta-keyword {
+  color: #5f0000; /* color 52 */
+}
+.hljs-meta-string {
+  color: #005f5f; /* color 23 */
+}
+
+/****************************
+  Tags, attributes, configs:
+ */
+.hljs-section {
+  color: #870000 !important; /* color 88 */
+}
+.hljs-tag {
+  color: #005f87 !important; /* color 24 */
+}
+.hljs-name,
+.hljs-builtin-name {
+  color: #0087af !important; /* color 31 */
+}
+.hljs-attr {
+  color: #8700af !important; /* color 91 as literal */
+}
+.hljs-attribute {
+  color: #875f00 !important; /* color 94 */
+}
+.hljs-variable {
+  color: #008700 !important; /* color 28 as quote */
+}
+
+/*********
+  Markup:
+ */
+.hljs-bullet {
+  color: #0000d7 !important; /* color 20 */
+}
+.hljs-code {
+  color: #000080 !important; /* color 4 */
+}
+.hljs-emphasis {
+  color: #080808 !important; /* color 232 */
+}
+.hljs-strong {
+  color: #080808 !important; /* color 232 */
+  font-weight: bold;
+}
+.hljs-formula {
+  color: #080808 !important; /* color 232 */
+  font-style: italic;
+}
+.hljs-link {
+  color: #00afd7 !important; /* color 38 */
+}
+.hljs-quote {
+  color: #008700; /* color 28 */
+}
+
+/******
+  CSS:
+ */
+.hljs-selector-tag {
+  color: #00005f !important; /* color 17 */
+}
+.hljs-selector-id {
+  color: #005fff !important; /* color 27 */
+}
+.hljs-selector-class {
+  color: #005faf !important; /* color 25 */
+}
+.hljs-selector-attr {
+  color: #875fff !important; /* color 99 */
+}
+.hljs-selector-pseudo {
+  color: #8700d7 !important; /* color 92 */
+}
+
+/************
+  Templates:
+ */
+.hljs-template-tag {
+  color: #800000 !important; /* color 1 */
+}
+.hljs-template-variable {
+  color: #870087 !important; /* color 90 */
+}
+
+/*******
+  Diff:
+ */
+.hljs-deletion {
+  color: #d70000 !important; /* color 160 */
+}
+.hljs-addition {
+  color: #008700 !important; /* color 28 */
+}
+
+/***********
+  ReasonML:
+ */
+.hljs-operator {
+  color: #af0000 !important; /* color 124 */
+}
+.hljs-pattern-match {
+  color: #00af00 !important; /* color 34 */
+}
+.hljs-constructor {
+  color: #878700 !important; /* color 100 */
+}
+/* .hljs-module-access {} is a parent of module */
+.hljs-module {
+  color: #5f5f00 !important; /* color 58 */
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-dark.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-dark.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-dark.css	(revision 12)
@@ -0,0 +1,96 @@
+/*
+
+Atom One Dark by Daniel Gamage
+Original One Dark Syntax theme from https://github.com/atom/one-dark-syntax
+
+base:    #282c34
+mono-1:  #abb2bf
+mono-2:  #818896
+mono-3:  #5c6370
+hue-1:   #56b6c2
+hue-2:   #61aeee
+hue-3:   #c678dd
+hue-4:   #98c379
+hue-5:   #e06c75
+hue-5-2: #be5046
+hue-6:   #d19a66
+hue-6-2: #e6c07b
+
+*/
+
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em;
+  color: #abb2bf;
+  background: #282c34;
+}
+
+.hljs-comment,
+.hljs-quote {
+  color: #5c6370;
+  font-style: italic;
+}
+
+.hljs-doctag,
+.hljs-keyword,
+.hljs-formula {
+  color: #c678dd;
+}
+
+.hljs-section,
+.hljs-name,
+.hljs-selector-tag,
+.hljs-deletion,
+.hljs-subst {
+  color: #e06c75;
+}
+
+.hljs-literal {
+  color: #56b6c2;
+}
+
+.hljs-string,
+.hljs-regexp,
+.hljs-addition,
+.hljs-attribute,
+.hljs-meta-string {
+  color: #98c379;
+}
+
+.hljs-built_in,
+.hljs-class .hljs-title {
+  color: #e6c07b;
+}
+
+.hljs-attr,
+.hljs-variable,
+.hljs-template-variable,
+.hljs-type,
+.hljs-selector-class,
+.hljs-selector-attr,
+.hljs-selector-pseudo,
+.hljs-number {
+  color: #d19a66;
+}
+
+.hljs-symbol,
+.hljs-bullet,
+.hljs-link,
+.hljs-meta,
+.hljs-selector-id,
+.hljs-title {
+  color: #61aeee;
+}
+
+.hljs-emphasis {
+  font-style: italic;
+}
+
+.hljs-strong {
+  font-weight: bold;
+}
+
+.hljs-link {
+  text-decoration: underline;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-light.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-light.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/atom-one-light.css	(revision 12)
@@ -0,0 +1,96 @@
+/*
+
+Atom One Light by Daniel Gamage
+Original One Light Syntax theme from https://github.com/atom/one-light-syntax
+
+base:    #fafafa
+mono-1:  #383a42
+mono-2:  #686b77
+mono-3:  #a0a1a7
+hue-1:   #0184bb
+hue-2:   #4078f2
+hue-3:   #a626a4
+hue-4:   #50a14f
+hue-5:   #e45649
+hue-5-2: #c91243
+hue-6:   #986801
+hue-6-2: #c18401
+
+*/
+
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em;
+  color: #383a42;
+  background: #fafafa;
+}
+
+.hljs-comment,
+.hljs-quote {
+  color: #a0a1a7;
+  font-style: italic;
+}
+
+.hljs-doctag,
+.hljs-keyword,
+.hljs-formula {
+  color: #a626a4;
+}
+
+.hljs-section,
+.hljs-name,
+.hljs-selector-tag,
+.hljs-deletion,
+.hljs-subst {
+  color: #e45649;
+}
+
+.hljs-literal {
+  color: #0184bb;
+}
+
+.hljs-string,
+.hljs-regexp,
+.hljs-addition,
+.hljs-attribute,
+.hljs-meta-string {
+  color: #50a14f;
+}
+
+.hljs-built_in,
+.hljs-class .hljs-title {
+  color: #c18401;
+}
+
+.hljs-attr,
+.hljs-variable,
+.hljs-template-variable,
+.hljs-type,
+.hljs-selector-class,
+.hljs-selector-attr,
+.hljs-selector-pseudo,
+.hljs-number {
+  color: #986801;
+}
+
+.hljs-symbol,
+.hljs-bullet,
+.hljs-link,
+.hljs-meta,
+.hljs-selector-id,
+.hljs-title {
+  color: #4078f2;
+}
+
+.hljs-emphasis {
+  font-style: italic;
+}
+
+.hljs-strong {
+  font-weight: bold;
+}
+
+.hljs-link {
+  text-decoration: underline;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/default.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/default.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/default.css	(revision 12)
@@ -0,0 +1,107 @@
+
+/****************************************************************************
+  Original highlight.js style (c) Ivan Sagalaev <maniac@softwaremaniacs.org>
+ */
+
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em;
+  background: #F0F0F0;
+/*
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em 0.5em 0.5em 1.5em;
+  color: #424242;
+  background: #fcfcfc;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+ */
+}
+
+
+/* Base color: saturation 0; */
+
+.hljs,
+.hljs-subst {
+  color: #444;
+}
+
+.hljs-comment {
+  color: #888888;
+}
+
+.hljs-keyword,
+.hljs-attribute,
+.hljs-selector-tag,
+.hljs-meta-keyword,
+.hljs-doctag,
+.hljs-name {
+  font-weight: bold;
+}
+
+
+/* User color: hue: 0 */
+
+.hljs-type,
+.hljs-string,
+.hljs-number,
+.hljs-selector-id,
+.hljs-selector-class,
+.hljs-quote,
+.hljs-template-tag,
+.hljs-deletion {
+  color: #880000;
+}
+
+.hljs-title,
+.hljs-section {
+  color: #880000;
+  font-weight: bold;
+}
+
+.hljs-regexp,
+.hljs-symbol,
+.hljs-variable,
+.hljs-template-variable,
+.hljs-link,
+.hljs-selector-attr,
+.hljs-selector-pseudo {
+  color: #BC6060;
+}
+
+
+/* Language color: hue: 90; */
+
+.hljs-literal {
+  color: #78A960;
+}
+
+.hljs-built_in,
+.hljs-bullet,
+.hljs-code,
+.hljs-addition {
+  color: #397300;
+}
+
+
+/* Meta color: hue: 200 */
+
+.hljs-meta {
+  color: #1f7199;
+}
+
+.hljs-meta-string {
+  color: #4d99bf;
+}
+
+
+/* Misc effects */
+
+.hljs-emphasis {
+  font-style: italic;
+}
+
+.hljs-strong {
+  font-weight: bold;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/foundation.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/foundation.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/foundation.css	(revision 12)
@@ -0,0 +1,99 @@
+
+/*******************************************************
+  Description: Foundation 4 docs style for highlight.js
+  Author: Dan Allen <dan.j.allen@gmail.com>
+  Website: http://foundation.zurb.com/docs/
+  Version: 1.0
+  Date: 2013-04-02
+*/
+
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em;
+  background: #eee;
+  color: black;
+/*
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em 0.5em 0.5em 1.5em;
+  color: #424242;
+  background: #fcfcfc;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+ */
+}
+
+.hljs-link,
+.hljs-emphasis,
+.hljs-attribute,
+.hljs-addition {
+  color: #070;
+}
+
+.hljs-emphasis {
+  font-style: italic;
+}
+
+.hljs-strong,
+.hljs-string,
+.hljs-deletion {
+  color: #d14;
+}
+
+.hljs-strong {
+  font-weight: bold;
+}
+
+.hljs-quote,
+.hljs-comment {
+  color: #998;
+  font-style: italic;
+}
+
+.hljs-section,
+.hljs-title {
+  color: #900;
+}
+
+.hljs-class .hljs-title,
+.hljs-type {
+  color: #458;
+}
+
+.hljs-variable,
+.hljs-template-variable {
+  color: #336699;
+}
+
+.hljs-bullet {
+  color: #997700;
+}
+
+.hljs-meta {
+  color: #3344bb;
+}
+
+.hljs-code,
+.hljs-number,
+.hljs-literal,
+.hljs-keyword,
+.hljs-selector-tag {
+  color: #099;
+}
+
+.hljs-regexp {
+  background-color: #fff0ff;
+  color: #880088;
+}
+
+.hljs-symbol {
+  color: #990073;
+}
+
+.hljs-tag,
+.hljs-name,
+.hljs-selector-id,
+.hljs-selector-class {
+  color: #007700;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/vs.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/vs.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/css/vs.css	(revision 12)
@@ -0,0 +1,76 @@
+
+/**********************************************************************************************
+  Visual Studio-like style based on original C# coloring by Jason Diamond <jason@diamond.name>
+ */
+.hljs {
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em;
+  background: white;
+  color: black;
+/*
+  display: block;
+  overflow-x: auto;
+  padding: 0.5em 0.5em 0.5em 1.5em;
+  color: #424242;
+  background: #fcfcfc;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+ */
+}
+
+.hljs-comment,
+.hljs-quote,
+.hljs-variable {
+  color: #008000;
+}
+
+.hljs-keyword,
+.hljs-selector-tag,
+.hljs-built_in,
+.hljs-name,
+.hljs-tag {
+  color: #00f;
+}
+
+.hljs-string,
+.hljs-title,
+.hljs-section,
+.hljs-attribute,
+.hljs-literal,
+.hljs-template-tag,
+.hljs-template-variable,
+.hljs-type,
+.hljs-addition {
+  color: #a31515;
+}
+
+.hljs-deletion,
+.hljs-selector-attr,
+.hljs-selector-pseudo,
+.hljs-meta {
+  color: #2b91af;
+}
+
+.hljs-doctag {
+  color: #808080;
+}
+
+.hljs-attr {
+  color: #f00;
+}
+
+.hljs-symbol,
+.hljs-bullet,
+.hljs-link {
+  color: #00b0e8;
+}
+
+
+.hljs-emphasis {
+  font-style: italic;
+}
+
+.hljs-strong {
+  font-weight: bold;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/js/highlight.pack.js
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/js/highlight.pack.js	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/10.4.0/js/highlight.pack.js	(revision 12)
@@ -0,0 +1,1962 @@
+/*
+  Highlight.js 10.4.0 (4055826e)
+  License: BSD-3-Clause
+  Copyright (c) 2006-2020, Ivan Sagalaev
+*/
+var hljs=function(){"use strict";function e(t){
+return t instanceof Map?t.clear=t.delete=t.set=()=>{
+throw Error("map is read-only")}:t instanceof Set&&(t.add=t.clear=t.delete=()=>{
+throw Error("set is read-only")
+}),Object.freeze(t),Object.getOwnPropertyNames(t).forEach((n=>{var s=t[n]
+;"object"!=typeof s||Object.isFrozen(s)||e(s)})),t}var t=e,n=e;t.default=n
+;class s{constructor(e){void 0===e.data&&(e.data={}),this.data=e.data}
+ignoreMatch(){this.ignore=!0}}function r(e){
+return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;")
+}function a(e,...t){const n=Object.create(null);for(const t in e)n[t]=e[t]
+;return t.forEach((e=>{for(const t in e)n[t]=e[t]})),n}function i(e){
+return e.nodeName.toLowerCase()}var o=Object.freeze({__proto__:null,
+escapeHTML:r,inherit:a,nodeStream:e=>{const t=[];return function e(n,s){
+for(let r=n.firstChild;r;r=r.nextSibling)3===r.nodeType?s+=r.nodeValue.length:1===r.nodeType&&(t.push({
+event:"start",offset:s,node:r}),s=e(r,s),i(r).match(/br|hr|img|input/)||t.push({
+event:"stop",offset:s,node:r}));return s}(e,0),t},mergeStreams:(e,t,n)=>{
+let s=0,a="";const o=[];function l(){
+return e.length&&t.length?e[0].offset!==t[0].offset?e[0].offset<t[0].offset?e:t:"start"===t[0].event?e:t:e.length?e:t
+}function c(e){
+a+="<"+i(e)+[].map.call(e.attributes,(e=>" "+e.nodeName+'="'+r(e.value)+'"')).join("")+">"
+}function u(e){a+="</"+i(e)+">"}function g(e){("start"===e.event?c:u)(e.node)}
+for(;e.length||t.length;){let t=l()
+;if(a+=r(n.substring(s,t[0].offset)),s=t[0].offset,t===e){o.reverse().forEach(u)
+;do{g(t.splice(0,1)[0]),t=l()}while(t===e&&t.length&&t[0].offset===s)
+;o.reverse().forEach(c)
+}else"start"===t[0].event?o.push(t[0].node):o.pop(),g(t.splice(0,1)[0])}
+return a+r(n.substr(s))}});const l=e=>!!e.kind;class c{constructor(e,t){
+this.buffer="",this.classPrefix=t.classPrefix,e.walk(this)}addText(e){
+this.buffer+=r(e)}openNode(e){if(!l(e))return;let t=e.kind
+;e.sublanguage||(t=`${this.classPrefix}${t}`),this.span(t)}closeNode(e){
+l(e)&&(this.buffer+="</span>")}value(){return this.buffer}span(e){
+this.buffer+=`<span class="${e}">`}}class u{constructor(){this.rootNode={
+children:[]},this.stack=[this.rootNode]}get top(){
+return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(e){
+this.top.children.push(e)}openNode(e){const t={kind:e,children:[]}
+;this.add(t),this.stack.push(t)}closeNode(){
+if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){
+for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)}
+walk(e){return this.constructor._walk(e,this.rootNode)}static _walk(e,t){
+return"string"==typeof t?e.addText(t):t.children&&(e.openNode(t),
+t.children.forEach((t=>this._walk(e,t))),e.closeNode(t)),e}static _collapse(e){
+"string"!=typeof e&&e.children&&(e.children.every((e=>"string"==typeof e))?e.children=[e.children.join("")]:e.children.forEach((e=>{
+u._collapse(e)})))}}class g extends u{constructor(e){super(),this.options=e}
+addKeyword(e,t){""!==e&&(this.openNode(t),this.addText(e),this.closeNode())}
+addText(e){""!==e&&this.add(e)}addSublanguage(e,t){const n=e.root
+;n.kind=t,n.sublanguage=!0,this.add(n)}toHTML(){
+return new c(this,this.options).value()}finalize(){return!0}}function d(e){
+return e?"string"==typeof e?e:e.source:null}
+const h="[a-zA-Z]\\w*",f="[a-zA-Z_]\\w*",p="\\b\\d+(\\.\\d+)?",m="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",b="\\b(0b[01]+)",x={
+begin:"\\\\[\\s\\S]",relevance:0},E={className:"string",begin:"'",end:"'",
+illegal:"\\n",contains:[x]},v={className:"string",begin:'"',end:'"',
+illegal:"\\n",contains:[x]},_={
+begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/
+},w=(e,t,n={})=>{const s=a({className:"comment",begin:e,end:t,contains:[]},n)
+;return s.contains.push(_),s.contains.push({className:"doctag",
+begin:"(?:TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):",relevance:0}),s
+},N=w("//","$"),y=w("/\\*","\\*/"),R=w("#","$");var k=Object.freeze({
+__proto__:null,IDENT_RE:h,UNDERSCORE_IDENT_RE:f,NUMBER_RE:p,C_NUMBER_RE:m,
+BINARY_NUMBER_RE:b,
+RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",
+SHEBANG:(e={})=>{const t=/^#![ ]*\//
+;return e.binary&&(e.begin=((...e)=>e.map((e=>d(e))).join(""))(t,/.*\b/,e.binary,/\b.*/)),
+a({className:"meta",begin:t,end:/$/,relevance:0,"on:begin":(e,t)=>{
+0!==e.index&&t.ignoreMatch()}},e)},BACKSLASH_ESCAPE:x,APOS_STRING_MODE:E,
+QUOTE_STRING_MODE:v,PHRASAL_WORDS_MODE:_,COMMENT:w,C_LINE_COMMENT_MODE:N,
+C_BLOCK_COMMENT_MODE:y,HASH_COMMENT_MODE:R,NUMBER_MODE:{className:"number",
+begin:p,relevance:0},C_NUMBER_MODE:{className:"number",begin:m,relevance:0},
+BINARY_NUMBER_MODE:{className:"number",begin:b,relevance:0},CSS_NUMBER_MODE:{
+className:"number",
+begin:p+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",
+relevance:0},REGEXP_MODE:{begin:/(?=\/[^/\n]*\/)/,contains:[{className:"regexp",
+begin:/\//,end:/\/[gimuy]*/,illegal:/\n/,contains:[x,{begin:/\[/,end:/\]/,
+relevance:0,contains:[x]}]}]},TITLE_MODE:{className:"title",begin:h,relevance:0
+},UNDERSCORE_TITLE_MODE:{className:"title",begin:f,relevance:0},METHOD_GUARD:{
+begin:"\\.\\s*[a-zA-Z_]\\w*",relevance:0},END_SAME_AS_BEGIN:e=>Object.assign(e,{
+"on:begin":(e,t)=>{t.data._beginMatch=e[1]},"on:end":(e,t)=>{
+t.data._beginMatch!==e[1]&&t.ignoreMatch()}})})
+;const M=["of","and","for","in","not","or","if","then","parent","list","value"]
+;function O(e){function t(t,n){
+return RegExp(d(t),"m"+(e.case_insensitive?"i":"")+(n?"g":""))}class n{
+constructor(){
+this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0}
+addRule(e,t){
+t.position=this.position++,this.matchIndexes[this.matchAt]=t,this.regexes.push([t,e]),
+this.matchAt+=(e=>RegExp(e.toString()+"|").exec("").length-1)(e)+1}compile(){
+0===this.regexes.length&&(this.exec=()=>null)
+;const e=this.regexes.map((e=>e[1]));this.matcherRe=t(((e,t="|")=>{
+const n=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./;let s=0,r=""
+;for(let a=0;a<e.length;a++){s+=1;const i=s;let o=d(e[a])
+;for(a>0&&(r+=t),r+="(";o.length>0;){const e=n.exec(o);if(null==e){r+=o;break}
+r+=o.substring(0,e.index),
+o=o.substring(e.index+e[0].length),"\\"===e[0][0]&&e[1]?r+="\\"+(Number(e[1])+i):(r+=e[0],
+"("===e[0]&&s++)}r+=")"}return r})(e),!0),this.lastIndex=0}exec(e){
+this.matcherRe.lastIndex=this.lastIndex;const t=this.matcherRe.exec(e)
+;if(!t)return null
+;const n=t.findIndex(((e,t)=>t>0&&void 0!==e)),s=this.matchIndexes[n]
+;return t.splice(0,n),Object.assign(t,s)}}class s{constructor(){
+this.rules=[],this.multiRegexes=[],
+this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(e){
+if(this.multiRegexes[e])return this.multiRegexes[e];const t=new n
+;return this.rules.slice(e).forEach((([e,n])=>t.addRule(e,n))),
+t.compile(),this.multiRegexes[e]=t,t}resumingScanAtSamePosition(){
+return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(e,t){
+this.rules.push([e,t]),"begin"===t.type&&this.count++}exec(e){
+const t=this.getMatcher(this.regexIndex);t.lastIndex=this.lastIndex
+;let n=t.exec(e)
+;if(this.resumingScanAtSamePosition())if(n&&n.index===this.lastIndex);else{
+const t=this.getMatcher(0);t.lastIndex=this.lastIndex+1,n=t.exec(e)}
+return n&&(this.regexIndex+=n.position+1,
+this.regexIndex===this.count&&this.considerAll()),n}}function r(e,t){
+"."===e.input[e.index-1]&&t.ignoreMatch()}
+if(e.contains&&e.contains.includes("self"))throw Error("ERR: contains `self` is not supported at the top-level of a language.  See documentation.")
+;return e.classNameAliases=a(e.classNameAliases||{}),function n(i,o){const l=i
+;if(i.compiled)return l
+;i.compiled=!0,i.__beforeBegin=null,i.keywords=i.keywords||i.beginKeywords
+;let c=null
+;if("object"==typeof i.keywords&&(c=i.keywords.$pattern,delete i.keywords.$pattern),
+i.keywords&&(i.keywords=((e,t)=>{const n={}
+;return"string"==typeof e?s("keyword",e):Object.keys(e).forEach((t=>{s(t,e[t])
+})),n;function s(e,s){t&&(s=s.toLowerCase()),s.split(" ").forEach((t=>{
+const s=t.split("|");n[s[0]]=[e,A(s[0],s[1])]}))}
+})(i.keywords,e.case_insensitive)),
+i.lexemes&&c)throw Error("ERR: Prefer `keywords.$pattern` to `mode.lexemes`, BOTH are not allowed. (see mode reference) ")
+;return l.keywordPatternRe=t(i.lexemes||c||/\w+/,!0),
+o&&(i.beginKeywords&&(i.begin="\\b("+i.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)",
+i.__beforeBegin=r),
+i.begin||(i.begin=/\B|\b/),l.beginRe=t(i.begin),i.endSameAsBegin&&(i.end=i.begin),
+i.end||i.endsWithParent||(i.end=/\B|\b/),
+i.end&&(l.endRe=t(i.end)),l.terminator_end=d(i.end)||"",
+i.endsWithParent&&o.terminator_end&&(l.terminator_end+=(i.end?"|":"")+o.terminator_end)),
+i.illegal&&(l.illegalRe=t(i.illegal)),
+void 0===i.relevance&&(i.relevance=1),i.contains||(i.contains=[]),
+i.contains=[].concat(...i.contains.map((e=>(e=>(e.variants&&!e.cached_variants&&(e.cached_variants=e.variants.map((t=>a(e,{
+variants:null},t)))),e.cached_variants?e.cached_variants:L(e)?a(e,{
+starts:e.starts?a(e.starts):null
+}):Object.isFrozen(e)?a(e):e))("self"===e?i:e)))),i.contains.forEach((e=>{n(e,l)
+})),i.starts&&n(i.starts,o),l.matcher=(e=>{const t=new s
+;return e.contains.forEach((e=>t.addRule(e.begin,{rule:e,type:"begin"
+}))),e.terminator_end&&t.addRule(e.terminator_end,{type:"end"
+}),e.illegal&&t.addRule(e.illegal,{type:"illegal"}),t})(l),l}(e)}function L(e){
+return!!e&&(e.endsWithParent||L(e.starts))}function A(e,t){
+return t?Number(t):(e=>M.includes(e.toLowerCase()))(e)?0:1}function j(e){
+const t={props:["language","code","autodetect"],data:()=>({detectedLanguage:"",
+unknownLanguage:!1}),computed:{className(){
+return this.unknownLanguage?"":"hljs "+this.detectedLanguage},highlighted(){
+if(!this.autoDetect&&!e.getLanguage(this.language))return console.warn(`The language "${this.language}" you specified could not be found.`),
+this.unknownLanguage=!0,r(this.code);let t
+;return this.autoDetect?(t=e.highlightAuto(this.code),
+this.detectedLanguage=t.language):(t=e.highlight(this.language,this.code,this.ignoreIllegals),
+this.detectedLanguage=this.language),t.value},autoDetect(){
+return!(this.language&&(e=this.autodetect,!e&&""!==e));var e},
+ignoreIllegals:()=>!0},render(e){return e("pre",{},[e("code",{
+class:this.className,domProps:{innerHTML:this.highlighted}})])}};return{
+Component:t,VuePlugin:{install(e){e.component("highlightjs",t)}}}}
+const I=r,S=a,{nodeStream:T,mergeStreams:B}=o,P=Symbol("nomatch");return(e=>{
+const n=[],r=Object.create(null),a=Object.create(null),i=[];let o=!0
+;const l=/(^(<[^>]+>|\t|)+|\n)/gm,c="Could not find the language '{}', did you forget to load/include a language module?",u={
+disableAutodetect:!0,name:"Plain text",contains:[]};let d={
+noHighlightRe:/^(no-?highlight)$/i,
+languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-",
+tabReplace:null,useBR:!1,languages:null,__emitter:g};function h(e){
+return d.noHighlightRe.test(e)}function f(e,t,n,s){const r={code:t,language:e}
+;N("before:highlight",r);const a=r.result?r.result:p(r.language,r.code,n,s)
+;return a.code=r.code,N("after:highlight",a),a}function p(e,t,n,a){const i=t
+;function l(e,t){const n=_.case_insensitive?t[0].toLowerCase():t[0]
+;return Object.prototype.hasOwnProperty.call(e.keywords,n)&&e.keywords[n]}
+function u(){null!=y.subLanguage?(()=>{if(""===M)return;let e=null
+;if("string"==typeof y.subLanguage){
+if(!r[y.subLanguage])return void k.addText(M)
+;e=p(y.subLanguage,M,!0,R[y.subLanguage]),R[y.subLanguage]=e.top
+}else e=m(M,y.subLanguage.length?y.subLanguage:null)
+;y.relevance>0&&(L+=e.relevance),k.addSublanguage(e.emitter,e.language)
+})():(()=>{if(!y.keywords)return void k.addText(M);let e=0
+;y.keywordPatternRe.lastIndex=0;let t=y.keywordPatternRe.exec(M),n="";for(;t;){
+n+=M.substring(e,t.index);const s=l(y,t);if(s){const[e,r]=s
+;k.addText(n),n="",L+=r;const a=_.classNameAliases[e]||e;k.addKeyword(t[0],a)
+}else n+=t[0];e=y.keywordPatternRe.lastIndex,t=y.keywordPatternRe.exec(M)}
+n+=M.substr(e),k.addText(n)})(),M=""}function g(e){
+return e.className&&k.openNode(_.classNameAliases[e.className]||e.className),
+y=Object.create(e,{parent:{value:y}}),y}function h(e,t,n){let r=((e,t)=>{
+const n=e&&e.exec(t);return n&&0===n.index})(e.endRe,n);if(r){if(e["on:end"]){
+const n=new s(e);e["on:end"](t,n),n.ignore&&(r=!1)}if(r){
+for(;e.endsParent&&e.parent;)e=e.parent;return e}}
+if(e.endsWithParent)return h(e.parent,t,n)}function f(e){
+return 0===y.matcher.regexIndex?(M+=e[0],1):(S=!0,0)}function b(e){
+const t=e[0],n=i.substr(e.index),s=h(y,e,n);if(!s)return P;const r=y
+;r.skip?M+=t:(r.returnEnd||r.excludeEnd||(M+=t),u(),r.excludeEnd&&(M=t));do{
+y.className&&k.closeNode(),y.skip||y.subLanguage||(L+=y.relevance),y=y.parent
+}while(y!==s.parent)
+;return s.starts&&(s.endSameAsBegin&&(s.starts.endRe=s.endRe),
+g(s.starts)),r.returnEnd?0:t.length}let x={};function E(t,r){const a=r&&r[0]
+;if(M+=t,null==a)return u(),0
+;if("begin"===x.type&&"end"===r.type&&x.index===r.index&&""===a){
+if(M+=i.slice(r.index,r.index+1),!o){const t=Error("0 width match regex")
+;throw t.languageName=e,t.badRule=x.rule,t}return 1}
+if(x=r,"begin"===r.type)return function(e){
+const t=e[0],n=e.rule,r=new s(n),a=[n.__beforeBegin,n["on:begin"]]
+;for(const n of a)if(n&&(n(e,r),r.ignore))return f(t)
+;return n&&n.endSameAsBegin&&(n.endRe=RegExp(t.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&"),"m")),
+n.skip?M+=t:(n.excludeBegin&&(M+=t),
+u(),n.returnBegin||n.excludeBegin||(M=t)),g(n),n.returnBegin?0:t.length}(r)
+;if("illegal"===r.type&&!n){
+const e=Error('Illegal lexeme "'+a+'" for mode "'+(y.className||"<unnamed>")+'"')
+;throw e.mode=y,e}if("end"===r.type){const e=b(r);if(e!==P)return e}
+if("illegal"===r.type&&""===a)return 1
+;if(j>1e5&&j>3*r.index)throw Error("potential infinite loop, way more iterations than matches")
+;return M+=a,a.length}const _=v(e);if(!_)throw console.error(c.replace("{}",e)),
+Error('Unknown language: "'+e+'"');const w=O(_);let N="",y=a||w
+;const R={},k=new d.__emitter(d);(()=>{const e=[]
+;for(let t=y;t!==_;t=t.parent)t.className&&e.unshift(t.className)
+;e.forEach((e=>k.openNode(e)))})();let M="",L=0,A=0,j=0,S=!1;try{
+for(y.matcher.considerAll();;){
+j++,S?S=!1:y.matcher.considerAll(),y.matcher.lastIndex=A
+;const e=y.matcher.exec(i);if(!e)break;const t=E(i.substring(A,e.index),e)
+;A=e.index+t}return E(i.substr(A)),k.closeAllNodes(),k.finalize(),N=k.toHTML(),{
+relevance:L,value:N,language:e,illegal:!1,emitter:k,top:y}}catch(t){
+if(t.message&&t.message.includes("Illegal"))return{illegal:!0,illegalBy:{
+msg:t.message,context:i.slice(A-100,A+100),mode:t.mode},sofar:N,relevance:0,
+value:I(i),emitter:k};if(o)return{illegal:!1,relevance:0,value:I(i),emitter:k,
+language:e,top:y,errorRaised:t};throw t}}function m(e,t){
+t=t||d.languages||Object.keys(r);const n=(e=>{const t={relevance:0,
+emitter:new d.__emitter(d),value:I(e),illegal:!1,top:u}
+;return t.emitter.addText(e),t})(e),s=t.filter(v).filter(w).map((t=>p(t,e,!1)))
+;s.unshift(n);const a=s.sort(((e,t)=>{
+if(e.relevance!==t.relevance)return t.relevance-e.relevance
+;if(e.language&&t.language){if(v(e.language).supersetOf===t.language)return 1
+;if(v(t.language).supersetOf===e.language)return-1}return 0})),[i,o]=a,l=i
+;return l.second_best=o,l}function b(e){
+return d.tabReplace||d.useBR?e.replace(l,(e=>"\n"===e?d.useBR?"<br>":e:d.tabReplace?e.replace(/\t/g,d.tabReplace):e)):e
+}function x(e){let t=null;const n=(e=>{let t=e.className+" "
+;t+=e.parentNode?e.parentNode.className:"";const n=d.languageDetectRe.exec(t)
+;if(n){const t=v(n[1])
+;return t||(console.warn(c.replace("{}",n[1])),console.warn("Falling back to no-highlight mode for this block.",e)),
+t?n[1]:"no-highlight"}return t.split(/\s+/).find((e=>h(e)||v(e)))})(e)
+;if(h(n))return;N("before:highlightBlock",{block:e,language:n
+}),d.useBR?(t=document.createElement("div"),
+t.innerHTML=e.innerHTML.replace(/\n/g,"").replace(/<br[ /]*>/g,"\n")):t=e
+;const s=t.textContent,r=n?f(n,s,!0):m(s),i=T(t);if(i.length){
+const e=document.createElement("div");e.innerHTML=r.value,r.value=B(i,T(e),s)}
+r.value=b(r.value),N("after:highlightBlock",{block:e,result:r
+}),e.innerHTML=r.value,e.className=((e,t,n)=>{const s=t?a[t]:n,r=[e.trim()]
+;return e.match(/\bhljs\b/)||r.push("hljs"),
+e.includes(s)||r.push(s),r.join(" ").trim()
+})(e.className,n,r.language),e.result={language:r.language,re:r.relevance,
+relavance:r.relevance},r.second_best&&(e.second_best={
+language:r.second_best.language,re:r.second_best.relevance,
+relavance:r.second_best.relevance})}const E=()=>{if(E.called)return;E.called=!0
+;const e=document.querySelectorAll("pre code");n.forEach.call(e,x)}
+;function v(e){return e=(e||"").toLowerCase(),r[e]||r[a[e]]}
+function _(e,{languageName:t}){"string"==typeof e&&(e=[e]),e.forEach((e=>{a[e]=t
+}))}function w(e){const t=v(e);return t&&!t.disableAutodetect}function N(e,t){
+const n=e;i.forEach((e=>{e[n]&&e[n](t)}))}Object.assign(e,{highlight:f,
+highlightAuto:m,
+fixMarkup:e=>(console.warn("fixMarkup is deprecated and will be removed entirely in v11.0"),
+console.warn("Please see https://github.com/highlightjs/highlight.js/issues/2534"),
+b(e)),highlightBlock:x,configure:e=>{
+e.useBR&&(console.warn("'useBR' option is deprecated and will be removed entirely in v11.0"),
+console.warn("Please see https://github.com/highlightjs/highlight.js/issues/2559")),
+d=S(d,e)},initHighlighting:E,initHighlightingOnLoad:()=>{
+window.addEventListener("DOMContentLoaded",E,!1)},registerLanguage:(t,n)=>{
+let s=null;try{s=n(e)}catch(e){
+if(console.error("Language definition for '{}' could not be registered.".replace("{}",t)),
+!o)throw e;console.error(e),s=u}
+s.name||(s.name=t),r[t]=s,s.rawDefinition=n.bind(null,e),
+s.aliases&&_(s.aliases,{languageName:t})},listLanguages:()=>Object.keys(r),
+getLanguage:v,registerAliases:_,requireLanguage:e=>{
+console.warn("requireLanguage is deprecated and will be removed entirely in the future."),
+console.warn("Please see https://github.com/highlightjs/highlight.js/pull/2844")
+;const t=v(e);if(t)return t
+;throw Error("The '{}' language is required, but not loaded.".replace("{}",e))},
+autoDetection:w,inherit:S,addPlugin:e=>{i.push(e)},vuePlugin:j(e).VuePlugin
+}),e.debugMode=()=>{o=!1},e.safeMode=()=>{o=!0},e.versionString="10.4.0"
+;for(const e in k)"object"==typeof k[e]&&t(k[e]);return Object.assign(e,k),e
+})({})}()
+;"object"==typeof exports&&"undefined"!=typeof module&&(module.exports=hljs);hljs.registerLanguage("ada",(()=>{"use strict";return e=>{
+const n="[A-Za-z](_?[A-Za-z0-9.])*",s="[]\\{\\}%#'\"",a=e.COMMENT("--","$"),r={
+begin:"\\s+:\\s+",end:"\\s*(:=|;|\\)|=>|$)",illegal:s,contains:[{
+beginKeywords:"loop for declare others",endsParent:!0},{className:"keyword",
+beginKeywords:"not null constant access function procedure in out aliased exception"
+},{className:"type",begin:n,endsParent:!0,relevance:0}]};return{name:"Ada",
+case_insensitive:!0,keywords:{
+keyword:"abort else new return abs elsif not reverse abstract end accept entry select access exception of separate aliased exit or some all others subtype and for out synchronized array function overriding at tagged generic package task begin goto pragma terminate body private then if procedure type case in protected constant interface is raise use declare range delay limited record when delta loop rem while digits renames with do mod requeue xor",
+literal:"True False"},contains:[a,{className:"string",begin:/"/,end:/"/,
+contains:[{begin:/""/,relevance:0}]},{className:"string",begin:/'.'/},{
+className:"number",
+begin:"\\b(\\d(_|\\d)*#\\w+(\\.\\w+)?#([eE][-+]?\\d(_|\\d)*)?|\\d(_|\\d)*(\\.\\d(_|\\d)*)?([eE][-+]?\\d(_|\\d)*)?)",
+relevance:0},{className:"symbol",begin:"'"+n},{className:"title",
+begin:"(\\bwith\\s+)?(\\bprivate\\s+)?\\bpackage\\s+(\\bbody\\s+)?",
+end:"(is|$)",keywords:"package body",excludeBegin:!0,excludeEnd:!0,illegal:s},{
+begin:"(\\b(with|overriding)\\s+)?\\b(function|procedure)\\s+",
+end:"(\\bis|\\bwith|\\brenames|\\)\\s*;)",
+keywords:"overriding function procedure with is renames return",returnBegin:!0,
+contains:[a,{className:"title",
+begin:"(\\bwith\\s+)?\\b(function|procedure)\\s+",end:"(\\(|\\s+|$)",
+excludeBegin:!0,excludeEnd:!0,illegal:s},r,{className:"type",
+begin:"\\breturn\\s+",end:"(\\s+|;|$)",keywords:"return",excludeBegin:!0,
+excludeEnd:!0,endsParent:!0,illegal:s}]},{className:"type",
+begin:"\\b(sub)?type\\s+",end:"\\s+",keywords:"type",excludeBegin:!0,illegal:s
+},r]}}})());hljs.registerLanguage("awk",(()=>{"use strict";return e=>({name:"Awk",keywords:{
+keyword:"BEGIN END if else while do for in break continue delete next nextfile function func exit|10"
+},contains:[{className:"variable",variants:[{begin:/\$[\w\d#@][\w\d_]*/},{
+begin:/\$\{(.*?)\}/}]},{className:"string",contains:[e.BACKSLASH_ESCAPE],
+variants:[{begin:/(u|b)?r?'''/,end:/'''/,relevance:10},{begin:/(u|b)?r?"""/,
+end:/"""/,relevance:10},{begin:/(u|r|ur)'/,end:/'/,relevance:10},{
+begin:/(u|r|ur)"/,end:/"/,relevance:10},{begin:/(b|br)'/,end:/'/},{
+begin:/(b|br)"/,end:/"/},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]
+},e.REGEXP_MODE,e.HASH_COMMENT_MODE,e.NUMBER_MODE]})})());hljs.registerLanguage("coffeescript",(()=>{"use strict"
+;const e=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],n=["true","false","null","undefined","NaN","Infinity"],a=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"])
+;return r=>{const t={
+keyword:e.concat(["then","unless","until","loop","by","when","and","or","is","isnt","not"]).filter((i=["var","const","let","function","static"],
+e=>!i.includes(e))).join(" "),
+literal:n.concat(["yes","no","on","off"]).join(" "),
+built_in:a.concat(["npm","print"]).join(" ")};var i
+;const s="[A-Za-z$_][0-9A-Za-z$_]*",o={className:"subst",begin:/#\{/,end:/\}/,
+keywords:t},c=[r.BINARY_NUMBER_MODE,r.inherit(r.C_NUMBER_MODE,{starts:{
+end:"(\\s*/)?",relevance:0}}),{className:"string",variants:[{begin:/'''/,
+end:/'''/,contains:[r.BACKSLASH_ESCAPE]},{begin:/'/,end:/'/,
+contains:[r.BACKSLASH_ESCAPE]},{begin:/"""/,end:/"""/,
+contains:[r.BACKSLASH_ESCAPE,o]},{begin:/"/,end:/"/,
+contains:[r.BACKSLASH_ESCAPE,o]}]},{className:"regexp",variants:[{begin:"///",
+end:"///",contains:[o,r.HASH_COMMENT_MODE]},{begin:"//[gim]{0,3}(?=\\W)",
+relevance:0},{begin:/\/(?![ *]).*?(?![\\]).\/[gim]{0,3}(?=\W)/}]},{begin:"@"+s
+},{subLanguage:"javascript",excludeBegin:!0,excludeEnd:!0,variants:[{
+begin:"```",end:"```"},{begin:"`",end:"`"}]}];o.contains=c
+;const l=r.inherit(r.TITLE_MODE,{begin:s}),d="(\\(.*\\))?\\s*\\B[-=]>",g={
+className:"params",begin:"\\([^\\(]",returnBegin:!0,contains:[{begin:/\(/,
+end:/\)/,keywords:t,contains:["self"].concat(c)}]};return{name:"CoffeeScript",
+aliases:["coffee","cson","iced"],keywords:t,illegal:/\/\*/,
+contains:c.concat([r.COMMENT("###","###"),r.HASH_COMMENT_MODE,{
+className:"function",begin:"^\\s*"+s+"\\s*=\\s*"+d,end:"[-=]>",returnBegin:!0,
+contains:[l,g]},{begin:/[:\(,=]\s*/,relevance:0,contains:[{className:"function",
+begin:d,end:"[-=]>",returnBegin:!0,contains:[g]}]},{className:"class",
+beginKeywords:"class",end:"$",illegal:/[:="\[\]]/,contains:[{
+beginKeywords:"extends",endsWithParent:!0,illegal:/[:="\[\]]/,contains:[l]},l]
+},{begin:s+":",end:":",returnBegin:!0,returnEnd:!0,relevance:0}])}}})());hljs.registerLanguage("abnf",(()=>{"use strict";return s=>({
+name:"Augmented Backus-Naur Form",illegal:"[!@#$^&',?+~`|:]",
+keywords:"ALPHA BIT CHAR CR CRLF CTL DIGIT DQUOTE HEXDIG HTAB LF LWSP OCTET SP VCHAR WSP",
+contains:[{className:"attribute",begin:"^[a-zA-Z][a-zA-Z0-9-]*(?=\\s*=)"
+},s.COMMENT(";","$"),{className:"symbol",
+begin:/%b[0-1]+(-[0-1]+|(\.[0-1]+)+){0,1}/},{className:"symbol",
+begin:/%d[0-9]+(-[0-9]+|(\.[0-9]+)+){0,1}/},{className:"symbol",
+begin:/%x[0-9A-F]+(-[0-9A-F]+|(\.[0-9A-F]+)+){0,1}/},{className:"symbol",
+begin:/%[si]/},s.QUOTE_STRING_MODE,s.NUMBER_MODE]})})());hljs.registerLanguage("bash",(()=>{"use strict";function e(...e){
+return e.map((e=>{return(s=e)?"string"==typeof s?s:s.source:null;var s
+})).join("")}return s=>{const n={},t={begin:/\$\{/,end:/\}/,contains:["self",{
+begin:/:-/,contains:[n]}]};Object.assign(n,{className:"variable",variants:[{
+begin:e(/\$[\w\d#@][\w\d_]*/,"(?![\\w\\d])(?![$])")},t]});const a={
+className:"subst",begin:/\$\(/,end:/\)/,contains:[s.BACKSLASH_ESCAPE]},i={
+begin:/<<-?\s*(?=\w+)/,starts:{contains:[s.END_SAME_AS_BEGIN({begin:/(\w+)/,
+end:/(\w+)/,className:"string"})]}},c={className:"string",begin:/"/,end:/"/,
+contains:[s.BACKSLASH_ESCAPE,n,a]};a.contains.push(c);const o={begin:/\$\(\(/,
+end:/\)\)/,contains:[{begin:/\d+#[0-9a-f]+/,className:"number"},s.NUMBER_MODE,n]
+},r=s.SHEBANG({binary:"(fish|bash|zsh|sh|csh|ksh|tcsh|dash|scsh)",relevance:10
+}),l={className:"function",begin:/\w[\w\d_]*\s*\(\s*\)\s*\{/,returnBegin:!0,
+contains:[s.inherit(s.TITLE_MODE,{begin:/\w[\w\d_]*/})],relevance:0};return{
+name:"Bash",aliases:["sh","zsh"],keywords:{$pattern:/\b[a-z._-]+\b/,
+keyword:"if then else elif fi for while in do done case esac function",
+literal:"true false",
+built_in:"break cd continue eval exec exit export getopts hash pwd readonly return shift test times trap umask unset alias bind builtin caller command declare echo enable help let local logout mapfile printf read readarray source type typeset ulimit unalias set shopt autoload bg bindkey bye cap chdir clone comparguments compcall compctl compdescribe compfiles compgroups compquote comptags comptry compvalues dirs disable disown echotc echoti emulate fc fg float functions getcap getln history integer jobs kill limit log noglob popd print pushd pushln rehash sched setcap setopt stat suspend ttyctl unfunction unhash unlimit unsetopt vared wait whence where which zcompile zformat zftp zle zmodload zparseopts zprof zpty zregexparse zsocket zstyle ztcp"
+},contains:[r,s.SHEBANG(),l,o,s.HASH_COMMENT_MODE,i,c,{className:"",begin:/\\"/
+},{className:"string",begin:/'/,end:/'/},n]}}})());hljs.registerLanguage("java",(()=>{"use strict";return e=>{
+var n="false synchronized int abstract float private char boolean var static null if const for true while long strictfp finally protected import native final void enum else break transient catch instanceof byte super volatile case assert short package default double public try this switch continue throws protected public private module requires exports do",a={
+className:"meta",begin:"@[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*",
+contains:[{begin:/\(/,end:/\)/,contains:["self"]}]
+},s="\\.([0-9](_*[0-9])*)",i="[0-9a-fA-F](_*[0-9a-fA-F])*",r={
+className:"number",variants:[{
+begin:`(\\b([0-9](_*[0-9])*)((${s})|\\.)?|(${s}))[eE][+-]?([0-9](_*[0-9])*)[fFdD]?\\b`
+},{begin:`\\b([0-9](_*[0-9])*)((${s})[fFdD]?\\b|\\.([fFdD]\\b)?)`},{
+begin:`(${s})[fFdD]?\\b`},{begin:"\\b([0-9](_*[0-9])*)[fFdD]\\b"},{
+begin:`\\b0[xX]((${i})\\.?|(${i})?\\.(${i}))[pP][+-]?([0-9](_*[0-9])*)[fFdD]?\\b`
+},{begin:"\\b(0|[1-9](_*[0-9])*)[lL]?\\b"},{begin:`\\b0[xX](${i})[lL]?\\b`},{
+begin:"\\b0(_*[0-7])*[lL]?\\b"},{begin:"\\b0[bB][01](_*[01])*[lL]?\\b"}],
+relevance:0};return{name:"Java",aliases:["jsp"],keywords:n,illegal:/<\/|#/,
+contains:[e.COMMENT("/\\*\\*","\\*/",{relevance:0,contains:[{begin:/\w+@/,
+relevance:0},{className:"doctag",begin:"@[A-Za-z]+"}]}),{
+begin:/import java\.[a-z]+\./,keywords:"import",relevance:2
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{
+className:"class",beginKeywords:"class interface enum",end:/[{;=]/,
+excludeEnd:!0,keywords:"class interface enum",illegal:/[:"\[\]]/,contains:[{
+beginKeywords:"extends implements"},e.UNDERSCORE_TITLE_MODE]},{
+beginKeywords:"new throw return else",relevance:0},{className:"class",
+begin:"record\\s+"+e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,excludeEnd:!0,
+end:/[{;=]/,keywords:n,contains:[{beginKeywords:"record"},{
+begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0,
+contains:[e.UNDERSCORE_TITLE_MODE]},{className:"params",begin:/\(/,end:/\)/,
+keywords:n,relevance:0,contains:[e.C_BLOCK_COMMENT_MODE]
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{className:"function",
+begin:"([\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*(<[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*(\\s*,\\s*[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*)*>)?\\s+)+"+e.UNDERSCORE_IDENT_RE+"\\s*\\(",
+returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:n,contains:[{
+begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0,
+contains:[e.UNDERSCORE_TITLE_MODE]},{className:"params",begin:/\(/,end:/\)/,
+keywords:n,relevance:0,
+contains:[a,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,r,e.C_BLOCK_COMMENT_MODE]
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},r,a]}}})());hljs.registerLanguage("erlang-repl",(()=>{"use strict";return e=>({
+name:"Erlang REPL",keywords:{built_in:"spawn spawn_link self",
+keyword:"after and andalso|10 band begin bnot bor bsl bsr bxor case catch cond div end fun if let not of or orelse|10 query receive rem try when xor"
+},contains:[{className:"meta",begin:"^[0-9]+> ",relevance:10
+},e.COMMENT("%","$"),{className:"number",
+begin:"\\b(\\d+(_\\d+)*#[a-fA-F0-9]+(_[a-fA-F0-9]+)*|\\d+(_\\d+)*(\\.\\d+(_\\d+)*)?([eE][-+]?\\d+)?)",
+relevance:0},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{
+begin:"\\?(::)?([A-Z]\\w*(::)?)+"},{begin:"->"},{begin:"ok"},{begin:"!"},{
+begin:"(\\b[a-z'][a-zA-Z0-9_']*:[a-z'][a-zA-Z0-9_']*)|(\\b[a-z'][a-zA-Z0-9_']*)",
+relevance:0},{begin:"[A-Z][a-zA-Z0-9_']*",relevance:0}]})})());hljs.registerLanguage("go",(()=>{"use strict";return e=>{const n={
+keyword:"break default func interface select case map struct chan else goto package switch const fallthrough if range type continue for import return var go defer bool byte complex64 complex128 float32 float64 int8 int16 int32 int64 string uint8 uint16 uint32 uint64 int uint uintptr rune",
+literal:"true false iota nil",
+built_in:"append cap close complex copy imag len make new panic print println real recover delete"
+};return{name:"Go",aliases:["golang"],keywords:n,illegal:"</",
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{className:"string",
+variants:[e.QUOTE_STRING_MODE,e.APOS_STRING_MODE,{begin:"`",end:"`"}]},{
+className:"number",variants:[{begin:e.C_NUMBER_RE+"[i]",relevance:1
+},e.C_NUMBER_MODE]},{begin:/:=/},{className:"function",beginKeywords:"func",
+end:"\\s*(\\{|$)",excludeEnd:!0,contains:[e.TITLE_MODE,{className:"params",
+begin:/\(/,end:/\)/,keywords:n,illegal:/["']/}]}]}}})());hljs.registerLanguage("cpp",(()=>{"use strict";return e=>{const t=(e=>{
+function t(e){return"(?:"+e+")?"}var n=e.COMMENT("//","$",{contains:[{
+begin:/\\\n/}]
+}),r="[a-zA-Z_]\\w*::",a="(decltype\\(auto\\)|"+t(r)+"[a-zA-Z_]\\w*"+t("<.*?>")+")",i={
+className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},s={className:"string",
+variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]},{
+begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",
+end:"'",illegal:"."},e.END_SAME_AS_BEGIN({
+begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},c={
+className:"number",variants:[{begin:"\\b(0b[01']+)"},{
+begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{
+begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"
+}],relevance:0},o={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{
+"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"
+},contains:[{begin:/\\\n/,relevance:0},e.inherit(s,{className:"meta-string"}),{
+className:"meta-string",begin:/<.*?>/,end:/$/,illegal:"\\n"
+},n,e.C_BLOCK_COMMENT_MODE]},l={className:"title",begin:t(r)+e.IDENT_RE,
+relevance:0},d=t(r)+e.IDENT_RE+"\\s*\\(",u={
+keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq",
+built_in:"std string wstring cin cout cerr clog stdin stdout stderr stringstream istringstream ostringstream auto_ptr deque list queue stack vector map set pair bitset multiset multimap unordered_set unordered_map unordered_multiset unordered_multimap priority_queue make_pair array shared_ptr abort terminate abs acos asin atan2 atan calloc ceil cosh cos exit exp fabs floor fmod fprintf fputs free frexp fscanf future isalnum isalpha iscntrl isdigit isgraph islower isprint ispunct isspace isupper isxdigit tolower toupper labs ldexp log10 log malloc realloc memchr memcmp memcpy memset modf pow printf putchar puts scanf sinh sin snprintf sprintf sqrt sscanf strcat strchr strcmp strcpy strcspn strlen strncat strncmp strncpy strpbrk strrchr strspn strstr tanh tan vfprintf vprintf vsprintf endl initializer_list unique_ptr _Bool complex _Complex imaginary _Imaginary",
+literal:"true false nullptr NULL"},m=[o,i,n,e.C_BLOCK_COMMENT_MODE,c,s],p={
+variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{
+beginKeywords:"new throw return else",end:/;/}],keywords:u,contains:m.concat([{
+begin:/\(/,end:/\)/,keywords:u,contains:m.concat(["self"]),relevance:0}]),
+relevance:0},_={className:"function",begin:"("+a+"[\\*&\\s]+)+"+d,
+returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:u,illegal:/[^\w\s\*&:<>]/,
+contains:[{begin:"decltype\\(auto\\)",keywords:u,relevance:0},{begin:d,
+returnBegin:!0,contains:[l],relevance:0},{className:"params",begin:/\(/,
+end:/\)/,keywords:u,relevance:0,contains:[n,e.C_BLOCK_COMMENT_MODE,s,c,i,{
+begin:/\(/,end:/\)/,keywords:u,relevance:0,
+contains:["self",n,e.C_BLOCK_COMMENT_MODE,s,c,i]}]
+},i,n,e.C_BLOCK_COMMENT_MODE,o]};return{
+aliases:["c","cc","h","c++","h++","hpp","hh","hxx","cxx"],keywords:u,
+disableAutodetect:!0,illegal:"</",contains:[].concat(p,_,m,[o,{
+begin:"\\b(deque|list|queue|priority_queue|pair|stack|vector|map|set|bitset|multiset|multimap|unordered_map|unordered_set|unordered_multiset|unordered_multimap|array)\\s*<",
+end:">",keywords:u,contains:["self",i]},{begin:e.IDENT_RE+"::",keywords:u},{
+className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/,
+contains:[{beginKeywords:"final class struct"},e.TITLE_MODE]}]),exports:{
+preprocessor:o,strings:s,keywords:u}}})(e)
+;return t.disableAutodetect=!1,t.name="C++",
+t.aliases=["cc","c++","h++","hpp","hh","hxx","cxx"],t}})());hljs.registerLanguage("armasm",(()=>{"use strict";return s=>{const e={
+variants:[s.COMMENT("^[ \\t]*(?=#)","$",{relevance:0,excludeBegin:!0
+}),s.COMMENT("[;@]","$",{relevance:0
+}),s.C_LINE_COMMENT_MODE,s.C_BLOCK_COMMENT_MODE]};return{name:"ARM Assembly",
+case_insensitive:!0,aliases:["arm"],keywords:{$pattern:"\\.?"+s.IDENT_RE,
+meta:".2byte .4byte .align .ascii .asciz .balign .byte .code .data .else .end .endif .endm .endr .equ .err .exitm .extern .global .hword .if .ifdef .ifndef .include .irp .long .macro .rept .req .section .set .skip .space .text .word .arm .thumb .code16 .code32 .force_thumb .thumb_func .ltorg ALIAS ALIGN ARM AREA ASSERT ATTR CN CODE CODE16 CODE32 COMMON CP DATA DCB DCD DCDU DCDO DCFD DCFDU DCI DCQ DCQU DCW DCWU DN ELIF ELSE END ENDFUNC ENDIF ENDP ENTRY EQU EXPORT EXPORTAS EXTERN FIELD FILL FUNCTION GBLA GBLL GBLS GET GLOBAL IF IMPORT INCBIN INCLUDE INFO KEEP LCLA LCLL LCLS LTORG MACRO MAP MEND MEXIT NOFP OPT PRESERVE8 PROC QN READONLY RELOC REQUIRE REQUIRE8 RLIST FN ROUT SETA SETL SETS SN SPACE SUBT THUMB THUMBX TTL WHILE WEND ",
+built_in:"r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12 r13 r14 r15 pc lr sp ip sl sb fp a1 a2 a3 a4 v1 v2 v3 v4 v5 v6 v7 v8 f0 f1 f2 f3 f4 f5 f6 f7 p0 p1 p2 p3 p4 p5 p6 p7 p8 p9 p10 p11 p12 p13 p14 p15 c0 c1 c2 c3 c4 c5 c6 c7 c8 c9 c10 c11 c12 c13 c14 c15 q0 q1 q2 q3 q4 q5 q6 q7 q8 q9 q10 q11 q12 q13 q14 q15 cpsr_c cpsr_x cpsr_s cpsr_f cpsr_cx cpsr_cxs cpsr_xs cpsr_xsf cpsr_sf cpsr_cxsf spsr_c spsr_x spsr_s spsr_f spsr_cx spsr_cxs spsr_xs spsr_xsf spsr_sf spsr_cxsf s0 s1 s2 s3 s4 s5 s6 s7 s8 s9 s10 s11 s12 s13 s14 s15 s16 s17 s18 s19 s20 s21 s22 s23 s24 s25 s26 s27 s28 s29 s30 s31 d0 d1 d2 d3 d4 d5 d6 d7 d8 d9 d10 d11 d12 d13 d14 d15 d16 d17 d18 d19 d20 d21 d22 d23 d24 d25 d26 d27 d28 d29 d30 d31 {PC} {VAR} {TRUE} {FALSE} {OPT} {CONFIG} {ENDIAN} {CODESIZE} {CPU} {FPU} {ARCHITECTURE} {PCSTOREOFFSET} {ARMASM_VERSION} {INTER} {ROPI} {RWPI} {SWST} {NOSWST} . @"
+},contains:[{className:"keyword",
+begin:"\\b(adc|(qd?|sh?|u[qh]?)?add(8|16)?|usada?8|(q|sh?|u[qh]?)?(as|sa)x|and|adrl?|sbc|rs[bc]|asr|b[lx]?|blx|bxj|cbn?z|tb[bh]|bic|bfc|bfi|[su]bfx|bkpt|cdp2?|clz|clrex|cmp|cmn|cpsi[ed]|cps|setend|dbg|dmb|dsb|eor|isb|it[te]{0,3}|lsl|lsr|ror|rrx|ldm(([id][ab])|f[ds])?|ldr((s|ex)?[bhd])?|movt?|mvn|mra|mar|mul|[us]mull|smul[bwt][bt]|smu[as]d|smmul|smmla|mla|umlaal|smlal?([wbt][bt]|d)|mls|smlsl?[ds]|smc|svc|sev|mia([bt]{2}|ph)?|mrr?c2?|mcrr2?|mrs|msr|orr|orn|pkh(tb|bt)|rbit|rev(16|sh)?|sel|[su]sat(16)?|nop|pop|push|rfe([id][ab])?|stm([id][ab])?|str(ex)?[bhd]?|(qd?)?sub|(sh?|q|u[qh]?)?sub(8|16)|[su]xt(a?h|a?b(16)?)|srs([id][ab])?|swpb?|swi|smi|tst|teq|wfe|wfi|yield)(eq|ne|cs|cc|mi|pl|vs|vc|hi|ls|ge|lt|gt|le|al|hs|lo)?[sptrx]?(?=\\s)"
+},e,s.QUOTE_STRING_MODE,{className:"string",begin:"'",end:"[^\\\\]'",relevance:0
+},{className:"title",begin:"\\|",end:"\\|",illegal:"\\n",relevance:0},{
+className:"number",variants:[{begin:"[#$=]?0x[0-9a-f]+"},{begin:"[#$=]?0b[01]+"
+},{begin:"[#$=]\\d+"},{begin:"\\b\\d+"}],relevance:0},{className:"symbol",
+variants:[{begin:"^[ \\t]*[a-z_\\.\\$][a-z0-9_\\.\\$]+:"},{
+begin:"^[a-z_\\.\\$][a-z0-9_\\.\\$]+"},{begin:"[=#]\\w+"}],relevance:0}]}}})());hljs.registerLanguage("swift",(()=>{"use strict";return e=>{var i={
+$pattern:/[\w#]+/,
+keyword:"#available #colorLiteral #column #else #elseif #endif #file #fileLiteral #function #if #imageLiteral #line #selector #sourceLocation _ __COLUMN__ __FILE__ __FUNCTION__ __LINE__ Any as as! as? associatedtype associativity break case catch class continue convenience default defer deinit didSet do dynamic dynamicType else enum extension fallthrough false fileprivate final for func get guard if import in indirect infix init inout internal is lazy left let mutating nil none nonmutating open operator optional override postfix precedence prefix private protocol Protocol public repeat required rethrows return right self Self set some static struct subscript super switch throw throws true try try! try? Type typealias unowned var weak where while willSet",
+literal:"true false nil",
+built_in:"abs advance alignof alignofValue anyGenerator assert assertionFailure bridgeFromObjectiveC bridgeFromObjectiveCUnconditional bridgeToObjectiveC bridgeToObjectiveCUnconditional c compactMap contains count countElements countLeadingZeros debugPrint debugPrintln distance dropFirst dropLast dump encodeBitsAsWords enumerate equal fatalError filter find getBridgedObjectiveCType getVaList indices insertionSort isBridgedToObjectiveC isBridgedVerbatimToObjectiveC isUniquelyReferenced isUniquelyReferencedNonObjC join lazy lexicographicalCompare map max maxElement min minElement numericCast overlaps partition posix precondition preconditionFailure print println quickSort readLine reduce reflect reinterpretCast reverse roundUpToAlignment sizeof sizeofValue sort split startsWith stride strideof strideofValue swap toString transcode underestimateCount unsafeAddressOf unsafeBitCast unsafeDowncast unsafeUnwrap unsafeReflect withExtendedLifetime withObjectAtPlusZero withUnsafePointer withUnsafePointerToObject withUnsafeMutablePointer withUnsafeMutablePointers withUnsafePointer withUnsafePointers withVaList zip"
+},n=e.COMMENT("/\\*","\\*/",{contains:["self"]}),t={className:"subst",
+begin:/\\\(/,end:"\\)",keywords:i,contains:[]},a={className:"string",
+contains:[e.BACKSLASH_ESCAPE,t],variants:[{begin:/"""/,end:/"""/},{begin:/"/,
+end:/"/}]},r="([0-9a-fA-F]_*)+",s={className:"number",relevance:0,variants:[{
+begin:"\\b(([0-9]_*)+)(\\.(([0-9]_*)+))?([eE][+-]?(([0-9]_*)+))?\\b"},{
+begin:`\\b0x(${r})(\\.(${r}))?([pP][+-]?(([0-9]_*)+))?\\b`},{
+begin:/\b0o([0-7]_*)+\b/},{begin:/\b0b([01]_*)+\b/}]};return t.contains=[s],{
+name:"Swift",keywords:i,contains:[a,e.C_LINE_COMMENT_MODE,n,{className:"type",
+begin:"\\b[A-Z][\\w\xc0-\u02b8']*[!?]"},{className:"type",
+begin:"\\b[A-Z][\\w\xc0-\u02b8']*",relevance:0},s,{className:"function",
+beginKeywords:"func",end:/\{/,excludeEnd:!0,contains:[e.inherit(e.TITLE_MODE,{
+begin:/[A-Za-z$_][0-9A-Za-z$_]*/}),{begin:/</,end:/>/},{className:"params",
+begin:/\(/,end:/\)/,endsParent:!0,keywords:i,
+contains:["self",s,a,e.C_BLOCK_COMMENT_MODE,{begin:":"}],illegal:/["']/}],
+illegal:/\[|%/},{className:"class",
+beginKeywords:"struct protocol class extension enum",keywords:i,end:"\\{",
+excludeEnd:!0,contains:[e.inherit(e.TITLE_MODE,{
+begin:/[A-Za-z$_][\u00C0-\u02B80-9A-Za-z$_]*/})]},{className:"meta",
+begin:"(@discardableResult|@warn_unused_result|@exported|@lazy|@noescape|@NSCopying|@NSManaged|@objc|@objcMembers|@convention|@required|@noreturn|@IBAction|@IBDesignable|@IBInspectable|@IBOutlet|@infix|@prefix|@postfix|@autoclosure|@testable|@available|@nonobjc|@NSApplicationMain|@UIApplicationMain|@dynamicMemberLookup|@propertyWrapper|@main)\\b"
+},{beginKeywords:"import",end:/$/,contains:[e.C_LINE_COMMENT_MODE,n],relevance:0
+}]}}})());hljs.registerLanguage("apache",(()=>{"use strict";return e=>{const n={
+className:"number",begin:"\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}(:\\d{1,5})?"
+};return{name:"Apache config",aliases:["apacheconf"],case_insensitive:!0,
+contains:[e.HASH_COMMENT_MODE,{className:"section",begin:"</?",end:">",
+contains:[n,{className:"number",begin:":\\d{1,5}"
+},e.inherit(e.QUOTE_STRING_MODE,{relevance:0})]},{className:"attribute",
+begin:/\w+/,relevance:0,keywords:{
+nomarkup:"order deny allow setenv rewriterule rewriteengine rewritecond documentroot sethandler errordocument loadmodule options header listen serverroot servername"
+},starts:{end:/$/,relevance:0,keywords:{literal:"on off all deny allow"},
+contains:[{className:"meta",begin:"\\s\\[",end:"\\]$"},{className:"variable",
+begin:"[\\$%]\\{",end:"\\}",contains:["self",{className:"number",
+begin:"[\\$%]\\d+"}]},n,{className:"number",begin:"\\d+"},e.QUOTE_STRING_MODE]}
+}],illegal:/\S/}}})());hljs.registerLanguage("scilab",(()=>{"use strict";return e=>{
+const n=[e.C_NUMBER_MODE,{className:"string",begin:"'|\"",end:"'|\"",
+contains:[e.BACKSLASH_ESCAPE,{begin:"''"}]}];return{name:"Scilab",
+aliases:["sci"],keywords:{$pattern:/%?\w+/,
+keyword:"abort break case clear catch continue do elseif else endfunction end for function global if pause return resume select try then while",
+literal:"%f %F %t %T %pi %eps %inf %nan %e %i %z %s",
+built_in:"abs and acos asin atan ceil cd chdir clearglobal cosh cos cumprod deff disp error exec execstr exists exp eye gettext floor fprintf fread fsolve imag isdef isempty isinfisnan isvector lasterror length load linspace list listfiles log10 log2 log max min msprintf mclose mopen ones or pathconvert poly printf prod pwd rand real round sinh sin size gsort sprintf sqrt strcat strcmps tring sum system tanh tan type typename warning zeros matrix"
+},illegal:'("|#|/\\*|\\s+/\\w+)',contains:[{className:"function",
+beginKeywords:"function",end:"$",contains:[e.UNDERSCORE_TITLE_MODE,{
+className:"params",begin:"\\(",end:"\\)"}]},{
+begin:"[a-zA-Z_][a-zA-Z_0-9]*('+[\\.']*|[\\.']+)",end:"",relevance:0},{
+begin:"\\[",end:"\\]'*[\\.']*",relevance:0,contains:n
+},e.COMMENT("//","$")].concat(n)}}})());hljs.registerLanguage("php",(()=>{"use strict";return e=>{const r={
+className:"variable",
+begin:"\\$+[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*(?![A-Za-z0-9])(?![$])"},t={
+className:"meta",variants:[{begin:/<\?php/,relevance:10},{begin:/<\?[=]?/},{
+begin:/\?>/}]},a={className:"subst",variants:[{begin:/\$\w+/},{begin:/\{\$/,
+end:/\}/}]},n=e.inherit(e.APOS_STRING_MODE,{illegal:null
+}),i=e.inherit(e.QUOTE_STRING_MODE,{illegal:null,
+contains:e.QUOTE_STRING_MODE.contains.concat(a)}),o=e.END_SAME_AS_BEGIN({
+begin:/<<<[ \t]*(\w+)\n/,end:/[ \t]*(\w+)\b/,
+contains:e.QUOTE_STRING_MODE.contains.concat(a)}),l={className:"string",
+contains:[e.BACKSLASH_ESCAPE,t],variants:[e.inherit(n,{begin:"b'",end:"'"
+}),e.inherit(i,{begin:'b"',end:'"'}),i,n,o]},c={
+variants:[e.BINARY_NUMBER_MODE,e.C_NUMBER_MODE]},s={
+keyword:"__CLASS__ __DIR__ __FILE__ __FUNCTION__ __LINE__ __METHOD__ __NAMESPACE__ __TRAIT__ die echo exit include include_once print require require_once array abstract and as binary bool boolean break callable case catch class clone const continue declare default do double else elseif empty enddeclare endfor endforeach endif endswitch endwhile eval extends final finally float for foreach from global goto if implements instanceof insteadof int integer interface isset iterable list match|0 new object or private protected public real return string switch throw trait try unset use var void while xor yield",
+literal:"false null true",
+built_in:"Error|0 AppendIterator ArgumentCountError ArithmeticError ArrayIterator ArrayObject AssertionError BadFunctionCallException BadMethodCallException CachingIterator CallbackFilterIterator CompileError Countable DirectoryIterator DivisionByZeroError DomainException EmptyIterator ErrorException Exception FilesystemIterator FilterIterator GlobIterator InfiniteIterator InvalidArgumentException IteratorIterator LengthException LimitIterator LogicException MultipleIterator NoRewindIterator OutOfBoundsException OutOfRangeException OuterIterator OverflowException ParentIterator ParseError RangeException RecursiveArrayIterator RecursiveCachingIterator RecursiveCallbackFilterIterator RecursiveDirectoryIterator RecursiveFilterIterator RecursiveIterator RecursiveIteratorIterator RecursiveRegexIterator RecursiveTreeIterator RegexIterator RuntimeException SeekableIterator SplDoublyLinkedList SplFileInfo SplFileObject SplFixedArray SplHeap SplMaxHeap SplMinHeap SplObjectStorage SplObserver SplObserver SplPriorityQueue SplQueue SplStack SplSubject SplSubject SplTempFileObject TypeError UnderflowException UnexpectedValueException ArrayAccess Closure Generator Iterator IteratorAggregate Serializable Throwable Traversable WeakReference Directory __PHP_Incomplete_Class parent php_user_filter self static stdClass"
+};return{aliases:["php","php3","php4","php5","php6","php7","php8"],
+case_insensitive:!0,keywords:s,
+contains:[e.HASH_COMMENT_MODE,e.COMMENT("//","$",{contains:[t]
+}),e.COMMENT("/\\*","\\*/",{contains:[{className:"doctag",begin:"@[A-Za-z]+"}]
+}),e.COMMENT("__halt_compiler.+?;",!1,{endsWithParent:!0,
+keywords:"__halt_compiler"}),t,{className:"keyword",begin:/\$this\b/},r,{
+begin:/(::|->)+[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*/},{className:"function",
+relevance:0,beginKeywords:"fn function",end:/[;{]/,excludeEnd:!0,
+illegal:"[$%\\[]",contains:[e.UNDERSCORE_TITLE_MODE,{begin:"=>"},{
+className:"params",begin:"\\(",end:"\\)",excludeBegin:!0,excludeEnd:!0,
+keywords:s,contains:["self",r,e.C_BLOCK_COMMENT_MODE,l,c]}]},{className:"class",
+beginKeywords:"class interface",relevance:0,end:/\{/,excludeEnd:!0,
+illegal:/[:($"]/,contains:[{beginKeywords:"extends implements"
+},e.UNDERSCORE_TITLE_MODE]},{beginKeywords:"namespace",relevance:0,end:";",
+illegal:/[.']/,contains:[e.UNDERSCORE_TITLE_MODE]},{beginKeywords:"use",
+relevance:0,end:";",contains:[e.UNDERSCORE_TITLE_MODE]},l,c]}}})());hljs.registerLanguage("mipsasm",(()=>{"use strict";return e=>({
+name:"MIPS Assembly",case_insensitive:!0,aliases:["mips"],keywords:{
+$pattern:"\\.?"+e.IDENT_RE,
+meta:".2byte .4byte .align .ascii .asciz .balign .byte .code .data .else .end .endif .endm .endr .equ .err .exitm .extern .global .hword .if .ifdef .ifndef .include .irp .long .macro .rept .req .section .set .skip .space .text .word .ltorg ",
+built_in:"$0 $1 $2 $3 $4 $5 $6 $7 $8 $9 $10 $11 $12 $13 $14 $15 $16 $17 $18 $19 $20 $21 $22 $23 $24 $25 $26 $27 $28 $29 $30 $31 zero at v0 v1 a0 a1 a2 a3 a4 a5 a6 a7 t0 t1 t2 t3 t4 t5 t6 t7 t8 t9 s0 s1 s2 s3 s4 s5 s6 s7 s8 k0 k1 gp sp fp ra $f0 $f1 $f2 $f2 $f4 $f5 $f6 $f7 $f8 $f9 $f10 $f11 $f12 $f13 $f14 $f15 $f16 $f17 $f18 $f19 $f20 $f21 $f22 $f23 $f24 $f25 $f26 $f27 $f28 $f29 $f30 $f31 Context Random EntryLo0 EntryLo1 Context PageMask Wired EntryHi HWREna BadVAddr Count Compare SR IntCtl SRSCtl SRSMap Cause EPC PRId EBase Config Config1 Config2 Config3 LLAddr Debug DEPC DESAVE CacheErr ECC ErrorEPC TagLo DataLo TagHi DataHi WatchLo WatchHi PerfCtl PerfCnt "
+},contains:[{className:"keyword",
+begin:"\\b(addi?u?|andi?|b(al)?|beql?|bgez(al)?l?|bgtzl?|blezl?|bltz(al)?l?|bnel?|cl[oz]|divu?|ext|ins|j(al)?|jalr(\\.hb)?|jr(\\.hb)?|lbu?|lhu?|ll|lui|lw[lr]?|maddu?|mfhi|mflo|movn|movz|move|msubu?|mthi|mtlo|mul|multu?|nop|nor|ori?|rotrv?|sb|sc|se[bh]|sh|sllv?|slti?u?|srav?|srlv?|subu?|sw[lr]?|xori?|wsbh|abs\\.[sd]|add\\.[sd]|alnv.ps|bc1[ft]l?|c\\.(s?f|un|u?eq|[ou]lt|[ou]le|ngle?|seq|l[et]|ng[et])\\.[sd]|(ceil|floor|round|trunc)\\.[lw]\\.[sd]|cfc1|cvt\\.d\\.[lsw]|cvt\\.l\\.[dsw]|cvt\\.ps\\.s|cvt\\.s\\.[dlw]|cvt\\.s\\.p[lu]|cvt\\.w\\.[dls]|div\\.[ds]|ldx?c1|luxc1|lwx?c1|madd\\.[sd]|mfc1|mov[fntz]?\\.[ds]|msub\\.[sd]|mth?c1|mul\\.[ds]|neg\\.[ds]|nmadd\\.[ds]|nmsub\\.[ds]|p[lu][lu]\\.ps|recip\\.fmt|r?sqrt\\.[ds]|sdx?c1|sub\\.[ds]|suxc1|swx?c1|break|cache|d?eret|[de]i|ehb|mfc0|mtc0|pause|prefx?|rdhwr|rdpgpr|sdbbp|ssnop|synci?|syscall|teqi?|tgei?u?|tlb(p|r|w[ir])|tlti?u?|tnei?|wait|wrpgpr)",
+end:"\\s"
+},e.COMMENT("[;#](?!\\s*$)","$"),e.C_BLOCK_COMMENT_MODE,e.QUOTE_STRING_MODE,{
+className:"string",begin:"'",end:"[^\\\\]'",relevance:0},{className:"title",
+begin:"\\|",end:"\\|",illegal:"\\n",relevance:0},{className:"number",variants:[{
+begin:"0x[0-9a-f]+"},{begin:"\\b-?\\d+"}],relevance:0},{className:"symbol",
+variants:[{begin:"^\\s*[a-z_\\.\\$][a-z0-9_\\.\\$]+:"},{begin:"^\\s*[0-9]+:"},{
+begin:"[0-9]+[bf]"}],relevance:0}],illegal:/\//})})());hljs.registerLanguage("json",(()=>{"use strict";return n=>{const e={
+literal:"true false null"
+},i=[n.C_LINE_COMMENT_MODE,n.C_BLOCK_COMMENT_MODE],a=[n.QUOTE_STRING_MODE,n.C_NUMBER_MODE],l={
+end:",",endsWithParent:!0,excludeEnd:!0,contains:a,keywords:e},t={begin:/\{/,
+end:/\}/,contains:[{className:"attr",begin:/"/,end:/"/,
+contains:[n.BACKSLASH_ESCAPE],illegal:"\\n"},n.inherit(l,{begin:/:/
+})].concat(i),illegal:"\\S"},s={begin:"\\[",end:"\\]",contains:[n.inherit(l)],
+illegal:"\\S"};return a.push(t,s),i.forEach((n=>{a.push(n)})),{name:"JSON",
+contains:a,keywords:e,illegal:"\\S"}}})());hljs.registerLanguage("lisp",(()=>{"use strict";return e=>{
+var n="[a-zA-Z_\\-+\\*\\/<=>&#][a-zA-Z0-9_\\-+*\\/<=>&#!]*",a="\\|[^]*?\\|",i="(-|\\+)?\\d+(\\.\\d+|\\/\\d+)?((d|e|f|l|s|D|E|F|L|S)(\\+|-)?\\d+)?",s={
+className:"literal",begin:"\\b(t{1}|nil)\\b"},l={className:"number",variants:[{
+begin:i,relevance:0},{begin:"#(b|B)[0-1]+(/[0-1]+)?"},{
+begin:"#(o|O)[0-7]+(/[0-7]+)?"},{begin:"#(x|X)[0-9a-fA-F]+(/[0-9a-fA-F]+)?"},{
+begin:"#(c|C)\\("+i+" +"+i,end:"\\)"}]},b=e.inherit(e.QUOTE_STRING_MODE,{
+illegal:null}),g=e.COMMENT(";","$",{relevance:0}),r={begin:"\\*",end:"\\*"},t={
+className:"symbol",begin:"[:&]"+n},c={begin:n,relevance:0},d={begin:a},o={
+contains:[l,b,r,t,{begin:"\\(",end:"\\)",contains:["self",s,b,l,c]},c],
+variants:[{begin:"['`]\\(",end:"\\)"},{begin:"\\(quote ",end:"\\)",keywords:{
+name:"quote"}},{begin:"'"+a}]},v={variants:[{begin:"'"+n},{
+begin:"#'"+n+"(::"+n+")*"}]},m={begin:"\\(\\s*",end:"\\)"},u={endsWithParent:!0,
+relevance:0};return m.contains=[{className:"name",variants:[{begin:n,relevance:0
+},{begin:a}]},u],u.contains=[o,v,m,s,l,b,g,r,t,d,c],{name:"Lisp",illegal:/\S/,
+contains:[l,e.SHEBANG(),s,b,g,o,v,m,c]}}})());hljs.registerLanguage("dts",(()=>{"use strict";return e=>{const n={
+className:"string",variants:[e.inherit(e.QUOTE_STRING_MODE,{
+begin:'((u8?|U)|L)?"'}),{begin:'(u8?|U)?R"',end:'"',
+contains:[e.BACKSLASH_ESCAPE]},{begin:"'\\\\?.",end:"'",illegal:"."}]},a={
+className:"number",variants:[{
+begin:"\\b(\\d+(\\.\\d*)?|\\.\\d+)(u|U|l|L|ul|UL|f|F)"},{begin:e.C_NUMBER_RE}],
+relevance:0},s={className:"meta",begin:"#",end:"$",keywords:{
+"meta-keyword":"if else elif endif define undef ifdef ifndef"},contains:[{
+begin:/\\\n/,relevance:0},{beginKeywords:"include",end:"$",keywords:{
+"meta-keyword":"include"},contains:[e.inherit(n,{className:"meta-string"}),{
+className:"meta-string",begin:"<",end:">",illegal:"\\n"}]
+},n,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},i={className:"variable",
+begin:/&[a-z\d_]*\b/},d={className:"meta-keyword",begin:"/[a-z][a-z\\d-]*/"},l={
+className:"symbol",begin:"^\\s*[a-zA-Z_][a-zA-Z\\d_]*:"},r={className:"params",
+begin:"<",end:">",contains:[a,i]},_={className:"class",
+begin:/[a-zA-Z_][a-zA-Z\d_@]*\s\{/,end:/[{;=]/,returnBegin:!0,excludeEnd:!0}
+;return{name:"Device Tree",keywords:"",contains:[{className:"class",
+begin:"/\\s*\\{",end:/\};/,relevance:10,
+contains:[i,d,l,_,r,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,a,n]
+},i,d,l,_,r,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,a,n,s,{
+begin:e.IDENT_RE+"::",keywords:""}]}}})());hljs.registerLanguage("lua",(()=>{"use strict";return e=>{
+const t="\\[=*\\[",a="\\]=*\\]",n={begin:t,end:a,contains:["self"]
+},o=[e.COMMENT("--(?!\\[=*\\[)","$"),e.COMMENT("--\\[=*\\[",a,{contains:[n],
+relevance:10})];return{name:"Lua",keywords:{$pattern:e.UNDERSCORE_IDENT_RE,
+literal:"true false nil",
+keyword:"and break do else elseif end for goto if in local not or repeat return then until while",
+built_in:"_G _ENV _VERSION __index __newindex __mode __call __metatable __tostring __len __gc __add __sub __mul __div __mod __pow __concat __unm __eq __lt __le assert collectgarbage dofile error getfenv getmetatable ipairs load loadfile loadstring module next pairs pcall print rawequal rawget rawset require select setfenv setmetatable tonumber tostring type unpack xpcall arg self coroutine resume yield status wrap create running debug getupvalue debug sethook getmetatable gethook setmetatable setlocal traceback setfenv getinfo setupvalue getlocal getregistry getfenv io lines write close flush open output type read stderr stdin input stdout popen tmpfile math log max acos huge ldexp pi cos tanh pow deg tan cosh sinh random randomseed frexp ceil floor rad abs sqrt modf asin min mod fmod log10 atan2 exp sin atan os exit setlocale date getenv difftime remove time clock tmpname rename execute package preload loadlib loaded loaders cpath config path seeall string sub upper len gfind rep find match char dump gmatch reverse byte format gsub lower table setn insert getn foreachi maxn foreach concat sort remove"
+},contains:o.concat([{className:"function",beginKeywords:"function",end:"\\)",
+contains:[e.inherit(e.TITLE_MODE,{
+begin:"([_a-zA-Z]\\w*\\.)*([_a-zA-Z]\\w*:)?[_a-zA-Z]\\w*"}),{className:"params",
+begin:"\\(",endsWithParent:!0,contains:o}].concat(o)
+},e.C_NUMBER_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{className:"string",
+begin:t,end:a,contains:[n],relevance:5}])}}})());hljs.registerLanguage("scala",(()=>{"use strict";return e=>{const n={
+className:"subst",variants:[{begin:"\\$[A-Za-z0-9_]+"},{begin:/\$\{/,end:/\}/}]
+},a={className:"string",variants:[{begin:'"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]},{begin:'"""',end:'"""',relevance:10},{
+begin:'[a-z]+"',end:'"',illegal:"\\n",contains:[e.BACKSLASH_ESCAPE,n]},{
+className:"string",begin:'[a-z]+"""',end:'"""',contains:[n],relevance:10}]},s={
+className:"type",begin:"\\b[A-Z][A-Za-z0-9_]*",relevance:0},t={
+className:"title",
+begin:/[^0-9\n\t "'(),.`{}\[\]:;][^\n\t "'(),.`{}\[\]:;]+|[^0-9\n\t "'(),.`{}\[\]:;=]/,
+relevance:0},i={className:"class",beginKeywords:"class object trait type",
+end:/[:={\[\n;]/,excludeEnd:!0,
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{
+beginKeywords:"extends with",relevance:10},{begin:/\[/,end:/\]/,excludeBegin:!0,
+excludeEnd:!0,relevance:0,contains:[s]},{className:"params",begin:/\(/,end:/\)/,
+excludeBegin:!0,excludeEnd:!0,relevance:0,contains:[s]},t]},l={
+className:"function",beginKeywords:"def",end:/[:={\[(\n;]/,excludeEnd:!0,
+contains:[t]};return{name:"Scala",keywords:{literal:"true false null",
+keyword:"type yield lazy override def with val var sealed abstract private trait object if forSome for while throw finally protected extends import final return else break new catch super class case package default try this match continue throws implicit"
+},contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,a,{className:"symbol",
+begin:"'\\w[\\w\\d_]*(?!')"},s,l,i,e.C_NUMBER_MODE,{className:"meta",
+begin:"@[A-Za-z]+"}]}}})());hljs.registerLanguage("vala",(()=>{"use strict";return e=>({name:"Vala",
+keywords:{
+keyword:"char uchar unichar int uint long ulong short ushort int8 int16 int32 int64 uint8 uint16 uint32 uint64 float double bool struct enum string void weak unowned owned async signal static abstract interface override virtual delegate if while do for foreach else switch case break default return try catch public private protected internal using new this get set const stdout stdin stderr var",
+built_in:"DBus GLib CCode Gee Object Gtk Posix",literal:"false true null"},
+contains:[{className:"class",beginKeywords:"class interface namespace",end:/\{/,
+excludeEnd:!0,illegal:"[^,:\\n\\s\\.]",contains:[e.UNDERSCORE_TITLE_MODE]
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{className:"string",begin:'"""',
+end:'"""',relevance:5},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.C_NUMBER_MODE,{
+className:"meta",begin:"^#",end:"$",relevance:2}]})})());hljs.registerLanguage("rust",(()=>{"use strict";return e=>{
+const n="([ui](8|16|32|64|128|size)|f(32|64))?",t="drop i8 i16 i32 i64 i128 isize u8 u16 u32 u64 u128 usize f32 f64 str char bool Box Option Result String Vec Copy Send Sized Sync Drop Fn FnMut FnOnce ToOwned Clone Debug PartialEq PartialOrd Eq Ord AsRef AsMut Into From Default Iterator Extend IntoIterator DoubleEndedIterator ExactSizeIterator SliceConcatExt ToString assert! assert_eq! bitflags! bytes! cfg! col! concat! concat_idents! debug_assert! debug_assert_eq! env! panic! file! format! format_args! include_bin! include_str! line! local_data_key! module_path! option_env! print! println! select! stringify! try! unimplemented! unreachable! vec! write! writeln! macro_rules! assert_ne! debug_assert_ne!"
+;return{name:"Rust",aliases:["rs"],keywords:{$pattern:e.IDENT_RE+"!?",
+keyword:"abstract as async await become box break const continue crate do dyn else enum extern false final fn for if impl in let loop macro match mod move mut override priv pub ref return self Self static struct super trait true try type typeof unsafe unsized use virtual where while yield",
+literal:"true false Some None Ok Err",built_in:t},illegal:"</",
+contains:[e.C_LINE_COMMENT_MODE,e.COMMENT("/\\*","\\*/",{contains:["self"]
+}),e.inherit(e.QUOTE_STRING_MODE,{begin:/b?"/,illegal:null}),{
+className:"string",variants:[{begin:/r(#*)"(.|\n)*?"\1(?!#)/},{
+begin:/b?'\\?(x\w{2}|u\w{4}|U\w{8}|.)'/}]},{className:"symbol",
+begin:/'[a-zA-Z_][a-zA-Z0-9_]*/},{className:"number",variants:[{
+begin:"\\b0b([01_]+)"+n},{begin:"\\b0o([0-7_]+)"+n},{
+begin:"\\b0x([A-Fa-f0-9_]+)"+n},{
+begin:"\\b(\\d[\\d_]*(\\.[0-9_]+)?([eE][+-]?[0-9_]+)?)"+n}],relevance:0},{
+className:"function",beginKeywords:"fn",end:"(\\(|<)",excludeEnd:!0,
+contains:[e.UNDERSCORE_TITLE_MODE]},{className:"meta",begin:"#!?\\[",end:"\\]",
+contains:[{className:"meta-string",begin:/"/,end:/"/}]},{className:"class",
+beginKeywords:"type",end:";",contains:[e.inherit(e.UNDERSCORE_TITLE_MODE,{
+endsParent:!0})],illegal:"\\S"},{className:"class",
+beginKeywords:"trait enum struct union",end:/\{/,
+contains:[e.inherit(e.UNDERSCORE_TITLE_MODE,{endsParent:!0})],illegal:"[\\w\\d]"
+},{begin:e.IDENT_RE+"::",keywords:{built_in:t}},{begin:"->"}]}}})());hljs.registerLanguage("python",(()=>{"use strict";return e=>{const n={
+keyword:"and as assert async await break class continue def del elif else except finally for  from global if import in is lambda nonlocal|10 not or pass raise return try while with yield",
+built_in:"__import__ abs all any ascii bin bool breakpoint bytearray bytes callable chr classmethod compile complex delattr dict dir divmod enumerate eval exec filter float format frozenset getattr globals hasattr hash help hex id input int isinstance issubclass iter len list locals map max memoryview min next object oct open ord pow print property range repr reversed round set setattr slice sorted staticmethod str sum super tuple type vars zip",
+literal:"__debug__ Ellipsis False None NotImplemented True"},a={
+className:"meta",begin:/^(>>>|\.\.\.) /},s={className:"subst",begin:/\{/,
+end:/\}/,keywords:n,illegal:/#/},i={begin:/\{\{/,relevance:0},r={
+className:"string",contains:[e.BACKSLASH_ESCAPE],variants:[{
+begin:/([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?'''/,end:/'''/,
+contains:[e.BACKSLASH_ESCAPE,a],relevance:10},{
+begin:/([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?"""/,end:/"""/,
+contains:[e.BACKSLASH_ESCAPE,a],relevance:10},{
+begin:/([fF][rR]|[rR][fF]|[fF])'''/,end:/'''/,
+contains:[e.BACKSLASH_ESCAPE,a,i,s]},{begin:/([fF][rR]|[rR][fF]|[fF])"""/,
+end:/"""/,contains:[e.BACKSLASH_ESCAPE,a,i,s]},{begin:/([uU]|[rR])'/,end:/'/,
+relevance:10},{begin:/([uU]|[rR])"/,end:/"/,relevance:10},{
+begin:/([bB]|[bB][rR]|[rR][bB])'/,end:/'/},{begin:/([bB]|[bB][rR]|[rR][bB])"/,
+end:/"/},{begin:/([fF][rR]|[rR][fF]|[fF])'/,end:/'/,
+contains:[e.BACKSLASH_ESCAPE,i,s]},{begin:/([fF][rR]|[rR][fF]|[fF])"/,end:/"/,
+contains:[e.BACKSLASH_ESCAPE,i,s]},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]
+},t="[0-9](_?[0-9])*",l=`(\\b(${t}))?\\.(${t})|\\b(${t})\\.`,b={
+className:"number",relevance:0,variants:[{
+begin:`(\\b(${t})|(${l}))[eE][+-]?(${t})[jJ]?\\b`},{begin:`(${l})[jJ]?`},{
+begin:"\\b([1-9](_?[0-9])*|0+(_?0)*)[lLjJ]?\\b"},{
+begin:"\\b0[bB](_?[01])+[lL]?\\b"},{begin:"\\b0[oO](_?[0-7])+[lL]?\\b"},{
+begin:"\\b0[xX](_?[0-9a-fA-F])+[lL]?\\b"},{begin:`\\b(${t})[jJ]\\b`}]},o={
+className:"params",variants:[{begin:/\(\s*\)/,skip:!0,className:null},{
+begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:n,
+contains:["self",a,b,r,e.HASH_COMMENT_MODE]}]};return s.contains=[r,b,a],{
+name:"Python",aliases:["py","gyp","ipython"],keywords:n,
+illegal:/(<\/|->|\?)|=>/,contains:[a,b,{begin:/\bself\b/},{beginKeywords:"if",
+relevance:0},r,e.HASH_COMMENT_MODE,{variants:[{className:"function",
+beginKeywords:"def"},{className:"class",beginKeywords:"class"}],end:/:/,
+illegal:/[${=;\n,]/,contains:[e.UNDERSCORE_TITLE_MODE,o,{begin:/->/,
+endsWithParent:!0,keywords:"None"}]},{className:"meta",begin:/^[\t ]*@/,
+end:/(?=#)|$/,contains:[b,o,r]},{begin:/\b(print|exec)\(/}]}}})());hljs.registerLanguage("python-repl",(()=>{"use strict";return s=>({
+aliases:["pycon"],contains:[{className:"meta",starts:{end:/ |$/,starts:{end:"$",
+subLanguage:"python"}},variants:[{begin:/^>>>(?=[ ]|$)/},{
+begin:/^\.\.\.(?=[ ]|$)/}]}]})})());hljs.registerLanguage("ruby",(()=>{"use strict";function e(...e){
+return e.map((e=>{return(n=e)?"string"==typeof n?n:n.source:null;var n
+})).join("")}return n=>{
+var a,i="([a-zA-Z_]\\w*[!?=]?|[-+~]@|<<|>>|=~|===?|<=>|[<>]=?|\\*\\*|[-/+%^&*~`|]|\\[\\]=?)",s={
+keyword:"and then defined module in return redo if BEGIN retry end for self when next until do begin unless END rescue else break undef not super class case require yield alias while ensure elsif or include attr_reader attr_writer attr_accessor __FILE__",
+built_in:"proc lambda",literal:"true false nil"},r={className:"doctag",
+begin:"@[A-Za-z]+"},b={begin:"#<",end:">"},t=[n.COMMENT("#","$",{contains:[r]
+}),n.COMMENT("^=begin","^=end",{contains:[r],relevance:10
+}),n.COMMENT("^__END__","\\n$")],c={className:"subst",begin:/#\{/,end:/\}/,
+keywords:s},d={className:"string",contains:[n.BACKSLASH_ESCAPE,c],variants:[{
+begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/`/,end:/`/},{begin:/%[qQwWx]?\(/,
+end:/\)/},{begin:/%[qQwWx]?\[/,end:/\]/},{begin:/%[qQwWx]?\{/,end:/\}/},{
+begin:/%[qQwWx]?</,end:/>/},{begin:/%[qQwWx]?\//,end:/\//},{begin:/%[qQwWx]?%/,
+end:/%/},{begin:/%[qQwWx]?-/,end:/-/},{begin:/%[qQwWx]?\|/,end:/\|/},{
+begin:/\B\?(\\\d{1,3}|\\x[A-Fa-f0-9]{1,2}|\\u[A-Fa-f0-9]{4}|\\?\S)\b/},{
+begin:/<<[-~]?'?(\w+)(?:.|\n)*?\n\s*\1\b/,returnBegin:!0,contains:[{
+begin:/<<[-~]?'?/},n.END_SAME_AS_BEGIN({begin:/(\w+)/,end:/(\w+)/,
+contains:[n.BACKSLASH_ESCAPE,c]})]}]},g="[0-9](_?[0-9])*",l={className:"number",
+relevance:0,variants:[{
+begin:`\\b([1-9](_?[0-9])*|0)(\\.(${g}))?([eE][+-]?(${g})|r)?i?\\b`},{
+begin:"\\b0[dD][0-9](_?[0-9])*r?i?\\b"},{begin:"\\b0[bB][0-1](_?[0-1])*r?i?\\b"
+},{begin:"\\b0[oO][0-7](_?[0-7])*r?i?\\b"},{
+begin:"\\b0[xX][0-9a-fA-F](_?[0-9a-fA-F])*r?i?\\b"},{
+begin:"\\b0(_?[0-7])+r?i?\\b"}]},o={className:"params",begin:"\\(",end:"\\)",
+endsParent:!0,keywords:s},_=[d,{className:"class",beginKeywords:"class module",
+end:"$|;",illegal:/=/,contains:[n.inherit(n.TITLE_MODE,{
+begin:"[A-Za-z_]\\w*(::\\w+)*(\\?|!)?"}),{begin:"<\\s*",contains:[{
+begin:"("+n.IDENT_RE+"::)?"+n.IDENT_RE}]}].concat(t)},{className:"function",
+begin:e(/def\s*/,(a=i+"\\s*(\\(|;|$)",e("(?=",a,")"))),keywords:"def",end:"$|;",
+contains:[n.inherit(n.TITLE_MODE,{begin:i}),o].concat(t)},{begin:n.IDENT_RE+"::"
+},{className:"symbol",begin:n.UNDERSCORE_IDENT_RE+"(!|\\?)?:",relevance:0},{
+className:"symbol",begin:":(?!\\s)",contains:[d,{begin:i}],relevance:0},l,{
+className:"variable",
+begin:"(\\$\\W)|((\\$|@@?)(\\w+))(?=[^@$?])(?![A-Za-z])(?![@$?'])"},{
+className:"params",begin:/\|/,end:/\|/,relevance:0,keywords:s},{
+begin:"("+n.RE_STARTERS_RE+"|unless)\\s*",keywords:"unless",contains:[{
+className:"regexp",contains:[n.BACKSLASH_ESCAPE,c],illegal:/\n/,variants:[{
+begin:"/",end:"/[a-z]*"},{begin:/%r\{/,end:/\}[a-z]*/},{begin:"%r\\(",
+end:"\\)[a-z]*"},{begin:"%r!",end:"![a-z]*"},{begin:"%r\\[",end:"\\][a-z]*"}]
+}].concat(b,t),relevance:0}].concat(b,t);c.contains=_,o.contains=_;var E=[{
+begin:/^\s*=>/,starts:{end:"$",contains:_}},{className:"meta",
+begin:"^([>?]>|[\\w#]+\\(\\w+\\):\\d+:\\d+>|(\\w+-)?\\d+\\.\\d+\\.\\d(p\\d+)?[^>]+>)(?=[ ])",
+starts:{end:"$",contains:_}}];return t.unshift(b),{name:"Ruby",
+aliases:["rb","gemspec","podspec","thor","irb"],keywords:s,illegal:/\/\*/,
+contains:[n.SHEBANG({binary:"ruby"})].concat(E).concat(t).concat(_)}}})());hljs.registerLanguage("yaml",(()=>{"use strict";return e=>{
+var n="true false yes no null",a="[\\w#;/?:@&=+$,.~*'()[\\]]+",s={
+className:"string",relevance:0,variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/
+},{begin:/\S+/}],contains:[e.BACKSLASH_ESCAPE,{className:"template-variable",
+variants:[{begin:/\{\{/,end:/\}\}/},{begin:/%\{/,end:/\}/}]}]},i=e.inherit(s,{
+variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/[^\s,{}[\]]+/}]}),l={
+end:",",endsWithParent:!0,excludeEnd:!0,contains:[],keywords:n,relevance:0},t={
+begin:/\{/,end:/\}/,contains:[l],illegal:"\\n",relevance:0},g={begin:"\\[",
+end:"\\]",contains:[l],illegal:"\\n",relevance:0},b=[{className:"attr",
+variants:[{begin:"\\w[\\w :\\/.-]*:(?=[ \t]|$)"},{
+begin:'"\\w[\\w :\\/.-]*":(?=[ \t]|$)'},{begin:"'\\w[\\w :\\/.-]*':(?=[ \t]|$)"
+}]},{className:"meta",begin:"^---\\s*$",relevance:10},{className:"string",
+begin:"[\\|>]([1-9]?[+-])?[ ]*\\n( +)[^\\n]+\\n(\\2[^\\n]+\\n?)*"},{
+begin:"<%[%=-]?",end:"[%-]?%>",subLanguage:"ruby",excludeBegin:!0,excludeEnd:!0,
+relevance:0},{className:"type",begin:"!\\w+!"+a},{className:"type",
+begin:"!<"+a+">"},{className:"type",begin:"!"+a},{className:"type",begin:"!!"+a
+},{className:"meta",begin:"&"+e.UNDERSCORE_IDENT_RE+"$"},{className:"meta",
+begin:"\\*"+e.UNDERSCORE_IDENT_RE+"$"},{className:"bullet",begin:"-(?=[ ]|$)",
+relevance:0},e.HASH_COMMENT_MODE,{beginKeywords:n,keywords:{literal:n}},{
+className:"number",
+begin:"\\b[0-9]{4}(-[0-9][0-9]){0,2}([Tt \\t][0-9][0-9]?(:[0-9][0-9]){2})?(\\.[0-9]*)?([ \\t])*(Z|[-+][0-9][0-9]?(:[0-9][0-9])?)?\\b"
+},{className:"number",begin:e.C_NUMBER_RE+"\\b",relevance:0},t,g,s],r=[...b]
+;return r.pop(),r.push(i),l.contains=r,{name:"YAML",case_insensitive:!0,
+aliases:["yml","YAML"],contains:b}}})());hljs.registerLanguage("prolog",(()=>{"use strict";return n=>{const e={
+begin:/\(/,end:/\)/,relevance:0},a={begin:/\[/,end:/\]/},s={className:"comment",
+begin:/%/,end:/$/,contains:[n.PHRASAL_WORDS_MODE]},i={className:"string",
+begin:/`/,end:/`/,contains:[n.BACKSLASH_ESCAPE]},g=[{begin:/[a-z][A-Za-z0-9_]*/,
+relevance:0},{className:"symbol",variants:[{begin:/[A-Z][a-zA-Z0-9_]*/},{
+begin:/_[A-Za-z0-9_]*/}],relevance:0},e,{begin:/:-/
+},a,s,n.C_BLOCK_COMMENT_MODE,n.QUOTE_STRING_MODE,n.APOS_STRING_MODE,i,{
+className:"string",begin:/0'(\\'|.)/},{className:"string",begin:/0'\\s/
+},n.C_NUMBER_MODE];return e.contains=g,a.contains=g,{name:"Prolog",
+contains:g.concat([{begin:/\.$/}])}}})());hljs.registerLanguage("scheme",(()=>{"use strict";return e=>{
+var t="[^\\(\\)\\[\\]\\{\\}\",'`;#|\\\\\\s]+",n={$pattern:t,
+"builtin-name":"case-lambda call/cc class define-class exit-handler field import inherit init-field interface let*-values let-values let/ec mixin opt-lambda override protect provide public rename require require-for-syntax syntax syntax-case syntax-error unit/sig unless when with-syntax and begin call-with-current-continuation call-with-input-file call-with-output-file case cond define define-syntax delay do dynamic-wind else for-each if lambda let let* let-syntax letrec letrec-syntax map or syntax-rules ' * + , ,@ - ... / ; < <= = => > >= ` abs acos angle append apply asin assoc assq assv atan boolean? caar cadr call-with-input-file call-with-output-file call-with-values car cdddar cddddr cdr ceiling char->integer char-alphabetic? char-ci<=? char-ci<? char-ci=? char-ci>=? char-ci>? char-downcase char-lower-case? char-numeric? char-ready? char-upcase char-upper-case? char-whitespace? char<=? char<? char=? char>=? char>? char? close-input-port close-output-port complex? cons cos current-input-port current-output-port denominator display eof-object? eq? equal? eqv? eval even? exact->inexact exact? exp expt floor force gcd imag-part inexact->exact inexact? input-port? integer->char integer? interaction-environment lcm length list list->string list->vector list-ref list-tail list? load log magnitude make-polar make-rectangular make-string make-vector max member memq memv min modulo negative? newline not null-environment null? number->string number? numerator odd? open-input-file open-output-file output-port? pair? peek-char port? positive? procedure? quasiquote quote quotient rational? rationalize read read-char real-part real? remainder reverse round scheme-report-environment set! set-car! set-cdr! sin sqrt string string->list string->number string->symbol string-append string-ci<=? string-ci<? string-ci=? string-ci>=? string-ci>? string-copy string-fill! string-length string-ref string-set! string<=? string<? string=? string>=? string>? string? substring symbol->string symbol? tan transcript-off transcript-on truncate values vector vector->list vector-fill! vector-length vector-ref vector-set! with-input-from-file with-output-to-file write write-char zero?"
+},r={className:"literal",begin:"(#t|#f|#\\\\"+t+"|#\\\\.)"},a={
+className:"number",variants:[{begin:"(-|\\+)?\\d+([./]\\d+)?",relevance:0},{
+begin:"(-|\\+)?\\d+([./]\\d+)?[+\\-](-|\\+)?\\d+([./]\\d+)?i",relevance:0},{
+begin:"#b[0-1]+(/[0-1]+)?"},{begin:"#o[0-7]+(/[0-7]+)?"},{
+begin:"#x[0-9a-f]+(/[0-9a-f]+)?"}]},i=e.QUOTE_STRING_MODE,c=[e.COMMENT(";","$",{
+relevance:0}),e.COMMENT("#\\|","\\|#")],s={begin:t,relevance:0},l={
+className:"symbol",begin:"'"+t},o={endsWithParent:!0,relevance:0},g={variants:[{
+begin:/'/},{begin:"`"}],contains:[{begin:"\\(",end:"\\)",
+contains:["self",r,i,a,s,l]}]},u={className:"name",relevance:0,begin:t,
+keywords:n},d={variants:[{begin:"\\(",end:"\\)"},{begin:"\\[",end:"\\]"}],
+contains:[{begin:/lambda/,endsWithParent:!0,returnBegin:!0,contains:[u,{
+begin:/\(/,end:/\)/,endsParent:!0,contains:[s]}]},u,o]}
+;return o.contains=[r,a,i,s,l,g,d].concat(c),{name:"Scheme",illegal:/\S/,
+contains:[e.SHEBANG(),a,i,l,g,d].concat(c)}}})());hljs.registerLanguage("vim",(()=>{"use strict";return e=>({name:"Vim Script",
+keywords:{$pattern:/[!#@\w]+/,
+keyword:"N|0 P|0 X|0 a|0 ab abc abo al am an|0 ar arga argd arge argdo argg argl argu as au aug aun b|0 bN ba bad bd be bel bf bl bm bn bo bp br brea breaka breakd breakl bro bufdo buffers bun bw c|0 cN cNf ca cabc caddb cad caddf cal cat cb cc ccl cd ce cex cf cfir cgetb cgete cg changes chd che checkt cl cla clo cm cmapc cme cn cnew cnf cno cnorea cnoreme co col colo com comc comp con conf cope cp cpf cq cr cs cst cu cuna cunme cw delm deb debugg delc delf dif diffg diffo diffp diffpu diffs diffthis dig di dl dell dj dli do doautoa dp dr ds dsp e|0 ea ec echoe echoh echom echon el elsei em en endfo endf endt endw ene ex exe exi exu f|0 files filet fin fina fini fir fix fo foldc foldd folddoc foldo for fu go gr grepa gu gv ha helpf helpg helpt hi hid his ia iabc if ij il im imapc ime ino inorea inoreme int is isp iu iuna iunme j|0 ju k|0 keepa kee keepj lN lNf l|0 lad laddb laddf la lan lat lb lc lch lcl lcs le lefta let lex lf lfir lgetb lgete lg lgr lgrepa lh ll lla lli lmak lm lmapc lne lnew lnf ln loadk lo loc lockv lol lope lp lpf lr ls lt lu lua luad luaf lv lvimgrepa lw m|0 ma mak map mapc marks mat me menut mes mk mks mksp mkv mkvie mod mz mzf nbc nb nbs new nm nmapc nme nn nnoreme noa no noh norea noreme norm nu nun nunme ol o|0 om omapc ome on ono onoreme opt ou ounme ow p|0 profd prof pro promptr pc ped pe perld po popu pp pre prev ps pt ptN ptf ptj ptl ptn ptp ptr pts pu pw py3 python3 py3d py3f py pyd pyf quita qa rec red redi redr redraws reg res ret retu rew ri rightb rub rubyd rubyf rund ru rv sN san sa sal sav sb sbN sba sbf sbl sbm sbn sbp sbr scrip scripte scs se setf setg setl sf sfir sh sim sig sil sl sla sm smap smapc sme sn sni sno snor snoreme sor so spelld spe spelli spellr spellu spellw sp spr sre st sta startg startr star stopi stj sts sun sunm sunme sus sv sw sy synti sync tN tabN tabc tabdo tabe tabf tabfir tabl tabm tabnew tabn tabo tabp tabr tabs tab ta tags tc tcld tclf te tf th tj tl tm tn to tp tr try ts tu u|0 undoj undol una unh unl unlo unm unme uns up ve verb vert vim vimgrepa vi viu vie vm vmapc vme vne vn vnoreme vs vu vunme windo w|0 wN wa wh wi winc winp wn wp wq wqa ws wu wv x|0 xa xmapc xm xme xn xnoreme xu xunme y|0 z|0 ~ Next Print append abbreviate abclear aboveleft all amenu anoremenu args argadd argdelete argedit argglobal arglocal argument ascii autocmd augroup aunmenu buffer bNext ball badd bdelete behave belowright bfirst blast bmodified bnext botright bprevious brewind break breakadd breakdel breaklist browse bunload bwipeout change cNext cNfile cabbrev cabclear caddbuffer caddexpr caddfile call catch cbuffer cclose center cexpr cfile cfirst cgetbuffer cgetexpr cgetfile chdir checkpath checktime clist clast close cmap cmapclear cmenu cnext cnewer cnfile cnoremap cnoreabbrev cnoremenu copy colder colorscheme command comclear compiler continue confirm copen cprevious cpfile cquit crewind cscope cstag cunmap cunabbrev cunmenu cwindow delete delmarks debug debuggreedy delcommand delfunction diffupdate diffget diffoff diffpatch diffput diffsplit digraphs display deletel djump dlist doautocmd doautoall deletep drop dsearch dsplit edit earlier echo echoerr echohl echomsg else elseif emenu endif endfor endfunction endtry endwhile enew execute exit exusage file filetype find finally finish first fixdel fold foldclose folddoopen folddoclosed foldopen function global goto grep grepadd gui gvim hardcopy help helpfind helpgrep helptags highlight hide history insert iabbrev iabclear ijump ilist imap imapclear imenu inoremap inoreabbrev inoremenu intro isearch isplit iunmap iunabbrev iunmenu join jumps keepalt keepmarks keepjumps lNext lNfile list laddexpr laddbuffer laddfile last language later lbuffer lcd lchdir lclose lcscope left leftabove lexpr lfile lfirst lgetbuffer lgetexpr lgetfile lgrep lgrepadd lhelpgrep llast llist lmake lmap lmapclear lnext lnewer lnfile lnoremap loadkeymap loadview lockmarks lockvar lolder lopen lprevious lpfile lrewind ltag lunmap luado luafile lvimgrep lvimgrepadd lwindow move mark make mapclear match menu menutranslate messages mkexrc mksession mkspell mkvimrc mkview mode mzscheme mzfile nbclose nbkey nbsart next nmap nmapclear nmenu nnoremap nnoremenu noautocmd noremap nohlsearch noreabbrev noremenu normal number nunmap nunmenu oldfiles open omap omapclear omenu only onoremap onoremenu options ounmap ounmenu ownsyntax print profdel profile promptfind promptrepl pclose pedit perl perldo pop popup ppop preserve previous psearch ptag ptNext ptfirst ptjump ptlast ptnext ptprevious ptrewind ptselect put pwd py3do py3file python pydo pyfile quit quitall qall read recover redo redir redraw redrawstatus registers resize retab return rewind right rightbelow ruby rubydo rubyfile rundo runtime rviminfo substitute sNext sandbox sargument sall saveas sbuffer sbNext sball sbfirst sblast sbmodified sbnext sbprevious sbrewind scriptnames scriptencoding scscope set setfiletype setglobal setlocal sfind sfirst shell simalt sign silent sleep slast smagic smapclear smenu snext sniff snomagic snoremap snoremenu sort source spelldump spellgood spellinfo spellrepall spellundo spellwrong split sprevious srewind stop stag startgreplace startreplace startinsert stopinsert stjump stselect sunhide sunmap sunmenu suspend sview swapname syntax syntime syncbind tNext tabNext tabclose tabedit tabfind tabfirst tablast tabmove tabnext tabonly tabprevious tabrewind tag tcl tcldo tclfile tearoff tfirst throw tjump tlast tmenu tnext topleft tprevious trewind tselect tunmenu undo undojoin undolist unabbreviate unhide unlet unlockvar unmap unmenu unsilent update vglobal version verbose vertical vimgrep vimgrepadd visual viusage view vmap vmapclear vmenu vnew vnoremap vnoremenu vsplit vunmap vunmenu write wNext wall while winsize wincmd winpos wnext wprevious wqall wsverb wundo wviminfo xit xall xmapclear xmap xmenu xnoremap xnoremenu xunmap xunmenu yank",
+built_in:"synIDtrans atan2 range matcharg did_filetype asin feedkeys xor argv complete_check add getwinposx getqflist getwinposy screencol clearmatches empty extend getcmdpos mzeval garbagecollect setreg ceil sqrt diff_hlID inputsecret get getfperm getpid filewritable shiftwidth max sinh isdirectory synID system inputrestore winline atan visualmode inputlist tabpagewinnr round getregtype mapcheck hasmapto histdel argidx findfile sha256 exists toupper getcmdline taglist string getmatches bufnr strftime winwidth bufexists strtrans tabpagebuflist setcmdpos remote_read printf setloclist getpos getline bufwinnr float2nr len getcmdtype diff_filler luaeval resolve libcallnr foldclosedend reverse filter has_key bufname str2float strlen setline getcharmod setbufvar index searchpos shellescape undofile foldclosed setqflist buflisted strchars str2nr virtcol floor remove undotree remote_expr winheight gettabwinvar reltime cursor tabpagenr finddir localtime acos getloclist search tanh matchend rename gettabvar strdisplaywidth type abs py3eval setwinvar tolower wildmenumode log10 spellsuggest bufloaded synconcealed nextnonblank server2client complete settabwinvar executable input wincol setmatches getftype hlID inputsave searchpair or screenrow line settabvar histadd deepcopy strpart remote_peek and eval getftime submatch screenchar winsaveview matchadd mkdir screenattr getfontname libcall reltimestr getfsize winnr invert pow getbufline byte2line soundfold repeat fnameescape tagfiles sin strwidth spellbadword trunc maparg log lispindent hostname setpos globpath remote_foreground getchar synIDattr fnamemodify cscope_connection stridx winbufnr indent min complete_add nr2char searchpairpos inputdialog values matchlist items hlexists strridx browsedir expand fmod pathshorten line2byte argc count getwinvar glob foldtextresult getreg foreground cosh matchdelete has char2nr simplify histget searchdecl iconv winrestcmd pumvisible writefile foldlevel haslocaldir keys cos matchstr foldtext histnr tan tempname getcwd byteidx getbufvar islocked escape eventhandler remote_send serverlist winrestview synstack pyeval prevnonblank readfile cindent filereadable changenr exp"
+},illegal:/;/,contains:[e.NUMBER_MODE,{className:"string",begin:"'",end:"'",
+illegal:"\\n"},{className:"string",begin:/"(\\"|\n\\|[^"\n])*"/
+},e.COMMENT('"',"$"),{className:"variable",begin:/[bwtglsav]:[\w\d_]*/},{
+className:"function",beginKeywords:"function function!",end:"$",relevance:0,
+contains:[e.TITLE_MODE,{className:"params",begin:"\\(",end:"\\)"}]},{
+className:"symbol",begin:/<[\w-]+>/}]})})());hljs.registerLanguage("sql",(()=>{"use strict";return e=>{
+var t=e.COMMENT("--","$");return{name:"SQL",case_insensitive:!0,
+illegal:/[<>{}*]/,contains:[{
+beginKeywords:"begin end start commit rollback savepoint lock alter create drop rename call delete do handler insert load replace select truncate update set show pragma grant merge describe use explain help declare prepare execute deallocate release unlock purge reset change stop analyze cache flush optimize repair kill install uninstall checksum restore check backup revoke comment values with",
+end:/;/,endsWithParent:!0,keywords:{$pattern:/[\w\.]+/,
+keyword:"as abort abs absolute acc acce accep accept access accessed accessible account acos action activate add addtime admin administer advanced advise aes_decrypt aes_encrypt after agent aggregate ali alia alias all allocate allow alter always analyze ancillary and anti any anydata anydataset anyschema anytype apply archive archived archivelog are as asc ascii asin assembly assertion associate asynchronous at atan atn2 attr attri attrib attribu attribut attribute attributes audit authenticated authentication authid authors auto autoallocate autodblink autoextend automatic availability avg backup badfile basicfile before begin beginning benchmark between bfile bfile_base big bigfile bin binary_double binary_float binlog bit_and bit_count bit_length bit_or bit_xor bitmap blob_base block blocksize body both bound bucket buffer_cache buffer_pool build bulk by byte byteordermark bytes cache caching call calling cancel capacity cascade cascaded case cast catalog category ceil ceiling chain change changed char_base char_length character_length characters characterset charindex charset charsetform charsetid check checksum checksum_agg child choose chr chunk class cleanup clear client clob clob_base clone close cluster_id cluster_probability cluster_set clustering coalesce coercibility col collate collation collect colu colum column column_value columns columns_updated comment commit compact compatibility compiled complete composite_limit compound compress compute concat concat_ws concurrent confirm conn connec connect connect_by_iscycle connect_by_isleaf connect_by_root connect_time connection consider consistent constant constraint constraints constructor container content contents context contributors controlfile conv convert convert_tz corr corr_k corr_s corresponding corruption cos cost count count_big counted covar_pop covar_samp cpu_per_call cpu_per_session crc32 create creation critical cross cube cume_dist curdate current current_date current_time current_timestamp current_user cursor curtime customdatum cycle data database databases datafile datafiles datalength date_add date_cache date_format date_sub dateadd datediff datefromparts datename datepart datetime2fromparts day day_to_second dayname dayofmonth dayofweek dayofyear days db_role_change dbtimezone ddl deallocate declare decode decompose decrement decrypt deduplicate def defa defau defaul default defaults deferred defi defin define degrees delayed delegate delete delete_all delimited demand dense_rank depth dequeue des_decrypt des_encrypt des_key_file desc descr descri describ describe descriptor deterministic diagnostics difference dimension direct_load directory disable disable_all disallow disassociate discardfile disconnect diskgroup distinct distinctrow distribute distributed div do document domain dotnet double downgrade drop dumpfile duplicate duration each edition editionable editions element ellipsis else elsif elt empty enable enable_all enclosed encode encoding encrypt end end-exec endian enforced engine engines enqueue enterprise entityescaping eomonth error errors escaped evalname evaluate event eventdata events except exception exceptions exchange exclude excluding execu execut execute exempt exists exit exp expire explain explode export export_set extended extent external external_1 external_2 externally extract failed failed_login_attempts failover failure far fast feature_set feature_value fetch field fields file file_name_convert filesystem_like_logging final finish first first_value fixed flash_cache flashback floor flush following follows for forall force foreign form forma format found found_rows freelist freelists freepools fresh from from_base64 from_days ftp full function general generated get get_format get_lock getdate getutcdate global global_name globally go goto grant grants greatest group group_concat group_id grouping grouping_id groups gtid_subtract guarantee guard handler hash hashkeys having hea head headi headin heading heap help hex hierarchy high high_priority hosts hour hours http id ident_current ident_incr ident_seed identified identity idle_time if ifnull ignore iif ilike ilm immediate import in include including increment index indexes indexing indextype indicator indices inet6_aton inet6_ntoa inet_aton inet_ntoa infile initial initialized initially initrans inmemory inner innodb input insert install instance instantiable instr interface interleaved intersect into invalidate invisible is is_free_lock is_ipv4 is_ipv4_compat is_not is_not_null is_used_lock isdate isnull isolation iterate java join json json_exists keep keep_duplicates key keys kill language large last last_day last_insert_id last_value lateral lax lcase lead leading least leaves left len lenght length less level levels library like like2 like4 likec limit lines link list listagg little ln load load_file lob lobs local localtime localtimestamp locate locator lock locked log log10 log2 logfile logfiles logging logical logical_reads_per_call logoff logon logs long loop low low_priority lower lpad lrtrim ltrim main make_set makedate maketime managed management manual map mapping mask master master_pos_wait match matched materialized max maxextents maximize maxinstances maxlen maxlogfiles maxloghistory maxlogmembers maxsize maxtrans md5 measures median medium member memcompress memory merge microsecond mid migration min minextents minimum mining minus minute minutes minvalue missing mod mode model modification modify module monitoring month months mount move movement multiset mutex name name_const names nan national native natural nav nchar nclob nested never new newline next nextval no no_write_to_binlog noarchivelog noaudit nobadfile nocheck nocompress nocopy nocycle nodelay nodiscardfile noentityescaping noguarantee nokeep nologfile nomapping nomaxvalue nominimize nominvalue nomonitoring none noneditionable nonschema noorder nopr nopro noprom nopromp noprompt norely noresetlogs noreverse normal norowdependencies noschemacheck noswitch not nothing notice notnull notrim novalidate now nowait nth_value nullif nulls num numb numbe nvarchar nvarchar2 object ocicoll ocidate ocidatetime ociduration ociinterval ociloblocator ocinumber ociref ocirefcursor ocirowid ocistring ocitype oct octet_length of off offline offset oid oidindex old on online only opaque open operations operator optimal optimize option optionally or oracle oracle_date oradata ord ordaudio orddicom orddoc order ordimage ordinality ordvideo organization orlany orlvary out outer outfile outline output over overflow overriding package pad parallel parallel_enable parameters parent parse partial partition partitions pascal passing password password_grace_time password_lock_time password_reuse_max password_reuse_time password_verify_function patch path patindex pctincrease pctthreshold pctused pctversion percent percent_rank percentile_cont percentile_disc performance period period_add period_diff permanent physical pi pipe pipelined pivot pluggable plugin policy position post_transaction pow power pragma prebuilt precedes preceding precision prediction prediction_cost prediction_details prediction_probability prediction_set prepare present preserve prior priority private private_sga privileges procedural procedure procedure_analyze processlist profiles project prompt protection public publishingservername purge quarter query quick quiesce quota quotename radians raise rand range rank raw read reads readsize rebuild record records recover recovery recursive recycle redo reduced ref reference referenced references referencing refresh regexp_like register regr_avgx regr_avgy regr_count regr_intercept regr_r2 regr_slope regr_sxx regr_sxy reject rekey relational relative relaylog release release_lock relies_on relocate rely rem remainder rename repair repeat replace replicate replication required reset resetlogs resize resource respect restore restricted result result_cache resumable resume retention return returning returns reuse reverse revoke right rlike role roles rollback rolling rollup round row row_count rowdependencies rowid rownum rows rtrim rules safe salt sample save savepoint sb1 sb2 sb4 scan schema schemacheck scn scope scroll sdo_georaster sdo_topo_geometry search sec_to_time second seconds section securefile security seed segment select self semi sequence sequential serializable server servererror session session_user sessions_per_user set sets settings sha sha1 sha2 share shared shared_pool short show shrink shutdown si_averagecolor si_colorhistogram si_featurelist si_positionalcolor si_stillimage si_texture siblings sid sign sin size size_t sizes skip slave sleep smalldatetimefromparts smallfile snapshot some soname sort soundex source space sparse spfile split sql sql_big_result sql_buffer_result sql_cache sql_calc_found_rows sql_small_result sql_variant_property sqlcode sqldata sqlerror sqlname sqlstate sqrt square standalone standby start starting startup statement static statistics stats_binomial_test stats_crosstab stats_ks_test stats_mode stats_mw_test stats_one_way_anova stats_t_test_ stats_t_test_indep stats_t_test_one stats_t_test_paired stats_wsr_test status std stddev stddev_pop stddev_samp stdev stop storage store stored str str_to_date straight_join strcmp strict string struct stuff style subdate subpartition subpartitions substitutable substr substring subtime subtring_index subtype success sum suspend switch switchoffset switchover sync synchronous synonym sys sys_xmlagg sysasm sysaux sysdate sysdatetimeoffset sysdba sysoper system system_user sysutcdatetime table tables tablespace tablesample tan tdo template temporary terminated tertiary_weights test than then thread through tier ties time time_format time_zone timediff timefromparts timeout timestamp timestampadd timestampdiff timezone_abbr timezone_minute timezone_region to to_base64 to_date to_days to_seconds todatetimeoffset trace tracking transaction transactional translate translation treat trigger trigger_nestlevel triggers trim truncate try_cast try_convert try_parse type ub1 ub2 ub4 ucase unarchived unbounded uncompress under undo unhex unicode uniform uninstall union unique unix_timestamp unknown unlimited unlock unnest unpivot unrecoverable unsafe unsigned until untrusted unusable unused update updated upgrade upped upper upsert url urowid usable usage use use_stored_outlines user user_data user_resources users using utc_date utc_timestamp uuid uuid_short validate validate_password_strength validation valist value values var var_samp varcharc vari varia variab variabl variable variables variance varp varraw varrawc varray verify version versions view virtual visible void wait wallet warning warnings week weekday weekofyear wellformed when whene whenev wheneve whenever where while whitespace window with within without work wrapped xdb xml xmlagg xmlattributes xmlcast xmlcolattval xmlelement xmlexists xmlforest xmlindex xmlnamespaces xmlpi xmlquery xmlroot xmlschema xmlserialize xmltable xmltype xor year year_to_month years yearweek",
+literal:"true false null unknown",
+built_in:"array bigint binary bit blob bool boolean char character date dec decimal float int int8 integer interval number numeric real record serial serial8 smallint text time timestamp tinyint varchar varchar2 varying void"
+},contains:[{className:"string",begin:"'",end:"'",contains:[{begin:"''"}]},{
+className:"string",begin:'"',end:'"',contains:[{begin:'""'}]},{
+className:"string",begin:"`",end:"`"
+},e.C_NUMBER_MODE,e.C_BLOCK_COMMENT_MODE,t,e.HASH_COMMENT_MODE]
+},e.C_BLOCK_COMMENT_MODE,t,e.HASH_COMMENT_MODE]}}})());hljs.registerLanguage("shell",(()=>{"use strict";return s=>({
+name:"Shell Session",aliases:["console"],contains:[{className:"meta",
+begin:/^\s{0,3}[/~\w\d[\]()@-]*[>%$#]/,starts:{end:/[^\\](?=\s*$)/,
+subLanguage:"bash"}}]})})());hljs.registerLanguage("gml",(()=>{"use strict";return e=>({name:"GML",
+aliases:["gml","GML"],case_insensitive:!1,keywords:{
+keyword:"begin end if then else while do for break continue with until repeat exit and or xor not return mod div switch case default var globalvar enum #macro #region #endregion",
+built_in:"is_real is_string is_array is_undefined is_int32 is_int64 is_ptr is_vec3 is_vec4 is_matrix is_bool typeof variable_global_exists variable_global_get variable_global_set variable_instance_exists variable_instance_get variable_instance_set variable_instance_get_names array_length_1d array_length_2d array_height_2d array_equals array_create array_copy random random_range irandom irandom_range random_set_seed random_get_seed randomize randomise choose abs round floor ceil sign frac sqrt sqr exp ln log2 log10 sin cos tan arcsin arccos arctan arctan2 dsin dcos dtan darcsin darccos darctan darctan2 degtorad radtodeg power logn min max mean median clamp lerp dot_product dot_product_3d dot_product_normalised dot_product_3d_normalised dot_product_normalized dot_product_3d_normalized math_set_epsilon math_get_epsilon angle_difference point_distance_3d point_distance point_direction lengthdir_x lengthdir_y real string int64 ptr string_format chr ansi_char ord string_length string_byte_length string_pos string_copy string_char_at string_ord_at string_byte_at string_set_byte_at string_delete string_insert string_lower string_upper string_repeat string_letters string_digits string_lettersdigits string_replace string_replace_all string_count string_hash_to_newline clipboard_has_text clipboard_set_text clipboard_get_text date_current_datetime date_create_datetime date_valid_datetime date_inc_year date_inc_month date_inc_week date_inc_day date_inc_hour date_inc_minute date_inc_second date_get_year date_get_month date_get_week date_get_day date_get_hour date_get_minute date_get_second date_get_weekday date_get_day_of_year date_get_hour_of_year date_get_minute_of_year date_get_second_of_year date_year_span date_month_span date_week_span date_day_span date_hour_span date_minute_span date_second_span date_compare_datetime date_compare_date date_compare_time date_date_of date_time_of date_datetime_string date_date_string date_time_string date_days_in_month date_days_in_year date_leap_year date_is_today date_set_timezone date_get_timezone game_set_speed game_get_speed motion_set motion_add place_free place_empty place_meeting place_snapped move_random move_snap move_towards_point move_contact_solid move_contact_all move_outside_solid move_outside_all move_bounce_solid move_bounce_all move_wrap distance_to_point distance_to_object position_empty position_meeting path_start path_end mp_linear_step mp_potential_step mp_linear_step_object mp_potential_step_object mp_potential_settings mp_linear_path mp_potential_path mp_linear_path_object mp_potential_path_object mp_grid_create mp_grid_destroy mp_grid_clear_all mp_grid_clear_cell mp_grid_clear_rectangle mp_grid_add_cell mp_grid_get_cell mp_grid_add_rectangle mp_grid_add_instances mp_grid_path mp_grid_draw mp_grid_to_ds_grid collision_point collision_rectangle collision_circle collision_ellipse collision_line collision_point_list collision_rectangle_list collision_circle_list collision_ellipse_list collision_line_list instance_position_list instance_place_list point_in_rectangle point_in_triangle point_in_circle rectangle_in_rectangle rectangle_in_triangle rectangle_in_circle instance_find instance_exists instance_number instance_position instance_nearest instance_furthest instance_place instance_create_depth instance_create_layer instance_copy instance_change instance_destroy position_destroy position_change instance_id_get instance_deactivate_all instance_deactivate_object instance_deactivate_region instance_activate_all instance_activate_object instance_activate_region room_goto room_goto_previous room_goto_next room_previous room_next room_restart game_end game_restart game_load game_save game_save_buffer game_load_buffer event_perform event_user event_perform_object event_inherited show_debug_message show_debug_overlay debug_event debug_get_callstack alarm_get alarm_set font_texture_page_size keyboard_set_map keyboard_get_map keyboard_unset_map keyboard_check keyboard_check_pressed keyboard_check_released keyboard_check_direct keyboard_get_numlock keyboard_set_numlock keyboard_key_press keyboard_key_release keyboard_clear io_clear mouse_check_button mouse_check_button_pressed mouse_check_button_released mouse_wheel_up mouse_wheel_down mouse_clear draw_self draw_sprite draw_sprite_pos draw_sprite_ext draw_sprite_stretched draw_sprite_stretched_ext draw_sprite_tiled draw_sprite_tiled_ext draw_sprite_part draw_sprite_part_ext draw_sprite_general draw_clear draw_clear_alpha draw_point draw_line draw_line_width draw_rectangle draw_roundrect draw_roundrect_ext draw_triangle draw_circle draw_ellipse draw_set_circle_precision draw_arrow draw_button draw_path draw_healthbar draw_getpixel draw_getpixel_ext draw_set_colour draw_set_color draw_set_alpha draw_get_colour draw_get_color draw_get_alpha merge_colour make_colour_rgb make_colour_hsv colour_get_red colour_get_green colour_get_blue colour_get_hue colour_get_saturation colour_get_value merge_color make_color_rgb make_color_hsv color_get_red color_get_green color_get_blue color_get_hue color_get_saturation color_get_value merge_color screen_save screen_save_part draw_set_font draw_set_halign draw_set_valign draw_text draw_text_ext string_width string_height string_width_ext string_height_ext draw_text_transformed draw_text_ext_transformed draw_text_colour draw_text_ext_colour draw_text_transformed_colour draw_text_ext_transformed_colour draw_text_color draw_text_ext_color draw_text_transformed_color draw_text_ext_transformed_color draw_point_colour draw_line_colour draw_line_width_colour draw_rectangle_colour draw_roundrect_colour draw_roundrect_colour_ext draw_triangle_colour draw_circle_colour draw_ellipse_colour draw_point_color draw_line_color draw_line_width_color draw_rectangle_color draw_roundrect_color draw_roundrect_color_ext draw_triangle_color draw_circle_color draw_ellipse_color draw_primitive_begin draw_vertex draw_vertex_colour draw_vertex_color draw_primitive_end sprite_get_uvs font_get_uvs sprite_get_texture font_get_texture texture_get_width texture_get_height texture_get_uvs draw_primitive_begin_texture draw_vertex_texture draw_vertex_texture_colour draw_vertex_texture_color texture_global_scale surface_create surface_create_ext surface_resize surface_free surface_exists surface_get_width surface_get_height surface_get_texture surface_set_target surface_set_target_ext surface_reset_target surface_depth_disable surface_get_depth_disable draw_surface draw_surface_stretched draw_surface_tiled draw_surface_part draw_surface_ext draw_surface_stretched_ext draw_surface_tiled_ext draw_surface_part_ext draw_surface_general surface_getpixel surface_getpixel_ext surface_save surface_save_part surface_copy surface_copy_part application_surface_draw_enable application_get_position application_surface_enable application_surface_is_enabled display_get_width display_get_height display_get_orientation display_get_gui_width display_get_gui_height display_reset display_mouse_get_x display_mouse_get_y display_mouse_set display_set_ui_visibility window_set_fullscreen window_get_fullscreen window_set_caption window_set_min_width window_set_max_width window_set_min_height window_set_max_height window_get_visible_rects window_get_caption window_set_cursor window_get_cursor window_set_colour window_get_colour window_set_color window_get_color window_set_position window_set_size window_set_rectangle window_center window_get_x window_get_y window_get_width window_get_height window_mouse_get_x window_mouse_get_y window_mouse_set window_view_mouse_get_x window_view_mouse_get_y window_views_mouse_get_x window_views_mouse_get_y audio_listener_position audio_listener_velocity audio_listener_orientation audio_emitter_position audio_emitter_create audio_emitter_free audio_emitter_exists audio_emitter_pitch audio_emitter_velocity audio_emitter_falloff audio_emitter_gain audio_play_sound audio_play_sound_on audio_play_sound_at audio_stop_sound audio_resume_music audio_music_is_playing audio_resume_sound audio_pause_sound audio_pause_music audio_channel_num audio_sound_length audio_get_type audio_falloff_set_model audio_play_music audio_stop_music audio_master_gain audio_music_gain audio_sound_gain audio_sound_pitch audio_stop_all audio_resume_all audio_pause_all audio_is_playing audio_is_paused audio_exists audio_sound_set_track_position audio_sound_get_track_position audio_emitter_get_gain audio_emitter_get_pitch audio_emitter_get_x audio_emitter_get_y audio_emitter_get_z audio_emitter_get_vx audio_emitter_get_vy audio_emitter_get_vz audio_listener_set_position audio_listener_set_velocity audio_listener_set_orientation audio_listener_get_data audio_set_master_gain audio_get_master_gain audio_sound_get_gain audio_sound_get_pitch audio_get_name audio_sound_set_track_position audio_sound_get_track_position audio_create_stream audio_destroy_stream audio_create_sync_group audio_destroy_sync_group audio_play_in_sync_group audio_start_sync_group audio_stop_sync_group audio_pause_sync_group audio_resume_sync_group audio_sync_group_get_track_pos audio_sync_group_debug audio_sync_group_is_playing audio_debug audio_group_load audio_group_unload audio_group_is_loaded audio_group_load_progress audio_group_name audio_group_stop_all audio_group_set_gain audio_create_buffer_sound audio_free_buffer_sound audio_create_play_queue audio_free_play_queue audio_queue_sound audio_get_recorder_count audio_get_recorder_info audio_start_recording audio_stop_recording audio_sound_get_listener_mask audio_emitter_get_listener_mask audio_get_listener_mask audio_sound_set_listener_mask audio_emitter_set_listener_mask audio_set_listener_mask audio_get_listener_count audio_get_listener_info audio_system show_message show_message_async clickable_add clickable_add_ext clickable_change clickable_change_ext clickable_delete clickable_exists clickable_set_style show_question show_question_async get_integer get_string get_integer_async get_string_async get_login_async get_open_filename get_save_filename get_open_filename_ext get_save_filename_ext show_error highscore_clear highscore_add highscore_value highscore_name draw_highscore sprite_exists sprite_get_name sprite_get_number sprite_get_width sprite_get_height sprite_get_xoffset sprite_get_yoffset sprite_get_bbox_left sprite_get_bbox_right sprite_get_bbox_top sprite_get_bbox_bottom sprite_save sprite_save_strip sprite_set_cache_size sprite_set_cache_size_ext sprite_get_tpe sprite_prefetch sprite_prefetch_multi sprite_flush sprite_flush_multi sprite_set_speed sprite_get_speed_type sprite_get_speed font_exists font_get_name font_get_fontname font_get_bold font_get_italic font_get_first font_get_last font_get_size font_set_cache_size path_exists path_get_name path_get_length path_get_time path_get_kind path_get_closed path_get_precision path_get_number path_get_point_x path_get_point_y path_get_point_speed path_get_x path_get_y path_get_speed script_exists script_get_name timeline_add timeline_delete timeline_clear timeline_exists timeline_get_name timeline_moment_clear timeline_moment_add_script timeline_size timeline_max_moment object_exists object_get_name object_get_sprite object_get_solid object_get_visible object_get_persistent object_get_mask object_get_parent object_get_physics object_is_ancestor room_exists room_get_name sprite_set_offset sprite_duplicate sprite_assign sprite_merge sprite_add sprite_replace sprite_create_from_surface sprite_add_from_surface sprite_delete sprite_set_alpha_from_sprite sprite_collision_mask font_add_enable_aa font_add_get_enable_aa font_add font_add_sprite font_add_sprite_ext font_replace font_replace_sprite font_replace_sprite_ext font_delete path_set_kind path_set_closed path_set_precision path_add path_assign path_duplicate path_append path_delete path_add_point path_insert_point path_change_point path_delete_point path_clear_points path_reverse path_mirror path_flip path_rotate path_rescale path_shift script_execute object_set_sprite object_set_solid object_set_visible object_set_persistent object_set_mask room_set_width room_set_height room_set_persistent room_set_background_colour room_set_background_color room_set_view room_set_viewport room_get_viewport room_set_view_enabled room_add room_duplicate room_assign room_instance_add room_instance_clear room_get_camera room_set_camera asset_get_index asset_get_type file_text_open_from_string file_text_open_read file_text_open_write file_text_open_append file_text_close file_text_write_string file_text_write_real file_text_writeln file_text_read_string file_text_read_real file_text_readln file_text_eof file_text_eoln file_exists file_delete file_rename file_copy directory_exists directory_create directory_destroy file_find_first file_find_next file_find_close file_attributes filename_name filename_path filename_dir filename_drive filename_ext filename_change_ext file_bin_open file_bin_rewrite file_bin_close file_bin_position file_bin_size file_bin_seek file_bin_write_byte file_bin_read_byte parameter_count parameter_string environment_get_variable ini_open_from_string ini_open ini_close ini_read_string ini_read_real ini_write_string ini_write_real ini_key_exists ini_section_exists ini_key_delete ini_section_delete ds_set_precision ds_exists ds_stack_create ds_stack_destroy ds_stack_clear ds_stack_copy ds_stack_size ds_stack_empty ds_stack_push ds_stack_pop ds_stack_top ds_stack_write ds_stack_read ds_queue_create ds_queue_destroy ds_queue_clear ds_queue_copy ds_queue_size ds_queue_empty ds_queue_enqueue ds_queue_dequeue ds_queue_head ds_queue_tail ds_queue_write ds_queue_read ds_list_create ds_list_destroy ds_list_clear ds_list_copy ds_list_size ds_list_empty ds_list_add ds_list_insert ds_list_replace ds_list_delete ds_list_find_index ds_list_find_value ds_list_mark_as_list ds_list_mark_as_map ds_list_sort ds_list_shuffle ds_list_write ds_list_read ds_list_set ds_map_create ds_map_destroy ds_map_clear ds_map_copy ds_map_size ds_map_empty ds_map_add ds_map_add_list ds_map_add_map ds_map_replace ds_map_replace_map ds_map_replace_list ds_map_delete ds_map_exists ds_map_find_value ds_map_find_previous ds_map_find_next ds_map_find_first ds_map_find_last ds_map_write ds_map_read ds_map_secure_save ds_map_secure_load ds_map_secure_load_buffer ds_map_secure_save_buffer ds_map_set ds_priority_create ds_priority_destroy ds_priority_clear ds_priority_copy ds_priority_size ds_priority_empty ds_priority_add ds_priority_change_priority ds_priority_find_priority ds_priority_delete_value ds_priority_delete_min ds_priority_find_min ds_priority_delete_max ds_priority_find_max ds_priority_write ds_priority_read ds_grid_create ds_grid_destroy ds_grid_copy ds_grid_resize ds_grid_width ds_grid_height ds_grid_clear ds_grid_set ds_grid_add ds_grid_multiply ds_grid_set_region ds_grid_add_region ds_grid_multiply_region ds_grid_set_disk ds_grid_add_disk ds_grid_multiply_disk ds_grid_set_grid_region ds_grid_add_grid_region ds_grid_multiply_grid_region ds_grid_get ds_grid_get_sum ds_grid_get_max ds_grid_get_min ds_grid_get_mean ds_grid_get_disk_sum ds_grid_get_disk_min ds_grid_get_disk_max ds_grid_get_disk_mean ds_grid_value_exists ds_grid_value_x ds_grid_value_y ds_grid_value_disk_exists ds_grid_value_disk_x ds_grid_value_disk_y ds_grid_shuffle ds_grid_write ds_grid_read ds_grid_sort ds_grid_set ds_grid_get effect_create_below effect_create_above effect_clear part_type_create part_type_destroy part_type_exists part_type_clear part_type_shape part_type_sprite part_type_size part_type_scale part_type_orientation part_type_life part_type_step part_type_death part_type_speed part_type_direction part_type_gravity part_type_colour1 part_type_colour2 part_type_colour3 part_type_colour_mix part_type_colour_rgb part_type_colour_hsv part_type_color1 part_type_color2 part_type_color3 part_type_color_mix part_type_color_rgb part_type_color_hsv part_type_alpha1 part_type_alpha2 part_type_alpha3 part_type_blend part_system_create part_system_create_layer part_system_destroy part_system_exists part_system_clear part_system_draw_order part_system_depth part_system_position part_system_automatic_update part_system_automatic_draw part_system_update part_system_drawit part_system_get_layer part_system_layer part_particles_create part_particles_create_colour part_particles_create_color part_particles_clear part_particles_count part_emitter_create part_emitter_destroy part_emitter_destroy_all part_emitter_exists part_emitter_clear part_emitter_region part_emitter_burst part_emitter_stream external_call external_define external_free window_handle window_device matrix_get matrix_set matrix_build_identity matrix_build matrix_build_lookat matrix_build_projection_ortho matrix_build_projection_perspective matrix_build_projection_perspective_fov matrix_multiply matrix_transform_vertex matrix_stack_push matrix_stack_pop matrix_stack_multiply matrix_stack_set matrix_stack_clear matrix_stack_top matrix_stack_is_empty browser_input_capture os_get_config os_get_info os_get_language os_get_region os_lock_orientation display_get_dpi_x display_get_dpi_y display_set_gui_size display_set_gui_maximise display_set_gui_maximize device_mouse_dbclick_enable display_set_timing_method display_get_timing_method display_set_sleep_margin display_get_sleep_margin virtual_key_add virtual_key_hide virtual_key_delete virtual_key_show draw_enable_drawevent draw_enable_swf_aa draw_set_swf_aa_level draw_get_swf_aa_level draw_texture_flush draw_flush gpu_set_blendenable gpu_set_ztestenable gpu_set_zfunc gpu_set_zwriteenable gpu_set_lightingenable gpu_set_fog gpu_set_cullmode gpu_set_blendmode gpu_set_blendmode_ext gpu_set_blendmode_ext_sepalpha gpu_set_colorwriteenable gpu_set_colourwriteenable gpu_set_alphatestenable gpu_set_alphatestref gpu_set_alphatestfunc gpu_set_texfilter gpu_set_texfilter_ext gpu_set_texrepeat gpu_set_texrepeat_ext gpu_set_tex_filter gpu_set_tex_filter_ext gpu_set_tex_repeat gpu_set_tex_repeat_ext gpu_set_tex_mip_filter gpu_set_tex_mip_filter_ext gpu_set_tex_mip_bias gpu_set_tex_mip_bias_ext gpu_set_tex_min_mip gpu_set_tex_min_mip_ext gpu_set_tex_max_mip gpu_set_tex_max_mip_ext gpu_set_tex_max_aniso gpu_set_tex_max_aniso_ext gpu_set_tex_mip_enable gpu_set_tex_mip_enable_ext gpu_get_blendenable gpu_get_ztestenable gpu_get_zfunc gpu_get_zwriteenable gpu_get_lightingenable gpu_get_fog gpu_get_cullmode gpu_get_blendmode gpu_get_blendmode_ext gpu_get_blendmode_ext_sepalpha gpu_get_blendmode_src gpu_get_blendmode_dest gpu_get_blendmode_srcalpha gpu_get_blendmode_destalpha gpu_get_colorwriteenable gpu_get_colourwriteenable gpu_get_alphatestenable gpu_get_alphatestref gpu_get_alphatestfunc gpu_get_texfilter gpu_get_texfilter_ext gpu_get_texrepeat gpu_get_texrepeat_ext gpu_get_tex_filter gpu_get_tex_filter_ext gpu_get_tex_repeat gpu_get_tex_repeat_ext gpu_get_tex_mip_filter gpu_get_tex_mip_filter_ext gpu_get_tex_mip_bias gpu_get_tex_mip_bias_ext gpu_get_tex_min_mip gpu_get_tex_min_mip_ext gpu_get_tex_max_mip gpu_get_tex_max_mip_ext gpu_get_tex_max_aniso gpu_get_tex_max_aniso_ext gpu_get_tex_mip_enable gpu_get_tex_mip_enable_ext gpu_push_state gpu_pop_state gpu_get_state gpu_set_state draw_light_define_ambient draw_light_define_direction draw_light_define_point draw_light_enable draw_set_lighting draw_light_get_ambient draw_light_get draw_get_lighting shop_leave_rating url_get_domain url_open url_open_ext url_open_full get_timer achievement_login achievement_logout achievement_post achievement_increment achievement_post_score achievement_available achievement_show_achievements achievement_show_leaderboards achievement_load_friends achievement_load_leaderboard achievement_send_challenge achievement_load_progress achievement_reset achievement_login_status achievement_get_pic achievement_show_challenge_notifications achievement_get_challenges achievement_event achievement_show achievement_get_info cloud_file_save cloud_string_save cloud_synchronise ads_enable ads_disable ads_setup ads_engagement_launch ads_engagement_available ads_engagement_active ads_event ads_event_preload ads_set_reward_callback ads_get_display_height ads_get_display_width ads_move ads_interstitial_available ads_interstitial_display device_get_tilt_x device_get_tilt_y device_get_tilt_z device_is_keypad_open device_mouse_check_button device_mouse_check_button_pressed device_mouse_check_button_released device_mouse_x device_mouse_y device_mouse_raw_x device_mouse_raw_y device_mouse_x_to_gui device_mouse_y_to_gui iap_activate iap_status iap_enumerate_products iap_restore_all iap_acquire iap_consume iap_product_details iap_purchase_details facebook_init facebook_login facebook_status facebook_graph_request facebook_dialog facebook_logout facebook_launch_offerwall facebook_post_message facebook_send_invite facebook_user_id facebook_accesstoken facebook_check_permission facebook_request_read_permissions facebook_request_publish_permissions gamepad_is_supported gamepad_get_device_count gamepad_is_connected gamepad_get_description gamepad_get_button_threshold gamepad_set_button_threshold gamepad_get_axis_deadzone gamepad_set_axis_deadzone gamepad_button_count gamepad_button_check gamepad_button_check_pressed gamepad_button_check_released gamepad_button_value gamepad_axis_count gamepad_axis_value gamepad_set_vibration gamepad_set_colour gamepad_set_color os_is_paused window_has_focus code_is_compiled http_get http_get_file http_post_string http_request json_encode json_decode zip_unzip load_csv base64_encode base64_decode md5_string_unicode md5_string_utf8 md5_file os_is_network_connected sha1_string_unicode sha1_string_utf8 sha1_file os_powersave_enable analytics_event analytics_event_ext win8_livetile_tile_notification win8_livetile_tile_clear win8_livetile_badge_notification win8_livetile_badge_clear win8_livetile_queue_enable win8_secondarytile_pin win8_secondarytile_badge_notification win8_secondarytile_delete win8_livetile_notification_begin win8_livetile_notification_secondary_begin win8_livetile_notification_expiry win8_livetile_notification_tag win8_livetile_notification_text_add win8_livetile_notification_image_add win8_livetile_notification_end win8_appbar_enable win8_appbar_add_element win8_appbar_remove_element win8_settingscharm_add_entry win8_settingscharm_add_html_entry win8_settingscharm_add_xaml_entry win8_settingscharm_set_xaml_property win8_settingscharm_get_xaml_property win8_settingscharm_remove_entry win8_share_image win8_share_screenshot win8_share_file win8_share_url win8_share_text win8_search_enable win8_search_disable win8_search_add_suggestions win8_device_touchscreen_available win8_license_initialize_sandbox win8_license_trial_version winphone_license_trial_version winphone_tile_title winphone_tile_count winphone_tile_back_title winphone_tile_back_content winphone_tile_back_content_wide winphone_tile_front_image winphone_tile_front_image_small winphone_tile_front_image_wide winphone_tile_back_image winphone_tile_back_image_wide winphone_tile_background_colour winphone_tile_background_color winphone_tile_icon_image winphone_tile_small_icon_image winphone_tile_wide_content winphone_tile_cycle_images winphone_tile_small_background_image physics_world_create physics_world_gravity physics_world_update_speed physics_world_update_iterations physics_world_draw_debug physics_pause_enable physics_fixture_create physics_fixture_set_kinematic physics_fixture_set_density physics_fixture_set_awake physics_fixture_set_restitution physics_fixture_set_friction physics_fixture_set_collision_group physics_fixture_set_sensor physics_fixture_set_linear_damping physics_fixture_set_angular_damping physics_fixture_set_circle_shape physics_fixture_set_box_shape physics_fixture_set_edge_shape physics_fixture_set_polygon_shape physics_fixture_set_chain_shape physics_fixture_add_point physics_fixture_bind physics_fixture_bind_ext physics_fixture_delete physics_apply_force physics_apply_impulse physics_apply_angular_impulse physics_apply_local_force physics_apply_local_impulse physics_apply_torque physics_mass_properties physics_draw_debug physics_test_overlap physics_remove_fixture physics_set_friction physics_set_density physics_set_restitution physics_get_friction physics_get_density physics_get_restitution physics_joint_distance_create physics_joint_rope_create physics_joint_revolute_create physics_joint_prismatic_create physics_joint_pulley_create physics_joint_wheel_create physics_joint_weld_create physics_joint_friction_create physics_joint_gear_create physics_joint_enable_motor physics_joint_get_value physics_joint_set_value physics_joint_delete physics_particle_create physics_particle_delete physics_particle_delete_region_circle physics_particle_delete_region_box physics_particle_delete_region_poly physics_particle_set_flags physics_particle_set_category_flags physics_particle_draw physics_particle_draw_ext physics_particle_count physics_particle_get_data physics_particle_get_data_particle physics_particle_group_begin physics_particle_group_circle physics_particle_group_box physics_particle_group_polygon physics_particle_group_add_point physics_particle_group_end physics_particle_group_join physics_particle_group_delete physics_particle_group_count physics_particle_group_get_data physics_particle_group_get_mass physics_particle_group_get_inertia physics_particle_group_get_centre_x physics_particle_group_get_centre_y physics_particle_group_get_vel_x physics_particle_group_get_vel_y physics_particle_group_get_ang_vel physics_particle_group_get_x physics_particle_group_get_y physics_particle_group_get_angle physics_particle_set_group_flags physics_particle_get_group_flags physics_particle_get_max_count physics_particle_get_radius physics_particle_get_density physics_particle_get_damping physics_particle_get_gravity_scale physics_particle_set_max_count physics_particle_set_radius physics_particle_set_density physics_particle_set_damping physics_particle_set_gravity_scale network_create_socket network_create_socket_ext network_create_server network_create_server_raw network_connect network_connect_raw network_send_packet network_send_raw network_send_broadcast network_send_udp network_send_udp_raw network_set_timeout network_set_config network_resolve network_destroy buffer_create buffer_write buffer_read buffer_seek buffer_get_surface buffer_set_surface buffer_delete buffer_exists buffer_get_type buffer_get_alignment buffer_poke buffer_peek buffer_save buffer_save_ext buffer_load buffer_load_ext buffer_load_partial buffer_copy buffer_fill buffer_get_size buffer_tell buffer_resize buffer_md5 buffer_sha1 buffer_base64_encode buffer_base64_decode buffer_base64_decode_ext buffer_sizeof buffer_get_address buffer_create_from_vertex_buffer buffer_create_from_vertex_buffer_ext buffer_copy_from_vertex_buffer buffer_async_group_begin buffer_async_group_option buffer_async_group_end buffer_load_async buffer_save_async gml_release_mode gml_pragma steam_activate_overlay steam_is_overlay_enabled steam_is_overlay_activated steam_get_persona_name steam_initialised steam_is_cloud_enabled_for_app steam_is_cloud_enabled_for_account steam_file_persisted steam_get_quota_total steam_get_quota_free steam_file_write steam_file_write_file steam_file_read steam_file_delete steam_file_exists steam_file_size steam_file_share steam_is_screenshot_requested steam_send_screenshot steam_is_user_logged_on steam_get_user_steam_id steam_user_owns_dlc steam_user_installed_dlc steam_set_achievement steam_get_achievement steam_clear_achievement steam_set_stat_int steam_set_stat_float steam_set_stat_avg_rate steam_get_stat_int steam_get_stat_float steam_get_stat_avg_rate steam_reset_all_stats steam_reset_all_stats_achievements steam_stats_ready steam_create_leaderboard steam_upload_score steam_upload_score_ext steam_download_scores_around_user steam_download_scores steam_download_friends_scores steam_upload_score_buffer steam_upload_score_buffer_ext steam_current_game_language steam_available_languages steam_activate_overlay_browser steam_activate_overlay_user steam_activate_overlay_store steam_get_user_persona_name steam_get_app_id steam_get_user_account_id steam_ugc_download steam_ugc_create_item steam_ugc_start_item_update steam_ugc_set_item_title steam_ugc_set_item_description steam_ugc_set_item_visibility steam_ugc_set_item_tags steam_ugc_set_item_content steam_ugc_set_item_preview steam_ugc_submit_item_update steam_ugc_get_item_update_progress steam_ugc_subscribe_item steam_ugc_unsubscribe_item steam_ugc_num_subscribed_items steam_ugc_get_subscribed_items steam_ugc_get_item_install_info steam_ugc_get_item_update_info steam_ugc_request_item_details steam_ugc_create_query_user steam_ugc_create_query_user_ex steam_ugc_create_query_all steam_ugc_create_query_all_ex steam_ugc_query_set_cloud_filename_filter steam_ugc_query_set_match_any_tag steam_ugc_query_set_search_text steam_ugc_query_set_ranked_by_trend_days steam_ugc_query_add_required_tag steam_ugc_query_add_excluded_tag steam_ugc_query_set_return_long_description steam_ugc_query_set_return_total_only steam_ugc_query_set_allow_cached_response steam_ugc_send_query shader_set shader_get_name shader_reset shader_current shader_is_compiled shader_get_sampler_index shader_get_uniform shader_set_uniform_i shader_set_uniform_i_array shader_set_uniform_f shader_set_uniform_f_array shader_set_uniform_matrix shader_set_uniform_matrix_array shader_enable_corner_id texture_set_stage texture_get_texel_width texture_get_texel_height shaders_are_supported vertex_format_begin vertex_format_end vertex_format_delete vertex_format_add_position vertex_format_add_position_3d vertex_format_add_colour vertex_format_add_color vertex_format_add_normal vertex_format_add_texcoord vertex_format_add_textcoord vertex_format_add_custom vertex_create_buffer vertex_create_buffer_ext vertex_delete_buffer vertex_begin vertex_end vertex_position vertex_position_3d vertex_colour vertex_color vertex_argb vertex_texcoord vertex_normal vertex_float1 vertex_float2 vertex_float3 vertex_float4 vertex_ubyte4 vertex_submit vertex_freeze vertex_get_number vertex_get_buffer_size vertex_create_buffer_from_buffer vertex_create_buffer_from_buffer_ext push_local_notification push_get_first_local_notification push_get_next_local_notification push_cancel_local_notification skeleton_animation_set skeleton_animation_get skeleton_animation_mix skeleton_animation_set_ext skeleton_animation_get_ext skeleton_animation_get_duration skeleton_animation_get_frames skeleton_animation_clear skeleton_skin_set skeleton_skin_get skeleton_attachment_set skeleton_attachment_get skeleton_attachment_create skeleton_collision_draw_set skeleton_bone_data_get skeleton_bone_data_set skeleton_bone_state_get skeleton_bone_state_set skeleton_get_minmax skeleton_get_num_bounds skeleton_get_bounds skeleton_animation_get_frame skeleton_animation_set_frame draw_skeleton draw_skeleton_time draw_skeleton_instance draw_skeleton_collision skeleton_animation_list skeleton_skin_list skeleton_slot_data layer_get_id layer_get_id_at_depth layer_get_depth layer_create layer_destroy layer_destroy_instances layer_add_instance layer_has_instance layer_set_visible layer_get_visible layer_exists layer_x layer_y layer_get_x layer_get_y layer_hspeed layer_vspeed layer_get_hspeed layer_get_vspeed layer_script_begin layer_script_end layer_shader layer_get_script_begin layer_get_script_end layer_get_shader layer_set_target_room layer_get_target_room layer_reset_target_room layer_get_all layer_get_all_elements layer_get_name layer_depth layer_get_element_layer layer_get_element_type layer_element_move layer_force_draw_depth layer_is_draw_depth_forced layer_get_forced_depth layer_background_get_id layer_background_exists layer_background_create layer_background_destroy layer_background_visible layer_background_change layer_background_sprite layer_background_htiled layer_background_vtiled layer_background_stretch layer_background_yscale layer_background_xscale layer_background_blend layer_background_alpha layer_background_index layer_background_speed layer_background_get_visible layer_background_get_sprite layer_background_get_htiled layer_background_get_vtiled layer_background_get_stretch layer_background_get_yscale layer_background_get_xscale layer_background_get_blend layer_background_get_alpha layer_background_get_index layer_background_get_speed layer_sprite_get_id layer_sprite_exists layer_sprite_create layer_sprite_destroy layer_sprite_change layer_sprite_index layer_sprite_speed layer_sprite_xscale layer_sprite_yscale layer_sprite_angle layer_sprite_blend layer_sprite_alpha layer_sprite_x layer_sprite_y layer_sprite_get_sprite layer_sprite_get_index layer_sprite_get_speed layer_sprite_get_xscale layer_sprite_get_yscale layer_sprite_get_angle layer_sprite_get_blend layer_sprite_get_alpha layer_sprite_get_x layer_sprite_get_y layer_tilemap_get_id layer_tilemap_exists layer_tilemap_create layer_tilemap_destroy tilemap_tileset tilemap_x tilemap_y tilemap_set tilemap_set_at_pixel tilemap_get_tileset tilemap_get_tile_width tilemap_get_tile_height tilemap_get_width tilemap_get_height tilemap_get_x tilemap_get_y tilemap_get tilemap_get_at_pixel tilemap_get_cell_x_at_pixel tilemap_get_cell_y_at_pixel tilemap_clear draw_tilemap draw_tile tilemap_set_global_mask tilemap_get_global_mask tilemap_set_mask tilemap_get_mask tilemap_get_frame tile_set_empty tile_set_index tile_set_flip tile_set_mirror tile_set_rotate tile_get_empty tile_get_index tile_get_flip tile_get_mirror tile_get_rotate layer_tile_exists layer_tile_create layer_tile_destroy layer_tile_change layer_tile_xscale layer_tile_yscale layer_tile_blend layer_tile_alpha layer_tile_x layer_tile_y layer_tile_region layer_tile_visible layer_tile_get_sprite layer_tile_get_xscale layer_tile_get_yscale layer_tile_get_blend layer_tile_get_alpha layer_tile_get_x layer_tile_get_y layer_tile_get_region layer_tile_get_visible layer_instance_get_instance instance_activate_layer instance_deactivate_layer camera_create camera_create_view camera_destroy camera_apply camera_get_active camera_get_default camera_set_default camera_set_view_mat camera_set_proj_mat camera_set_update_script camera_set_begin_script camera_set_end_script camera_set_view_pos camera_set_view_size camera_set_view_speed camera_set_view_border camera_set_view_angle camera_set_view_target camera_get_view_mat camera_get_proj_mat camera_get_update_script camera_get_begin_script camera_get_end_script camera_get_view_x camera_get_view_y camera_get_view_width camera_get_view_height camera_get_view_speed_x camera_get_view_speed_y camera_get_view_border_x camera_get_view_border_y camera_get_view_angle camera_get_view_target view_get_camera view_get_visible view_get_xport view_get_yport view_get_wport view_get_hport view_get_surface_id view_set_camera view_set_visible view_set_xport view_set_yport view_set_wport view_set_hport view_set_surface_id gesture_drag_time gesture_drag_distance gesture_flick_speed gesture_double_tap_time gesture_double_tap_distance gesture_pinch_distance gesture_pinch_angle_towards gesture_pinch_angle_away gesture_rotate_time gesture_rotate_angle gesture_tap_count gesture_get_drag_time gesture_get_drag_distance gesture_get_flick_speed gesture_get_double_tap_time gesture_get_double_tap_distance gesture_get_pinch_distance gesture_get_pinch_angle_towards gesture_get_pinch_angle_away gesture_get_rotate_time gesture_get_rotate_angle gesture_get_tap_count keyboard_virtual_show keyboard_virtual_hide keyboard_virtual_status keyboard_virtual_height",
+literal:"self other all noone global local undefined pointer_invalid pointer_null path_action_stop path_action_restart path_action_continue path_action_reverse true false pi GM_build_date GM_version GM_runtime_version  timezone_local timezone_utc gamespeed_fps gamespeed_microseconds  ev_create ev_destroy ev_step ev_alarm ev_keyboard ev_mouse ev_collision ev_other ev_draw ev_draw_begin ev_draw_end ev_draw_pre ev_draw_post ev_keypress ev_keyrelease ev_trigger ev_left_button ev_right_button ev_middle_button ev_no_button ev_left_press ev_right_press ev_middle_press ev_left_release ev_right_release ev_middle_release ev_mouse_enter ev_mouse_leave ev_mouse_wheel_up ev_mouse_wheel_down ev_global_left_button ev_global_right_button ev_global_middle_button ev_global_left_press ev_global_right_press ev_global_middle_press ev_global_left_release ev_global_right_release ev_global_middle_release ev_joystick1_left ev_joystick1_right ev_joystick1_up ev_joystick1_down ev_joystick1_button1 ev_joystick1_button2 ev_joystick1_button3 ev_joystick1_button4 ev_joystick1_button5 ev_joystick1_button6 ev_joystick1_button7 ev_joystick1_button8 ev_joystick2_left ev_joystick2_right ev_joystick2_up ev_joystick2_down ev_joystick2_button1 ev_joystick2_button2 ev_joystick2_button3 ev_joystick2_button4 ev_joystick2_button5 ev_joystick2_button6 ev_joystick2_button7 ev_joystick2_button8 ev_outside ev_boundary ev_game_start ev_game_end ev_room_start ev_room_end ev_no_more_lives ev_animation_end ev_end_of_path ev_no_more_health ev_close_button ev_user0 ev_user1 ev_user2 ev_user3 ev_user4 ev_user5 ev_user6 ev_user7 ev_user8 ev_user9 ev_user10 ev_user11 ev_user12 ev_user13 ev_user14 ev_user15 ev_step_normal ev_step_begin ev_step_end ev_gui ev_gui_begin ev_gui_end ev_cleanup ev_gesture ev_gesture_tap ev_gesture_double_tap ev_gesture_drag_start ev_gesture_dragging ev_gesture_drag_end ev_gesture_flick ev_gesture_pinch_start ev_gesture_pinch_in ev_gesture_pinch_out ev_gesture_pinch_end ev_gesture_rotate_start ev_gesture_rotating ev_gesture_rotate_end ev_global_gesture_tap ev_global_gesture_double_tap ev_global_gesture_drag_start ev_global_gesture_dragging ev_global_gesture_drag_end ev_global_gesture_flick ev_global_gesture_pinch_start ev_global_gesture_pinch_in ev_global_gesture_pinch_out ev_global_gesture_pinch_end ev_global_gesture_rotate_start ev_global_gesture_rotating ev_global_gesture_rotate_end vk_nokey vk_anykey vk_enter vk_return vk_shift vk_control vk_alt vk_escape vk_space vk_backspace vk_tab vk_pause vk_printscreen vk_left vk_right vk_up vk_down vk_home vk_end vk_delete vk_insert vk_pageup vk_pagedown vk_f1 vk_f2 vk_f3 vk_f4 vk_f5 vk_f6 vk_f7 vk_f8 vk_f9 vk_f10 vk_f11 vk_f12 vk_numpad0 vk_numpad1 vk_numpad2 vk_numpad3 vk_numpad4 vk_numpad5 vk_numpad6 vk_numpad7 vk_numpad8 vk_numpad9 vk_divide vk_multiply vk_subtract vk_add vk_decimal vk_lshift vk_lcontrol vk_lalt vk_rshift vk_rcontrol vk_ralt  mb_any mb_none mb_left mb_right mb_middle c_aqua c_black c_blue c_dkgray c_fuchsia c_gray c_green c_lime c_ltgray c_maroon c_navy c_olive c_purple c_red c_silver c_teal c_white c_yellow c_orange fa_left fa_center fa_right fa_top fa_middle fa_bottom pr_pointlist pr_linelist pr_linestrip pr_trianglelist pr_trianglestrip pr_trianglefan bm_complex bm_normal bm_add bm_max bm_subtract bm_zero bm_one bm_src_colour bm_inv_src_colour bm_src_color bm_inv_src_color bm_src_alpha bm_inv_src_alpha bm_dest_alpha bm_inv_dest_alpha bm_dest_colour bm_inv_dest_colour bm_dest_color bm_inv_dest_color bm_src_alpha_sat tf_point tf_linear tf_anisotropic mip_off mip_on mip_markedonly audio_falloff_none audio_falloff_inverse_distance audio_falloff_inverse_distance_clamped audio_falloff_linear_distance audio_falloff_linear_distance_clamped audio_falloff_exponent_distance audio_falloff_exponent_distance_clamped audio_old_system audio_new_system audio_mono audio_stereo audio_3d cr_default cr_none cr_arrow cr_cross cr_beam cr_size_nesw cr_size_ns cr_size_nwse cr_size_we cr_uparrow cr_hourglass cr_drag cr_appstart cr_handpoint cr_size_all spritespeed_framespersecond spritespeed_framespergameframe asset_object asset_unknown asset_sprite asset_sound asset_room asset_path asset_script asset_font asset_timeline asset_tiles asset_shader fa_readonly fa_hidden fa_sysfile fa_volumeid fa_directory fa_archive  ds_type_map ds_type_list ds_type_stack ds_type_queue ds_type_grid ds_type_priority ef_explosion ef_ring ef_ellipse ef_firework ef_smoke ef_smokeup ef_star ef_spark ef_flare ef_cloud ef_rain ef_snow pt_shape_pixel pt_shape_disk pt_shape_square pt_shape_line pt_shape_star pt_shape_circle pt_shape_ring pt_shape_sphere pt_shape_flare pt_shape_spark pt_shape_explosion pt_shape_cloud pt_shape_smoke pt_shape_snow ps_distr_linear ps_distr_gaussian ps_distr_invgaussian ps_shape_rectangle ps_shape_ellipse ps_shape_diamond ps_shape_line ty_real ty_string dll_cdecl dll_stdcall matrix_view matrix_projection matrix_world os_win32 os_windows os_macosx os_ios os_android os_symbian os_linux os_unknown os_winphone os_tizen os_win8native os_wiiu os_3ds  os_psvita os_bb10 os_ps4 os_xboxone os_ps3 os_xbox360 os_uwp os_tvos os_switch browser_not_a_browser browser_unknown browser_ie browser_firefox browser_chrome browser_safari browser_safari_mobile browser_opera browser_tizen browser_edge browser_windows_store browser_ie_mobile  device_ios_unknown device_ios_iphone device_ios_iphone_retina device_ios_ipad device_ios_ipad_retina device_ios_iphone5 device_ios_iphone6 device_ios_iphone6plus device_emulator device_tablet display_landscape display_landscape_flipped display_portrait display_portrait_flipped tm_sleep tm_countvsyncs of_challenge_win of_challen ge_lose of_challenge_tie leaderboard_type_number leaderboard_type_time_mins_secs cmpfunc_never cmpfunc_less cmpfunc_equal cmpfunc_lessequal cmpfunc_greater cmpfunc_notequal cmpfunc_greaterequal cmpfunc_always cull_noculling cull_clockwise cull_counterclockwise lighttype_dir lighttype_point iap_ev_storeload iap_ev_product iap_ev_purchase iap_ev_consume iap_ev_restore iap_storeload_ok iap_storeload_failed iap_status_uninitialised iap_status_unavailable iap_status_loading iap_status_available iap_status_processing iap_status_restoring iap_failed iap_unavailable iap_available iap_purchased iap_canceled iap_refunded fb_login_default fb_login_fallback_to_webview fb_login_no_fallback_to_webview fb_login_forcing_webview fb_login_use_system_account fb_login_forcing_safari  phy_joint_anchor_1_x phy_joint_anchor_1_y phy_joint_anchor_2_x phy_joint_anchor_2_y phy_joint_reaction_force_x phy_joint_reaction_force_y phy_joint_reaction_torque phy_joint_motor_speed phy_joint_angle phy_joint_motor_torque phy_joint_max_motor_torque phy_joint_translation phy_joint_speed phy_joint_motor_force phy_joint_max_motor_force phy_joint_length_1 phy_joint_length_2 phy_joint_damping_ratio phy_joint_frequency phy_joint_lower_angle_limit phy_joint_upper_angle_limit phy_joint_angle_limits phy_joint_max_length phy_joint_max_torque phy_joint_max_force phy_debug_render_aabb phy_debug_render_collision_pairs phy_debug_render_coms phy_debug_render_core_shapes phy_debug_render_joints phy_debug_render_obb phy_debug_render_shapes  phy_particle_flag_water phy_particle_flag_zombie phy_particle_flag_wall phy_particle_flag_spring phy_particle_flag_elastic phy_particle_flag_viscous phy_particle_flag_powder phy_particle_flag_tensile phy_particle_flag_colourmixing phy_particle_flag_colormixing phy_particle_group_flag_solid phy_particle_group_flag_rigid phy_particle_data_flag_typeflags phy_particle_data_flag_position phy_particle_data_flag_velocity phy_particle_data_flag_colour phy_particle_data_flag_color phy_particle_data_flag_category  achievement_our_info achievement_friends_info achievement_leaderboard_info achievement_achievement_info achievement_filter_all_players achievement_filter_friends_only achievement_filter_favorites_only achievement_type_achievement_challenge achievement_type_score_challenge achievement_pic_loaded  achievement_show_ui achievement_show_profile achievement_show_leaderboard achievement_show_achievement achievement_show_bank achievement_show_friend_picker achievement_show_purchase_prompt network_socket_tcp network_socket_udp network_socket_bluetooth network_type_connect network_type_disconnect network_type_data network_type_non_blocking_connect network_config_connect_timeout network_config_use_non_blocking_socket network_config_enable_reliable_udp network_config_disable_reliable_udp buffer_fixed buffer_grow buffer_wrap buffer_fast buffer_vbuffer buffer_network buffer_u8 buffer_s8 buffer_u16 buffer_s16 buffer_u32 buffer_s32 buffer_u64 buffer_f16 buffer_f32 buffer_f64 buffer_bool buffer_text buffer_string buffer_surface_copy buffer_seek_start buffer_seek_relative buffer_seek_end buffer_generalerror buffer_outofspace buffer_outofbounds buffer_invalidtype  text_type button_type input_type ANSI_CHARSET DEFAULT_CHARSET EASTEUROPE_CHARSET RUSSIAN_CHARSET SYMBOL_CHARSET SHIFTJIS_CHARSET HANGEUL_CHARSET GB2312_CHARSET CHINESEBIG5_CHARSET JOHAB_CHARSET HEBREW_CHARSET ARABIC_CHARSET GREEK_CHARSET TURKISH_CHARSET VIETNAMESE_CHARSET THAI_CHARSET MAC_CHARSET BALTIC_CHARSET OEM_CHARSET  gp_face1 gp_face2 gp_face3 gp_face4 gp_shoulderl gp_shoulderr gp_shoulderlb gp_shoulderrb gp_select gp_start gp_stickl gp_stickr gp_padu gp_padd gp_padl gp_padr gp_axislh gp_axislv gp_axisrh gp_axisrv ov_friends ov_community ov_players ov_settings ov_gamegroup ov_achievements lb_sort_none lb_sort_ascending lb_sort_descending lb_disp_none lb_disp_numeric lb_disp_time_sec lb_disp_time_ms ugc_result_success ugc_filetype_community ugc_filetype_microtrans ugc_visibility_public ugc_visibility_friends_only ugc_visibility_private ugc_query_RankedByVote ugc_query_RankedByPublicationDate ugc_query_AcceptedForGameRankedByAcceptanceDate ugc_query_RankedByTrend ugc_query_FavoritedByFriendsRankedByPublicationDate ugc_query_CreatedByFriendsRankedByPublicationDate ugc_query_RankedByNumTimesReported ugc_query_CreatedByFollowedUsersRankedByPublicationDate ugc_query_NotYetRated ugc_query_RankedByTotalVotesAsc ugc_query_RankedByVotesUp ugc_query_RankedByTextSearch ugc_sortorder_CreationOrderDesc ugc_sortorder_CreationOrderAsc ugc_sortorder_TitleAsc ugc_sortorder_LastUpdatedDesc ugc_sortorder_SubscriptionDateDesc ugc_sortorder_VoteScoreDesc ugc_sortorder_ForModeration ugc_list_Published ugc_list_VotedOn ugc_list_VotedUp ugc_list_VotedDown ugc_list_WillVoteLater ugc_list_Favorited ugc_list_Subscribed ugc_list_UsedOrPlayed ugc_list_Followed ugc_match_Items ugc_match_Items_Mtx ugc_match_Items_ReadyToUse ugc_match_Collections ugc_match_Artwork ugc_match_Videos ugc_match_Screenshots ugc_match_AllGuides ugc_match_WebGuides ugc_match_IntegratedGuides ugc_match_UsableInGame ugc_match_ControllerBindings  vertex_usage_position vertex_usage_colour vertex_usage_color vertex_usage_normal vertex_usage_texcoord vertex_usage_textcoord vertex_usage_blendweight vertex_usage_blendindices vertex_usage_psize vertex_usage_tangent vertex_usage_binormal vertex_usage_fog vertex_usage_depth vertex_usage_sample vertex_type_float1 vertex_type_float2 vertex_type_float3 vertex_type_float4 vertex_type_colour vertex_type_color vertex_type_ubyte4 layerelementtype_undefined layerelementtype_background layerelementtype_instance layerelementtype_oldtilemap layerelementtype_sprite layerelementtype_tilemap layerelementtype_particlesystem layerelementtype_tile tile_rotate tile_flip tile_mirror tile_index_mask kbv_type_default kbv_type_ascii kbv_type_url kbv_type_email kbv_type_numbers kbv_type_phone kbv_type_phone_name kbv_returnkey_default kbv_returnkey_go kbv_returnkey_google kbv_returnkey_join kbv_returnkey_next kbv_returnkey_route kbv_returnkey_search kbv_returnkey_send kbv_returnkey_yahoo kbv_returnkey_done kbv_returnkey_continue kbv_returnkey_emergency kbv_autocapitalize_none kbv_autocapitalize_words kbv_autocapitalize_sentences kbv_autocapitalize_characters",
+symbol:"argument_relative argument argument0 argument1 argument2 argument3 argument4 argument5 argument6 argument7 argument8 argument9 argument10 argument11 argument12 argument13 argument14 argument15 argument_count x y xprevious yprevious xstart ystart hspeed vspeed direction speed friction gravity gravity_direction path_index path_position path_positionprevious path_speed path_scale path_orientation path_endaction object_index id solid persistent mask_index instance_count instance_id room_speed fps fps_real current_time current_year current_month current_day current_weekday current_hour current_minute current_second alarm timeline_index timeline_position timeline_speed timeline_running timeline_loop room room_first room_last room_width room_height room_caption room_persistent score lives health show_score show_lives show_health caption_score caption_lives caption_health event_type event_number event_object event_action application_surface gamemaker_pro gamemaker_registered gamemaker_version error_occurred error_last debug_mode keyboard_key keyboard_lastkey keyboard_lastchar keyboard_string mouse_x mouse_y mouse_button mouse_lastbutton cursor_sprite visible sprite_index sprite_width sprite_height sprite_xoffset sprite_yoffset image_number image_index image_speed depth image_xscale image_yscale image_angle image_alpha image_blend bbox_left bbox_right bbox_top bbox_bottom layer background_colour  background_showcolour background_color background_showcolor view_enabled view_current view_visible view_xview view_yview view_wview view_hview view_xport view_yport view_wport view_hport view_angle view_hborder view_vborder view_hspeed view_vspeed view_object view_surface_id view_camera game_id game_display_name game_project_name game_save_id working_directory temp_directory program_directory browser_width browser_height os_type os_device os_browser os_version display_aa async_load delta_time webgl_enabled event_data iap_data phy_rotation phy_position_x phy_position_y phy_angular_velocity phy_linear_velocity_x phy_linear_velocity_y phy_speed_x phy_speed_y phy_speed phy_angular_damping phy_linear_damping phy_bullet phy_fixed_rotation phy_active phy_mass phy_inertia phy_com_x phy_com_y phy_dynamic phy_kinematic phy_sleeping phy_collision_points phy_collision_x phy_collision_y phy_col_normal_x phy_col_normal_y phy_position_xprevious phy_position_yprevious"
+},
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.C_NUMBER_MODE]
+})})());hljs.registerLanguage("cmake",(()=>{"use strict";return e=>({name:"CMake",
+aliases:["cmake.in"],case_insensitive:!0,keywords:{
+keyword:"break cmake_host_system_information cmake_minimum_required cmake_parse_arguments cmake_policy configure_file continue elseif else endforeach endfunction endif endmacro endwhile execute_process file find_file find_library find_package find_path find_program foreach function get_cmake_property get_directory_property get_filename_component get_property if include include_guard list macro mark_as_advanced math message option return separate_arguments set_directory_properties set_property set site_name string unset variable_watch while add_compile_definitions add_compile_options add_custom_command add_custom_target add_definitions add_dependencies add_executable add_library add_link_options add_subdirectory add_test aux_source_directory build_command create_test_sourcelist define_property enable_language enable_testing export fltk_wrap_ui get_source_file_property get_target_property get_test_property include_directories include_external_msproject include_regular_expression install link_directories link_libraries load_cache project qt_wrap_cpp qt_wrap_ui remove_definitions set_source_files_properties set_target_properties set_tests_properties source_group target_compile_definitions target_compile_features target_compile_options target_include_directories target_link_directories target_link_libraries target_link_options target_sources try_compile try_run ctest_build ctest_configure ctest_coverage ctest_empty_binary_directory ctest_memcheck ctest_read_custom_files ctest_run_script ctest_sleep ctest_start ctest_submit ctest_test ctest_update ctest_upload build_name exec_program export_library_dependencies install_files install_programs install_targets load_command make_directory output_required_files remove subdir_depends subdirs use_mangled_mesa utility_source variable_requires write_file qt5_use_modules qt5_use_package qt5_wrap_cpp on off true false and or not command policy target test exists is_newer_than is_directory is_symlink is_absolute matches less greater equal less_equal greater_equal strless strgreater strequal strless_equal strgreater_equal version_less version_greater version_equal version_less_equal version_greater_equal in_list defined"
+},contains:[{className:"variable",begin:/\$\{/,end:/\}/
+},e.HASH_COMMENT_MODE,e.QUOTE_STRING_MODE,e.NUMBER_MODE]})})());hljs.registerLanguage("xml",(()=>{"use strict";function e(e){
+return e?"string"==typeof e?e:e.source:null}function n(e){return a("(?=",e,")")}
+function a(...n){return n.map((n=>e(n))).join("")}function s(...n){
+return"("+n.map((n=>e(n))).join("|")+")"}return e=>{
+const t=a(/[A-Z_]/,a("(",/[A-Z0-9_.-]+:/,")?"),/[A-Z0-9_.-]*/),i={
+className:"symbol",begin:"&[a-z]+;|&#[0-9]+;|&#x[a-f0-9]+;"},c={begin:"\\s",
+contains:[{className:"meta-keyword",begin:"#?[a-z_][a-z1-9_-]+",illegal:"\\n"}]
+},r=e.inherit(c,{begin:"\\(",end:"\\)"}),l=e.inherit(e.APOS_STRING_MODE,{
+className:"meta-string"}),g=e.inherit(e.QUOTE_STRING_MODE,{
+className:"meta-string"}),m={endsWithParent:!0,illegal:/</,relevance:0,
+contains:[{className:"attr",begin:"[A-Za-z0-9\\._:-]+",relevance:0},{
+begin:/=\s*/,relevance:0,contains:[{className:"string",endsParent:!0,variants:[{
+begin:/"/,end:/"/,contains:[i]},{begin:/'/,end:/'/,contains:[i]},{
+begin:/[^\s"'=<>`]+/}]}]}]};return{name:"HTML, XML",
+aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"],
+case_insensitive:!0,contains:[{className:"meta",begin:"<![a-z]",end:">",
+relevance:10,contains:[c,g,l,r,{begin:"\\[",end:"\\]",contains:[{
+className:"meta",begin:"<![a-z]",end:">",contains:[c,r,g,l]}]}]
+},e.COMMENT("\x3c!--","--\x3e",{relevance:10}),{begin:"<!\\[CDATA\\[",
+end:"\\]\\]>",relevance:10},i,{className:"meta",begin:/<\?xml/,end:/\?>/,
+relevance:10},{className:"tag",begin:"<style(?=\\s|>)",end:">",keywords:{
+name:"style"},contains:[m],starts:{end:"</style>",returnEnd:!0,
+subLanguage:["css","xml"]}},{className:"tag",begin:"<script(?=\\s|>)",end:">",
+keywords:{name:"script"},contains:[m],starts:{end:/<\/script>/,returnEnd:!0,
+subLanguage:["javascript","handlebars","xml"]}},{className:"tag",begin:/<>|<\/>/
+},{className:"tag",begin:a(/</,n(a(t,s(/\/>/,/>/,/\s/)))),end:/\/?>/,contains:[{
+className:"name",begin:t,relevance:0,starts:m}]},{className:"tag",
+begin:a(/<\//,n(a(t,/>/))),contains:[{className:"name",begin:t,relevance:0},{
+begin:/>/,relevance:0}]}]}}})());hljs.registerLanguage("markdown",(()=>{"use strict";function n(...n){
+return n.map((n=>{return(e=n)?"string"==typeof e?e:e.source:null;var e
+})).join("")}return e=>{const a={begin:/<\/?[A-Za-z_]/,end:">",
+subLanguage:"xml",relevance:0},i={variants:[{begin:/\[.+?\]\[.*?\]/,relevance:0
+},{begin:/\[.+?\]\(((data|javascript|mailto):|(?:http|ftp)s?:\/\/).*?\)/,
+relevance:2},{begin:n(/\[.+?\]\(/,/[A-Za-z][A-Za-z0-9+.-]*/,/:\/\/.*?\)/),
+relevance:2},{begin:/\[.+?\]\([./?&#].*?\)/,relevance:1},{
+begin:/\[.+?\]\(.*?\)/,relevance:0}],returnBegin:!0,contains:[{
+className:"string",relevance:0,begin:"\\[",end:"\\]",excludeBegin:!0,
+returnEnd:!0},{className:"link",relevance:0,begin:"\\]\\(",end:"\\)",
+excludeBegin:!0,excludeEnd:!0},{className:"symbol",relevance:0,begin:"\\]\\[",
+end:"\\]",excludeBegin:!0,excludeEnd:!0}]},s={className:"strong",contains:[],
+variants:[{begin:/_{2}/,end:/_{2}/},{begin:/\*{2}/,end:/\*{2}/}]},c={
+className:"emphasis",contains:[],variants:[{begin:/\*(?!\*)/,end:/\*/},{
+begin:/_(?!_)/,end:/_/,relevance:0}]};s.contains.push(c),c.contains.push(s)
+;let t=[a,i]
+;return s.contains=s.contains.concat(t),c.contains=c.contains.concat(t),
+t=t.concat(s,c),{name:"Markdown",aliases:["md","mkdown","mkd"],contains:[{
+className:"section",variants:[{begin:"^#{1,6}",end:"$",contains:t},{
+begin:"(?=^.+?\\n[=-]{2,}$)",contains:[{begin:"^[=-]*$"},{begin:"^",end:"\\n",
+contains:t}]}]},a,{className:"bullet",begin:"^[ \t]*([*+-]|(\\d+\\.))(?=\\s+)",
+end:"\\s+",excludeEnd:!0},s,c,{className:"quote",begin:"^>\\s+",contains:t,
+end:"$"},{className:"code",variants:[{begin:"(`{3,})(.|\\n)*?\\1`*[ ]*"},{
+begin:"(~{3,})(.|\\n)*?\\1~*[ ]*"},{begin:"```",end:"```+[ ]*$"},{begin:"~~~",
+end:"~~~+[ ]*$"},{begin:"`.+?`"},{begin:"(?=^( {4}|\\t))",contains:[{
+begin:"^( {4}|\\t)",end:"(\\n)$"}],relevance:0}]},{begin:"^[-\\*]{3,}",end:"$"
+},i,{begin:/^\[[^\n]+\]:/,returnBegin:!0,contains:[{className:"symbol",
+begin:/\[/,end:/\]/,excludeBegin:!0,excludeEnd:!0},{className:"link",
+begin:/:\s*/,end:/$/,excludeBegin:!0}]}]}}})());hljs.registerLanguage("diff",(()=>{"use strict";return e=>({name:"Diff",
+aliases:["patch"],contains:[{className:"meta",relevance:10,variants:[{
+begin:/^@@ +-\d+,\d+ +\+\d+,\d+ +@@/},{begin:/^\*\*\* +\d+,\d+ +\*\*\*\*$/},{
+begin:/^--- +\d+,\d+ +----$/}]},{className:"comment",variants:[{begin:/Index: /,
+end:/$/},{begin:/^index/,end:/$/},{begin:/={3,}/,end:/$/},{begin:/^-{3}/,end:/$/
+},{begin:/^\*{3} /,end:/$/},{begin:/^\+{3}/,end:/$/},{begin:/^\*{15}$/},{
+begin:/^diff --git/,end:/$/}]},{className:"addition",begin:/^\+/,end:/$/},{
+className:"deletion",begin:/^-/,end:/$/},{className:"addition",begin:/^!/,
+end:/$/}]})})());hljs.registerLanguage("c-like",(()=>{"use strict";return e=>{function t(e){
+return"(?:"+e+")?"}var n=e.COMMENT("//","$",{contains:[{begin:/\\\n/}]
+}),r="[a-zA-Z_]\\w*::",a="(decltype\\(auto\\)|"+t(r)+"[a-zA-Z_]\\w*"+t("<.*?>")+")",i={
+className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},s={className:"string",
+variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]},{
+begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",
+end:"'",illegal:"."},e.END_SAME_AS_BEGIN({
+begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={
+className:"number",variants:[{begin:"\\b(0b[01']+)"},{
+begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{
+begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"
+}],relevance:0},c={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{
+"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"
+},contains:[{begin:/\\\n/,relevance:0},e.inherit(s,{className:"meta-string"}),{
+className:"meta-string",begin:/<.*?>/,end:/$/,illegal:"\\n"
+},n,e.C_BLOCK_COMMENT_MODE]},l={className:"title",begin:t(r)+e.IDENT_RE,
+relevance:0},d=t(r)+e.IDENT_RE+"\\s*\\(",u={
+keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq",
+built_in:"std string wstring cin cout cerr clog stdin stdout stderr stringstream istringstream ostringstream auto_ptr deque list queue stack vector map set pair bitset multiset multimap unordered_set unordered_map unordered_multiset unordered_multimap priority_queue make_pair array shared_ptr abort terminate abs acos asin atan2 atan calloc ceil cosh cos exit exp fabs floor fmod fprintf fputs free frexp fscanf future isalnum isalpha iscntrl isdigit isgraph islower isprint ispunct isspace isupper isxdigit tolower toupper labs ldexp log10 log malloc realloc memchr memcmp memcpy memset modf pow printf putchar puts scanf sinh sin snprintf sprintf sqrt sscanf strcat strchr strcmp strcpy strcspn strlen strncat strncmp strncpy strpbrk strrchr strspn strstr tanh tan vfprintf vprintf vsprintf endl initializer_list unique_ptr _Bool complex _Complex imaginary _Imaginary",
+literal:"true false nullptr NULL"},m=[c,i,n,e.C_BLOCK_COMMENT_MODE,o,s],p={
+variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{
+beginKeywords:"new throw return else",end:/;/}],keywords:u,contains:m.concat([{
+begin:/\(/,end:/\)/,keywords:u,contains:m.concat(["self"]),relevance:0}]),
+relevance:0},_={className:"function",begin:"("+a+"[\\*&\\s]+)+"+d,
+returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:u,illegal:/[^\w\s\*&:<>]/,
+contains:[{begin:"decltype\\(auto\\)",keywords:u,relevance:0},{begin:d,
+returnBegin:!0,contains:[l],relevance:0},{className:"params",begin:/\(/,
+end:/\)/,keywords:u,relevance:0,contains:[n,e.C_BLOCK_COMMENT_MODE,s,o,i,{
+begin:/\(/,end:/\)/,keywords:u,relevance:0,
+contains:["self",n,e.C_BLOCK_COMMENT_MODE,s,o,i]}]
+},i,n,e.C_BLOCK_COMMENT_MODE,c]};return{
+aliases:["c","cc","h","c++","h++","hpp","hh","hxx","cxx"],keywords:u,
+disableAutodetect:!0,illegal:"</",contains:[].concat(p,_,m,[c,{
+begin:"\\b(deque|list|queue|priority_queue|pair|stack|vector|map|set|bitset|multiset|multimap|unordered_map|unordered_set|unordered_multiset|unordered_multimap|array)\\s*<",
+end:">",keywords:u,contains:["self",i]},{begin:e.IDENT_RE+"::",keywords:u},{
+className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/,
+contains:[{beginKeywords:"final class struct"},e.TITLE_MODE]}]),exports:{
+preprocessor:c,strings:s,keywords:u}}}})());hljs.registerLanguage("verilog",(()=>{"use strict";return e=>({name:"Verilog",
+aliases:["v","sv","svh"],case_insensitive:!1,keywords:{$pattern:/[\w\$]+/,
+keyword:"accept_on alias always always_comb always_ff always_latch and assert assign assume automatic before begin bind bins binsof bit break buf|0 bufif0 bufif1 byte case casex casez cell chandle checker class clocking cmos config const constraint context continue cover covergroup coverpoint cross deassign default defparam design disable dist do edge else end endcase endchecker endclass endclocking endconfig endfunction endgenerate endgroup endinterface endmodule endpackage endprimitive endprogram endproperty endspecify endsequence endtable endtask enum event eventually expect export extends extern final first_match for force foreach forever fork forkjoin function generate|5 genvar global highz0 highz1 if iff ifnone ignore_bins illegal_bins implements implies import incdir include initial inout input inside instance int integer interconnect interface intersect join join_any join_none large let liblist library local localparam logic longint macromodule matches medium modport module nand negedge nettype new nexttime nmos nor noshowcancelled not notif0 notif1 or output package packed parameter pmos posedge primitive priority program property protected pull0 pull1 pulldown pullup pulsestyle_ondetect pulsestyle_onevent pure rand randc randcase randsequence rcmos real realtime ref reg reject_on release repeat restrict return rnmos rpmos rtran rtranif0 rtranif1 s_always s_eventually s_nexttime s_until s_until_with scalared sequence shortint shortreal showcancelled signed small soft solve specify specparam static string strong strong0 strong1 struct super supply0 supply1 sync_accept_on sync_reject_on table tagged task this throughout time timeprecision timeunit tran tranif0 tranif1 tri tri0 tri1 triand trior trireg type typedef union unique unique0 unsigned until until_with untyped use uwire var vectored virtual void wait wait_order wand weak weak0 weak1 while wildcard wire with within wor xnor xor",
+literal:"null",
+built_in:"$finish $stop $exit $fatal $error $warning $info $realtime $time $printtimescale $bitstoreal $bitstoshortreal $itor $signed $cast $bits $stime $timeformat $realtobits $shortrealtobits $rtoi $unsigned $asserton $assertkill $assertpasson $assertfailon $assertnonvacuouson $assertoff $assertcontrol $assertpassoff $assertfailoff $assertvacuousoff $isunbounded $sampled $fell $changed $past_gclk $fell_gclk $changed_gclk $rising_gclk $steady_gclk $coverage_control $coverage_get $coverage_save $set_coverage_db_name $rose $stable $past $rose_gclk $stable_gclk $future_gclk $falling_gclk $changing_gclk $display $coverage_get_max $coverage_merge $get_coverage $load_coverage_db $typename $unpacked_dimensions $left $low $increment $clog2 $ln $log10 $exp $sqrt $pow $floor $ceil $sin $cos $tan $countbits $onehot $isunknown $fatal $warning $dimensions $right $high $size $asin $acos $atan $atan2 $hypot $sinh $cosh $tanh $asinh $acosh $atanh $countones $onehot0 $error $info $random $dist_chi_square $dist_erlang $dist_exponential $dist_normal $dist_poisson $dist_t $dist_uniform $q_initialize $q_remove $q_exam $async$and$array $async$nand$array $async$or$array $async$nor$array $sync$and$array $sync$nand$array $sync$or$array $sync$nor$array $q_add $q_full $psprintf $async$and$plane $async$nand$plane $async$or$plane $async$nor$plane $sync$and$plane $sync$nand$plane $sync$or$plane $sync$nor$plane $system $display $displayb $displayh $displayo $strobe $strobeb $strobeh $strobeo $write $readmemb $readmemh $writememh $value$plusargs $dumpvars $dumpon $dumplimit $dumpports $dumpportson $dumpportslimit $writeb $writeh $writeo $monitor $monitorb $monitorh $monitoro $writememb $dumpfile $dumpoff $dumpall $dumpflush $dumpportsoff $dumpportsall $dumpportsflush $fclose $fdisplay $fdisplayb $fdisplayh $fdisplayo $fstrobe $fstrobeb $fstrobeh $fstrobeo $swrite $swriteb $swriteh $swriteo $fscanf $fread $fseek $fflush $feof $fopen $fwrite $fwriteb $fwriteh $fwriteo $fmonitor $fmonitorb $fmonitorh $fmonitoro $sformat $sformatf $fgetc $ungetc $fgets $sscanf $rewind $ftell $ferror"
+},contains:[e.C_BLOCK_COMMENT_MODE,e.C_LINE_COMMENT_MODE,e.QUOTE_STRING_MODE,{
+className:"number",contains:[e.BACKSLASH_ESCAPE],variants:[{
+begin:"\\b((\\d+'(b|h|o|d|B|H|O|D))[0-9xzXZa-fA-F_]+)"},{
+begin:"\\B(('(b|h|o|d|B|H|O|D))[0-9xzXZa-fA-F_]+)"},{begin:"\\b([0-9_])+",
+relevance:0}]},{className:"variable",variants:[{begin:"#\\((?!parameter).+\\)"
+},{begin:"\\.\\w+",relevance:0}]},{className:"meta",begin:"`",end:"$",keywords:{
+"meta-keyword":"define __FILE__ __LINE__ begin_keywords celldefine default_nettype define else elsif end_keywords endcelldefine endif ifdef ifndef include line nounconnected_drive pragma resetall timescale unconnected_drive undef undefineall"
+},relevance:0}]})})());hljs.registerLanguage("reasonml",(()=>{"use strict";return e=>{
+const n="~?[a-z$_][0-9a-zA-Z$_]*",a="`?[A-Z$_][0-9a-zA-Z$_]*",s="("+["||","++","**","+.","*","/","*.","/.","..."].map((e=>e.split("").map((e=>"\\"+e)).join(""))).join("|")+"|\\|>|&&|==|===)",i="\\s+"+s+"\\s+",r={
+keyword:"and as asr assert begin class constraint do done downto else end exception external for fun function functor if in include inherit initializer land lazy let lor lsl lsr lxor match method mod module mutable new nonrec object of open or private rec sig struct then to try type val virtual when while with",
+built_in:"array bool bytes char exn|5 float int int32 int64 list lazy_t|5 nativeint|5 ref string unit ",
+literal:"true false"
+},l="\\b(0[xX][a-fA-F0-9_]+[Lln]?|0[oO][0-7_]+[Lln]?|0[bB][01_]+[Lln]?|[0-9][0-9_]*([Lln]|(\\.[0-9_]*)?([eE][-+]?[0-9_]+)?)?)",t={
+className:"number",relevance:0,variants:[{begin:l},{begin:"\\(-"+l+"\\)"}]},c={
+className:"operator",relevance:0,begin:s},o=[{className:"identifier",
+relevance:0,begin:n},c,t],g=[e.QUOTE_STRING_MODE,c,{className:"module",
+begin:"\\b"+a,returnBegin:!0,end:".",contains:[{className:"identifier",begin:a,
+relevance:0}]}],b=[{className:"module",begin:"\\b"+a,returnBegin:!0,end:".",
+relevance:0,contains:[{className:"identifier",begin:a,relevance:0}]}],m={
+className:"function",relevance:0,keywords:r,variants:[{
+begin:"\\s(\\(\\.?.*?\\)|"+n+")\\s*=>",end:"\\s*=>",returnBegin:!0,relevance:0,
+contains:[{className:"params",variants:[{begin:n},{
+begin:"~?[a-z$_][0-9a-zA-Z$_]*(s*:s*[a-z$_][0-9a-z$_]*((s*('?[a-z$_][0-9a-z$_]*s*(,'?[a-z$_][0-9a-z$_]*)*)?s*))?)?(s*:s*[a-z$_][0-9a-z$_]*((s*('?[a-z$_][0-9a-z$_]*s*(,'?[a-z$_][0-9a-z$_]*)*)?s*))?)?"
+},{begin:/\(\s*\)/}]}]},{begin:"\\s\\(\\.?[^;\\|]*\\)\\s*=>",end:"\\s=>",
+returnBegin:!0,relevance:0,contains:[{className:"params",relevance:0,variants:[{
+begin:n,end:"(,|\\n|\\))",relevance:0,contains:[c,{className:"typing",begin:":",
+end:"(,|\\n)",returnBegin:!0,relevance:0,contains:b}]}]}]},{
+begin:"\\(\\.\\s"+n+"\\)\\s*=>"}]};g.push(m);const d={className:"constructor",
+begin:a+"\\(",end:"\\)",illegal:"\\n",keywords:r,
+contains:[e.QUOTE_STRING_MODE,c,{className:"params",begin:"\\b"+n}]},u={
+className:"pattern-match",begin:"\\|",returnBegin:!0,keywords:r,end:"=>",
+relevance:0,contains:[d,c,{relevance:0,className:"constructor",begin:a}]},_={
+className:"module-access",keywords:r,returnBegin:!0,variants:[{
+begin:"\\b("+a+"\\.)+"+n},{begin:"\\b("+a+"\\.)+\\(",end:"\\)",returnBegin:!0,
+contains:[m,{begin:"\\(",end:"\\)",skip:!0}].concat(g)},{
+begin:"\\b("+a+"\\.)+\\{",end:/\}/}],contains:g};return b.push(_),{
+name:"ReasonML",aliases:["re"],keywords:r,illegal:"(:-|:=|\\$\\{|\\+=)",
+contains:[e.COMMENT("/\\*","\\*/",{illegal:"^(#,\\/\\/)"}),{
+className:"character",begin:"'(\\\\[^']+|[^'])'",illegal:"\\n",relevance:0
+},e.QUOTE_STRING_MODE,{className:"literal",begin:"\\(\\)",relevance:0},{
+className:"literal",begin:"\\[\\|",end:"\\|\\]",relevance:0,contains:o},{
+className:"literal",begin:"\\[",end:"\\]",relevance:0,contains:o},d,{
+className:"operator",begin:i,illegal:"--\x3e",relevance:0
+},t,e.C_LINE_COMMENT_MODE,u,m,{className:"module-def",
+begin:"\\bmodule\\s+"+n+"\\s+"+a+"\\s+=\\s+\\{",end:/\}/,returnBegin:!0,
+keywords:r,relevance:0,contains:[{className:"module",relevance:0,begin:a},{
+begin:/\{/,end:/\}/,skip:!0}].concat(g)},_]}}})());hljs.registerLanguage("arduino",(()=>{"use strict";return e=>{const t=(e=>{
+const t=(e=>{function t(e){return"(?:"+e+")?"}var r=e.COMMENT("//","$",{
+contains:[{begin:/\\\n/}]
+}),n="[a-zA-Z_]\\w*::",i="(decltype\\(auto\\)|"+t(n)+"[a-zA-Z_]\\w*"+t("<.*?>")+")",a={
+className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},s={className:"string",
+variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]},{
+begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",
+end:"'",illegal:"."},e.END_SAME_AS_BEGIN({
+begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={
+className:"number",variants:[{begin:"\\b(0b[01']+)"},{
+begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{
+begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"
+}],relevance:0},l={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{
+"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"
+},contains:[{begin:/\\\n/,relevance:0},e.inherit(s,{className:"meta-string"}),{
+className:"meta-string",begin:/<.*?>/,end:/$/,illegal:"\\n"
+},r,e.C_BLOCK_COMMENT_MODE]},c={className:"title",begin:t(n)+e.IDENT_RE,
+relevance:0},d=t(n)+e.IDENT_RE+"\\s*\\(",u={
+keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq",
+built_in:"std string wstring cin cout cerr clog stdin stdout stderr stringstream istringstream ostringstream auto_ptr deque list queue stack vector map set pair bitset multiset multimap unordered_set unordered_map unordered_multiset unordered_multimap priority_queue make_pair array shared_ptr abort terminate abs acos asin atan2 atan calloc ceil cosh cos exit exp fabs floor fmod fprintf fputs free frexp fscanf future isalnum isalpha iscntrl isdigit isgraph islower isprint ispunct isspace isupper isxdigit tolower toupper labs ldexp log10 log malloc realloc memchr memcmp memcpy memset modf pow printf putchar puts scanf sinh sin snprintf sprintf sqrt sscanf strcat strchr strcmp strcpy strcspn strlen strncat strncmp strncpy strpbrk strrchr strspn strstr tanh tan vfprintf vprintf vsprintf endl initializer_list unique_ptr _Bool complex _Complex imaginary _Imaginary",
+literal:"true false nullptr NULL"},m=[l,a,r,e.C_BLOCK_COMMENT_MODE,o,s],p={
+variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{
+beginKeywords:"new throw return else",end:/;/}],keywords:u,contains:m.concat([{
+begin:/\(/,end:/\)/,keywords:u,contains:m.concat(["self"]),relevance:0}]),
+relevance:0},g={className:"function",begin:"("+i+"[\\*&\\s]+)+"+d,
+returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:u,illegal:/[^\w\s\*&:<>]/,
+contains:[{begin:"decltype\\(auto\\)",keywords:u,relevance:0},{begin:d,
+returnBegin:!0,contains:[c],relevance:0},{className:"params",begin:/\(/,
+end:/\)/,keywords:u,relevance:0,contains:[r,e.C_BLOCK_COMMENT_MODE,s,o,a,{
+begin:/\(/,end:/\)/,keywords:u,relevance:0,
+contains:["self",r,e.C_BLOCK_COMMENT_MODE,s,o,a]}]
+},a,r,e.C_BLOCK_COMMENT_MODE,l]};return{
+aliases:["c","cc","h","c++","h++","hpp","hh","hxx","cxx"],keywords:u,
+disableAutodetect:!0,illegal:"</",contains:[].concat(p,g,m,[l,{
+begin:"\\b(deque|list|queue|priority_queue|pair|stack|vector|map|set|bitset|multiset|multimap|unordered_map|unordered_set|unordered_multiset|unordered_multimap|array)\\s*<",
+end:">",keywords:u,contains:["self",a]},{begin:e.IDENT_RE+"::",keywords:u},{
+className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/,
+contains:[{beginKeywords:"final class struct"},e.TITLE_MODE]}]),exports:{
+preprocessor:l,strings:s,keywords:u}}})(e)
+;return t.disableAutodetect=!1,t.name="C++",
+t.aliases=["cc","c++","h++","hpp","hh","hxx","cxx"],t})(e),r=t.keywords
+;return r.keyword+=" boolean byte word String",
+r.literal+=" DIGITAL_MESSAGE FIRMATA_STRING ANALOG_MESSAGE REPORT_DIGITAL REPORT_ANALOG INPUT_PULLUP SET_PIN_MODE INTERNAL2V56 SYSTEM_RESET LED_BUILTIN INTERNAL1V1 SYSEX_START INTERNAL EXTERNAL DEFAULT OUTPUT INPUT HIGH LOW",
+r.built_in+=" setup loop KeyboardController MouseController SoftwareSerial EthernetServer EthernetClient LiquidCrystal RobotControl GSMVoiceCall EthernetUDP EsploraTFT HttpClient RobotMotor WiFiClient GSMScanner FileSystem Scheduler GSMServer YunClient YunServer IPAddress GSMClient GSMModem Keyboard Ethernet Console GSMBand Esplora Stepper Process WiFiUDP GSM_SMS Mailbox USBHost Firmata PImage Client Server GSMPIN FileIO Bridge Serial EEPROM Stream Mouse Audio Servo File Task GPRS WiFi Wire TFT GSM SPI SD runShellCommandAsynchronously analogWriteResolution retrieveCallingNumber printFirmwareVersion analogReadResolution sendDigitalPortPair noListenOnLocalhost readJoystickButton setFirmwareVersion readJoystickSwitch scrollDisplayRight getVoiceCallStatus scrollDisplayLeft writeMicroseconds delayMicroseconds beginTransmission getSignalStrength runAsynchronously getAsynchronously listenOnLocalhost getCurrentCarrier readAccelerometer messageAvailable sendDigitalPorts lineFollowConfig countryNameWrite runShellCommand readStringUntil rewindDirectory readTemperature setClockDivider readLightSensor endTransmission analogReference detachInterrupt countryNameRead attachInterrupt encryptionType readBytesUntil robotNameWrite readMicrophone robotNameRead cityNameWrite userNameWrite readJoystickY readJoystickX mouseReleased openNextFile scanNetworks noInterrupts digitalWrite beginSpeaker mousePressed isActionDone mouseDragged displayLogos noAutoscroll addParameter remoteNumber getModifiers keyboardRead userNameRead waitContinue processInput parseCommand printVersion readNetworks writeMessage blinkVersion cityNameRead readMessage setDataMode parsePacket isListening setBitOrder beginPacket isDirectory motorsWrite drawCompass digitalRead clearScreen serialEvent rightToLeft setTextSize leftToRight requestFrom keyReleased compassRead analogWrite interrupts WiFiServer disconnect playMelody parseFloat autoscroll getPINUsed setPINUsed setTimeout sendAnalog readSlider analogRead beginWrite createChar motorsStop keyPressed tempoWrite readButton subnetMask debugPrint macAddress writeGreen randomSeed attachGPRS readString sendString remotePort releaseAll mouseMoved background getXChange getYChange answerCall getResult voiceCall endPacket constrain getSocket writeJSON getButton available connected findUntil readBytes exitValue readGreen writeBlue startLoop IPAddress isPressed sendSysex pauseMode gatewayIP setCursor getOemKey tuneWrite noDisplay loadImage switchPIN onRequest onReceive changePIN playFile noBuffer parseInt overflow checkPIN knobRead beginTFT bitClear updateIR bitWrite position writeRGB highByte writeRed setSpeed readBlue noStroke remoteIP transfer shutdown hangCall beginSMS endWrite attached maintain noCursor checkReg checkPUK shiftOut isValid shiftIn pulseIn connect println localIP pinMode getIMEI display noBlink process getBand running beginSD drawBMP lowByte setBand release bitRead prepare pointTo readRed setMode noFill remove listen stroke detach attach noTone exists buffer height bitSet circle config cursor random IRread setDNS endSMS getKey micros millis begin print write ready flush width isPIN blink clear press mkdir rmdir close point yield image BSSID click delay read text move peek beep rect line open seek fill size turn stop home find step tone sqrt RSSI SSID end bit tan cos sin pow map abs max min get run put",
+t.name="Arduino",t.aliases=["ino"],t.supersetOf="cpp",t}})());hljs.registerLanguage("accesslog",(()=>{"use strict";return e=>{
+const n=["GET","POST","HEAD","PUT","DELETE","CONNECT","OPTIONS","PATCH","TRACE"]
+;return{name:"Apache Access Log",contains:[{className:"number",
+begin:"^\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}(:\\d{1,5})?\\b",relevance:5},{
+className:"number",begin:"\\b\\d+\\b",relevance:0},{className:"string",
+begin:'"('+n.join("|")+")",end:'"',keywords:n.join(" "),illegal:"\\n",
+relevance:5,contains:[{begin:"HTTP/[12]\\.\\d",relevance:5}]},{
+className:"string",begin:/\[\d[^\]\n]{8,}\]/,illegal:"\\n",relevance:1},{
+className:"string",begin:/\[/,end:/\]/,illegal:"\\n",relevance:0},{
+className:"string",begin:'"Mozilla/\\d\\.\\d \\(',end:'"',illegal:"\\n",
+relevance:3},{className:"string",begin:'"',end:'"',illegal:"\\n",relevance:0}]}}
+})());hljs.registerLanguage("d",(()=>{"use strict";return e=>{const a={
+$pattern:e.UNDERSCORE_IDENT_RE,
+keyword:"abstract alias align asm assert auto body break byte case cast catch class const continue debug default delete deprecated do else enum export extern final finally for foreach foreach_reverse|10 goto if immutable import in inout int interface invariant is lazy macro mixin module new nothrow out override package pragma private protected public pure ref return scope shared static struct super switch synchronized template this throw try typedef typeid typeof union unittest version void volatile while with __FILE__ __LINE__ __gshared|10 __thread __traits __DATE__ __EOF__ __TIME__ __TIMESTAMP__ __VENDOR__ __VERSION__",
+built_in:"bool cdouble cent cfloat char creal dchar delegate double dstring float function idouble ifloat ireal long real short string ubyte ucent uint ulong ushort wchar wstring",
+literal:"false null true"
+},d="((0|[1-9][\\d_]*)|0[bB][01_]+|0[xX]([\\da-fA-F][\\da-fA-F_]*|_[\\da-fA-F][\\da-fA-F_]*))",n="\\\\(['\"\\?\\\\abfnrtv]|u[\\dA-Fa-f]{4}|[0-7]{1,3}|x[\\dA-Fa-f]{2}|U[\\dA-Fa-f]{8})|&[a-zA-Z\\d]{2,};",t={
+className:"number",begin:"\\b"+d+"(L|u|U|Lu|LU|uL|UL)?",relevance:0},_={
+className:"number",
+begin:"\\b(((0[xX](([\\da-fA-F][\\da-fA-F_]*|_[\\da-fA-F][\\da-fA-F_]*)\\.([\\da-fA-F][\\da-fA-F_]*|_[\\da-fA-F][\\da-fA-F_]*)|\\.?([\\da-fA-F][\\da-fA-F_]*|_[\\da-fA-F][\\da-fA-F_]*))[pP][+-]?(0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d))|((0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d)(\\.\\d*|([eE][+-]?(0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d)))|\\d+\\.(0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d)(0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d)|\\.(0|[1-9][\\d_]*)([eE][+-]?(0|[1-9][\\d_]*|\\d[\\d_]*|[\\d_]+?\\d))?))([fF]|L|i|[fF]i|Li)?|"+d+"(i|[fF]i|Li))",
+relevance:0},r={className:"string",begin:"'("+n+"|.)",end:"'",illegal:"."},i={
+className:"string",begin:'"',contains:[{begin:n,relevance:0}],end:'"[cwd]?'
+},s=e.COMMENT("\\/\\+","\\+\\/",{contains:["self"],relevance:10});return{
+name:"D",keywords:a,contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,s,{
+className:"string",begin:'x"[\\da-fA-F\\s\\n\\r]*"[cwd]?',relevance:10},i,{
+className:"string",begin:'[rq]"',end:'"[cwd]?',relevance:5},{className:"string",
+begin:"`",end:"`[cwd]?"},{className:"string",begin:'q"\\{',end:'\\}"'},_,t,r,{
+className:"meta",begin:"^#!",end:"$",relevance:5},{className:"meta",
+begin:"#(line)",end:"$",relevance:5},{className:"keyword",
+begin:"@[a-zA-Z_][a-zA-Z_\\d]*"}]}}})());hljs.registerLanguage("haml",(()=>{"use strict";return e=>({name:"HAML",
+case_insensitive:!0,contains:[{className:"meta",
+begin:"^!!!( (5|1\\.1|Strict|Frameset|Basic|Mobile|RDFa|XML\\b.*))?$",
+relevance:10},e.COMMENT("^\\s*(!=#|=#|-#|/).*$",!1,{relevance:0}),{
+begin:"^\\s*(-|=|!=)(?!#)",starts:{end:"\\n",subLanguage:"ruby"}},{
+className:"tag",begin:"^\\s*%",contains:[{className:"selector-tag",begin:"\\w+"
+},{className:"selector-id",begin:"#[\\w-]+"},{className:"selector-class",
+begin:"\\.[\\w-]+"},{begin:/\{\s*/,end:/\s*\}/,contains:[{begin:":\\w+\\s*=>",
+end:",\\s+",returnBegin:!0,endsWithParent:!0,contains:[{className:"attr",
+begin:":\\w+"},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{begin:"\\w+",relevance:0
+}]}]},{begin:"\\(\\s*",end:"\\s*\\)",excludeEnd:!0,contains:[{begin:"\\w+\\s*=",
+end:"\\s+",returnBegin:!0,endsWithParent:!0,contains:[{className:"attr",
+begin:"\\w+",relevance:0},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{begin:"\\w+",
+relevance:0}]}]}]},{begin:"^\\s*[=~]\\s*"},{begin:/#\{/,starts:{end:/\}/,
+subLanguage:"ruby"}}]})})());hljs.registerLanguage("ebnf",(()=>{"use strict";return a=>{
+const e=a.COMMENT(/\(\*/,/\*\)/);return{name:"Extended Backus-Naur Form",
+illegal:/\S/,contains:[e,{className:"attribute",
+begin:/^[ ]*[a-zA-Z][a-zA-Z_-]*([\s_-]+[a-zA-Z][a-zA-Z]*)*/},{begin:/=/,
+end:/[.;]/,contains:[e,{className:"meta",begin:/\?.*\?/},{className:"string",
+variants:[a.APOS_STRING_MODE,a.QUOTE_STRING_MODE,{begin:"`",end:"`"}]}]}]}}
+})());hljs.registerLanguage("tcl",(()=>{"use strict";return e=>({name:"Tcl",
+aliases:["tk"],
+keywords:"after append apply array auto_execok auto_import auto_load auto_mkindex auto_mkindex_old auto_qualify auto_reset bgerror binary break catch cd chan clock close concat continue dde dict encoding eof error eval exec exit expr fblocked fconfigure fcopy file fileevent filename flush for foreach format gets glob global history http if incr info interp join lappend|10 lassign|10 lindex|10 linsert|10 list llength|10 load lrange|10 lrepeat|10 lreplace|10 lreverse|10 lsearch|10 lset|10 lsort|10 mathfunc mathop memory msgcat namespace open package parray pid pkg::create pkg_mkIndex platform platform::shell proc puts pwd read refchan regexp registry regsub|10 rename return safe scan seek set socket source split string subst switch tcl_endOfWord tcl_findLibrary tcl_startOfNextWord tcl_startOfPreviousWord tcl_wordBreakAfter tcl_wordBreakBefore tcltest tclvars tell time tm trace unknown unload unset update uplevel upvar variable vwait while",
+contains:[e.COMMENT(";[ \\t]*#","$"),e.COMMENT("^[ \\t]*#","$"),{
+beginKeywords:"proc",end:"[\\{]",excludeEnd:!0,contains:[{className:"title",
+begin:"[ \\t\\n\\r]+(::)?[a-zA-Z_]((::)?[a-zA-Z0-9_])*",end:"[ \\t\\n\\r]",
+endsWithParent:!0,excludeEnd:!0}]},{excludeEnd:!0,variants:[{
+begin:"\\$(\\{)?(::)?[a-zA-Z_]((::)?[a-zA-Z0-9_])*\\(([a-zA-Z0-9_])*\\)",
+end:"[^a-zA-Z0-9_\\}\\$]"},{begin:"\\$(\\{)?(::)?[a-zA-Z_]((::)?[a-zA-Z0-9_])*",
+end:"(\\))?[^a-zA-Z0-9_\\}\\$]"}]},{className:"string",
+contains:[e.BACKSLASH_ESCAPE],variants:[e.inherit(e.QUOTE_STRING_MODE,{
+illegal:null})]},{className:"number",
+variants:[e.BINARY_NUMBER_MODE,e.C_NUMBER_MODE]}]})})());hljs.registerLanguage("haskell",(()=>{"use strict";return e=>{const n={
+variants:[e.COMMENT("--","$"),e.COMMENT(/\{-/,/-\}/,{contains:["self"]})]},i={
+className:"meta",begin:/\{-#/,end:/#-\}/},a={className:"meta",begin:"^#",end:"$"
+},s={className:"type",begin:"\\b[A-Z][\\w']*",relevance:0},l={begin:"\\(",
+end:"\\)",illegal:'"',contains:[i,a,{className:"type",
+begin:"\\b[A-Z][\\w]*(\\((\\.\\.|,|\\w+)\\))?"},e.inherit(e.TITLE_MODE,{
+begin:"[_a-z][\\w']*"}),n]};return{name:"Haskell",aliases:["hs"],
+keywords:"let in if then else case of where do module import hiding qualified type data newtype deriving class instance as default infix infixl infixr foreign export ccall stdcall cplusplus jvm dotnet safe unsafe family forall mdo proc rec",
+contains:[{beginKeywords:"module",end:"where",keywords:"module where",
+contains:[l,n],illegal:"\\W\\.|;"},{begin:"\\bimport\\b",end:"$",
+keywords:"import qualified as hiding",contains:[l,n],illegal:"\\W\\.|;"},{
+className:"class",begin:"^(\\s*)?(class|instance)\\b",end:"where",
+keywords:"class family instance where",contains:[s,l,n]},{className:"class",
+begin:"\\b(data|(new)?type)\\b",end:"$",
+keywords:"data family type newtype deriving",contains:[i,s,l,{begin:/\{/,
+end:/\}/,contains:l.contains},n]},{beginKeywords:"default",end:"$",
+contains:[s,l,n]},{beginKeywords:"infix infixl infixr",end:"$",
+contains:[e.C_NUMBER_MODE,n]},{begin:"\\bforeign\\b",end:"$",
+keywords:"foreign import export ccall stdcall cplusplus jvm dotnet safe unsafe",
+contains:[s,e.QUOTE_STRING_MODE,n]},{className:"meta",
+begin:"#!\\/usr\\/bin\\/env runhaskell",end:"$"
+},i,a,e.QUOTE_STRING_MODE,e.C_NUMBER_MODE,s,e.inherit(e.TITLE_MODE,{
+begin:"^[_a-z][\\w']*"}),n,{begin:"->|<-"}]}}})());hljs.registerLanguage("ini",(()=>{"use strict";function e(e){
+return e?"string"==typeof e?e:e.source:null}function n(...n){
+return n.map((n=>e(n))).join("")}return s=>{const a={className:"number",
+relevance:0,variants:[{begin:/([+-]+)?[\d]+_[\d_]+/},{begin:s.NUMBER_RE}]
+},i=s.COMMENT();i.variants=[{begin:/;/,end:/$/},{begin:/#/,end:/$/}];const t={
+className:"variable",variants:[{begin:/\$[\w\d"][\w\d_]*/},{begin:/\$\{(.*?)\}/
+}]},r={className:"literal",begin:/\bon|off|true|false|yes|no\b/},l={
+className:"string",contains:[s.BACKSLASH_ESCAPE],variants:[{begin:"'''",
+end:"'''",relevance:10},{begin:'"""',end:'"""',relevance:10},{begin:'"',end:'"'
+},{begin:"'",end:"'"}]},c={begin:/\[/,end:/\]/,contains:[i,r,t,l,a,"self"],
+relevance:0
+},g="("+[/[A-Za-z0-9_-]+/,/"(\\"|[^"])*"/,/'[^']*'/].map((n=>e(n))).join("|")+")"
+;return{name:"TOML, also INI",aliases:["toml"],case_insensitive:!0,illegal:/\S/,
+contains:[i,{className:"section",begin:/\[+/,end:/\]+/},{
+begin:n(g,"(\\s*\\.\\s*",g,")*",n("(?=",/\s*=\s*[^#\s]/,")")),className:"attr",
+starts:{end:/$/,contains:[i,c,r,t,l,a]}}]}}})());hljs.registerLanguage("makefile",(()=>{"use strict";return e=>{const i={
+className:"variable",variants:[{begin:"\\$\\("+e.UNDERSCORE_IDENT_RE+"\\)",
+contains:[e.BACKSLASH_ESCAPE]},{begin:/\$[@%<?\^\+\*]/}]},a={className:"string",
+begin:/"/,end:/"/,contains:[e.BACKSLASH_ESCAPE,i]},n={className:"variable",
+begin:/\$\([\w-]+\s/,end:/\)/,keywords:{
+built_in:"subst patsubst strip findstring filter filter-out sort word wordlist firstword lastword dir notdir suffix basename addsuffix addprefix join wildcard realpath abspath error warning shell origin flavor foreach if or and call eval file value"
+},contains:[i]},s={begin:"^"+e.UNDERSCORE_IDENT_RE+"\\s*(?=[:+?]?=)"},r={
+className:"section",begin:/^[^\s]+:/,end:/$/,contains:[i]};return{
+name:"Makefile",aliases:["mk","mak"],keywords:{$pattern:/[\w-]+/,
+keyword:"define endef undefine ifdef ifndef ifeq ifneq else endif include -include sinclude override export unexport private vpath"
+},contains:[e.HASH_COMMENT_MODE,i,a,n,s,{className:"meta",begin:/^\.PHONY:/,
+end:/$/,keywords:{$pattern:/[\.\w]+/,"meta-keyword":".PHONY"}},r]}}})());hljs.registerLanguage("powershell",(()=>{"use strict";return e=>{const n={
+$pattern:/-?[A-z\.\-]+\b/,
+keyword:"if else foreach return do while until elseif begin for trap data dynamicparam end break throw param continue finally in switch exit filter try process catch hidden static parameter",
+built_in:"ac asnp cat cd CFS chdir clc clear clhy cli clp cls clv cnsn compare copy cp cpi cpp curl cvpa dbp del diff dir dnsn ebp echo|0 epal epcsv epsn erase etsn exsn fc fhx fl ft fw gal gbp gc gcb gci gcm gcs gdr gerr ghy gi gin gjb gl gm gmo gp gps gpv group gsn gsnp gsv gtz gu gv gwmi h history icm iex ihy ii ipal ipcsv ipmo ipsn irm ise iwmi iwr kill lp ls man md measure mi mount move mp mv nal ndr ni nmo npssc nsn nv ogv oh popd ps pushd pwd r rbp rcjb rcsn rd rdr ren ri rjb rm rmdir rmo rni rnp rp rsn rsnp rujb rv rvpa rwmi sajb sal saps sasv sbp sc scb select set shcm si sl sleep sls sort sp spjb spps spsv start stz sujb sv swmi tee trcm type wget where wjb write"
+},s={begin:"`[\\s\\S]",relevance:0},i={className:"variable",variants:[{
+begin:/\$\B/},{className:"keyword",begin:/\$this/},{begin:/\$[\w\d][\w\d_:]*/}]
+},a={className:"string",variants:[{begin:/"/,end:/"/},{begin:/@"/,end:/^"@/}],
+contains:[s,i,{className:"variable",begin:/\$[A-z]/,end:/[^A-z]/}]},t={
+className:"string",variants:[{begin:/'/,end:/'/},{begin:/@'/,end:/^'@/}]
+},r=e.inherit(e.COMMENT(null,null),{variants:[{begin:/#/,end:/$/},{begin:/<#/,
+end:/#>/}],contains:[{className:"doctag",variants:[{
+begin:/\.(synopsis|description|example|inputs|outputs|notes|link|component|role|functionality)/
+},{
+begin:/\.(parameter|forwardhelptargetname|forwardhelpcategory|remotehelprunspace|externalhelp)\s+\S+/
+}]}]}),c={className:"class",beginKeywords:"class enum",end:/\s*[{]/,
+excludeEnd:!0,relevance:0,contains:[e.TITLE_MODE]},l={className:"function",
+begin:/function\s+/,end:/\s*\{|$/,excludeEnd:!0,returnBegin:!0,relevance:0,
+contains:[{begin:"function",relevance:0,className:"keyword"},{className:"title",
+begin:/\w[\w\d]*((-)[\w\d]+)*/,relevance:0},{begin:/\(/,end:/\)/,
+className:"params",relevance:0,contains:[i]}]},o={begin:/using\s/,end:/$/,
+returnBegin:!0,contains:[a,t,{className:"keyword",
+begin:/(using|assembly|command|module|namespace|type)/}]},p={
+className:"function",begin:/\[.*\]\s*[\w]+[ ]??\(/,end:/$/,returnBegin:!0,
+relevance:0,contains:[{className:"keyword",
+begin:"(".concat(n.keyword.toString().replace(/\s/g,"|"),")\\b"),endsParent:!0,
+relevance:0},e.inherit(e.TITLE_MODE,{endsParent:!0})]
+},g=[p,r,s,e.NUMBER_MODE,a,t,{className:"built_in",variants:[{
+begin:"(Add|Clear|Close|Copy|Enter|Exit|Find|Format|Get|Hide|Join|Lock|Move|New|Open|Optimize|Pop|Push|Redo|Remove|Rename|Reset|Resize|Search|Select|Set|Show|Skip|Split|Step|Switch|Undo|Unlock|Watch|Backup|Checkpoint|Compare|Compress|Convert|ConvertFrom|ConvertTo|Dismount|Edit|Expand|Export|Group|Import|Initialize|Limit|Merge|New|Out|Publish|Restore|Save|Sync|Unpublish|Update|Approve|Assert|Complete|Confirm|Deny|Disable|Enable|Install|Invoke|Register|Request|Restart|Resume|Start|Stop|Submit|Suspend|Uninstall|Unregister|Wait|Debug|Measure|Ping|Repair|Resolve|Test|Trace|Connect|Disconnect|Read|Receive|Send|Write|Block|Grant|Protect|Revoke|Unblock|Unprotect|Use|ForEach|Sort|Tee|Where)+(-)[\\w\\d]+"
+}]},i,{className:"literal",begin:/\$(null|true|false)\b/},{
+className:"selector-tag",begin:/@\B/,relevance:0}],m={begin:/\[/,end:/\]/,
+excludeBegin:!0,excludeEnd:!0,relevance:0,contains:[].concat("self",g,{
+begin:"(string|char|byte|int|long|bool|decimal|single|double|DateTime|xml|array|hashtable|void)",
+className:"built_in",relevance:0},{className:"type",begin:/[\.\w\d]+/,
+relevance:0})};return p.contains.unshift(m),{name:"PowerShell",
+aliases:["ps","ps1"],case_insensitive:!0,keywords:n,contains:g.concat(c,l,o,{
+variants:[{className:"operator",
+begin:"(-and|-as|-band|-bnot|-bor|-bxor|-casesensitive|-ccontains|-ceq|-cge|-cgt|-cle|-clike|-clt|-cmatch|-cne|-cnotcontains|-cnotlike|-cnotmatch|-contains|-creplace|-csplit|-eq|-exact|-f|-file|-ge|-gt|-icontains|-ieq|-ige|-igt|-ile|-ilike|-ilt|-imatch|-in|-ine|-inotcontains|-inotlike|-inotmatch|-ireplace|-is|-isnot|-isplit|-join|-le|-like|-lt|-match|-ne|-not|-notcontains|-notin|-notlike|-notmatch|-or|-regex|-replace|-shl|-shr|-split|-wildcard|-xor)\\b"
+},{className:"literal",begin:/(-)[\w\d]+/,relevance:0}]},m)}}})());hljs.registerLanguage("properties",(()=>{"use strict";return e=>{
+var n="[ \\t\\f]*",a=n+"[:=]"+n,t="("+a+"|[ \\t\\f]+)",r="([^\\\\\\W:= \\t\\f\\n]|\\\\.)+",s="([^\\\\:= \\t\\f\\n]|\\\\.)+",i={
+end:t,relevance:0,starts:{className:"string",end:/$/,relevance:0,contains:[{
+begin:"\\\\\\n"}]}};return{name:".properties",case_insensitive:!0,illegal:/\S/,
+contains:[e.COMMENT("^\\s*[!#]","$"),{returnBegin:!0,variants:[{begin:r+a,
+relevance:1},{begin:r+"[ \\t\\f]+",relevance:0}],contains:[{className:"attr",
+begin:r,endsParent:!0,relevance:0}],starts:i},{begin:s+t,returnBegin:!0,
+relevance:0,contains:[{className:"meta",begin:s,endsParent:!0,relevance:0}],
+starts:i},{className:"attr",relevance:0,begin:s+n+"$"}]}}})());hljs.registerLanguage("php-template",(()=>{"use strict";return n=>({
+name:"PHP template",subLanguage:"xml",contains:[{begin:/<\?(php|=)?/,end:/\?>/,
+subLanguage:"php",contains:[{begin:"/\\*",end:"\\*/",skip:!0},{begin:'b"',
+end:'"',skip:!0},{begin:"b'",end:"'",skip:!0},n.inherit(n.APOS_STRING_MODE,{
+illegal:null,className:null,contains:null,skip:!0
+}),n.inherit(n.QUOTE_STRING_MODE,{illegal:null,className:null,contains:null,
+skip:!0})]}]})})());hljs.registerLanguage("angelscript",(()=>{"use strict";return e=>{var n={
+className:"built_in",
+begin:"\\b(void|bool|int|int8|int16|int32|int64|uint|uint8|uint16|uint32|uint64|string|ref|array|double|float|auto|dictionary)"
+},a={className:"symbol",begin:"[a-zA-Z0-9_]+@"},i={className:"keyword",
+begin:"<",end:">",contains:[n,a]};return n.contains=[i],a.contains=[i],{
+name:"AngelScript",aliases:["asc"],
+keywords:"for in|0 break continue while do|0 return if else case switch namespace is cast or and xor not get|0 in inout|10 out override set|0 private public const default|0 final shared external mixin|10 enum typedef funcdef this super import from interface abstract|0 try catch protected explicit property",
+illegal:"(^using\\s+[A-Za-z0-9_\\.]+;$|\\bfunction\\s*[^\\(])",contains:[{
+className:"string",begin:"'",end:"'",illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE],relevance:0},{className:"string",begin:'"""',
+end:'"""'},{className:"string",begin:'"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE],relevance:0
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{className:"string",
+begin:"^\\s*\\[",end:"\\]"},{beginKeywords:"interface namespace",end:/\{/,
+illegal:"[;.\\-]",contains:[{className:"symbol",begin:"[a-zA-Z0-9_]+"}]},{
+beginKeywords:"class",end:/\{/,illegal:"[;.\\-]",contains:[{className:"symbol",
+begin:"[a-zA-Z0-9_]+",contains:[{begin:"[:,]\\s*",contains:[{className:"symbol",
+begin:"[a-zA-Z0-9_]+"}]}]}]},n,a,{className:"literal",
+begin:"\\b(null|true|false)"},{className:"number",relevance:0,
+begin:"(-?)(\\b0[xXbBoOdD][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?f?|\\.\\d+f?)([eE][-+]?\\d+f?)?)"
+}]}}})());hljs.registerLanguage("less",(()=>{"use strict";return e=>{
+var n="([\\w-]+|@\\{[\\w-]+\\})",a=[],s=[],t=e=>({className:"string",
+begin:"~?"+e+".*?"+e}),r=(e,n,a)=>({className:e,begin:n,relevance:a}),i={
+begin:"\\(",end:"\\)",contains:s,relevance:0}
+;s.push(e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,t("'"),t('"'),e.CSS_NUMBER_MODE,{
+begin:"(url|data-uri)\\(",starts:{className:"string",end:"[\\)\\n]",
+excludeEnd:!0}
+},r("number","#[0-9A-Fa-f]+\\b"),i,r("variable","@@?[\\w-]+",10),r("variable","@\\{[\\w-]+\\}"),r("built_in","~?`[^`]*?`"),{
+className:"attribute",begin:"[\\w-]+\\s*:",end:":",returnBegin:!0,excludeEnd:!0
+},{className:"meta",begin:"!important"});var c=s.concat({begin:/\{/,end:/\}/,
+contains:a}),l={beginKeywords:"when",endsWithParent:!0,contains:[{
+beginKeywords:"and not"}].concat(s)},g={begin:n+"\\s*:",returnBegin:!0,
+end:"[;}]",relevance:0,contains:[{className:"attribute",begin:n,end:":",
+excludeEnd:!0,starts:{endsWithParent:!0,illegal:"[<=$]",relevance:0,contains:s}
+}]},d={className:"keyword",
+begin:"@(import|media|charset|font-face|(-[a-z]+-)?keyframes|supports|document|namespace|page|viewport|host)\\b",
+starts:{end:"[;{}]",returnEnd:!0,contains:s,relevance:0}},o={
+className:"variable",variants:[{begin:"@[\\w-]+\\s*:",relevance:15},{
+begin:"@[\\w-]+"}],starts:{end:"[;}]",returnEnd:!0,contains:c}},b={variants:[{
+begin:"[\\.#:&\\[>]",end:"[;{}]"},{begin:n,end:/\{/}],returnBegin:!0,
+returnEnd:!0,illegal:"[<='$\"]",relevance:0,
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,l,r("keyword","all\\b"),r("variable","@\\{[\\w-]+\\}"),r("selector-tag",n+"%?",0),r("selector-id","#"+n),r("selector-class","\\."+n,0),r("selector-tag","&",0),{
+className:"selector-attr",begin:"\\[",end:"\\]"},{className:"selector-pseudo",
+begin:/:(:)?[a-zA-Z0-9_\-+()"'.]+/},{begin:"\\(",end:"\\)",contains:c},{
+begin:"!important"}]}
+;return a.push(e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,d,o,g,b),{
+name:"Less",case_insensitive:!0,illegal:"[=>'/<($\"]",contains:a}}})());hljs.registerLanguage("routeros",(()=>{"use strict";return e=>{
+const r="foreach do while for if from to step else on-error and or not in",n="true false yes no nothing nil null",i={
+className:"variable",variants:[{begin:/\$[\w\d#@][\w\d_]*/},{begin:/\$\{(.*?)\}/
+}]},s={className:"string",begin:/"/,end:/"/,contains:[e.BACKSLASH_ESCAPE,i,{
+className:"variable",begin:/\$\(/,end:/\)/,contains:[e.BACKSLASH_ESCAPE]}]},t={
+className:"string",begin:/'/,end:/'/};return{name:"Microtik RouterOS script",
+aliases:["routeros","mikrotik"],case_insensitive:!0,keywords:{
+$pattern:/:?[\w-]+/,literal:n,
+keyword:r+" :"+r.split(" ").join(" :")+" :"+"global local beep delay put len typeof pick log time set find environment terminal error execute parse resolve toarray tobool toid toip toip6 tonum tostr totime".split(" ").join(" :")
+},contains:[{variants:[{begin:/\/\*/,end:/\*\//},{begin:/\/\//,end:/$/},{
+begin:/<\//,end:/>/}],illegal:/./},e.COMMENT("^#","$"),s,t,i,{
+begin:/[\w-]+=([^\s{}[\]()]+)/,relevance:0,returnBegin:!0,contains:[{
+className:"attribute",begin:/[^=]+/},{begin:/=/,endsWithParent:!0,relevance:0,
+contains:[s,t,i,{className:"literal",begin:"\\b("+n.split(" ").join("|")+")\\b"
+},{begin:/("[^"]*"|[^\s{}[\]]+)/}]}]},{className:"number",begin:/\*[0-9a-fA-F]+/
+},{
+begin:"\\b(add|remove|enable|disable|set|get|print|export|edit|find|run|debug|error|info|warning)([\\s[(\\]|])",
+returnBegin:!0,contains:[{className:"builtin-name",begin:/\w+/}]},{
+className:"built_in",variants:[{
+begin:"(\\.\\./|/|\\s)((traffic-flow|traffic-generator|firewall|scheduler|aaa|accounting|address-list|address|align|area|bandwidth-server|bfd|bgp|bridge|client|clock|community|config|connection|console|customer|default|dhcp-client|dhcp-server|discovery|dns|e-mail|ethernet|filter|firewall|firmware|gps|graphing|group|hardware|health|hotspot|identity|igmp-proxy|incoming|instance|interface|ip|ipsec|ipv6|irq|l2tp-server|lcd|ldp|logging|mac-server|mac-winbox|mangle|manual|mirror|mme|mpls|nat|nd|neighbor|network|note|ntp|ospf|ospf-v3|ovpn-server|page|peer|pim|ping|policy|pool|port|ppp|pppoe-client|pptp-server|prefix|profile|proposal|proxy|queue|radius|resource|rip|ripng|route|routing|screen|script|security-profiles|server|service|service-port|settings|shares|smb|sms|sniffer|snmp|snooper|socks|sstp-server|system|tool|tracking|type|upgrade|upnp|user-manager|users|user|vlan|secret|vrrp|watchdog|web-access|wireless|pptp|pppoe|lan|wan|layer7-protocol|lease|simple|raw);?\\s)+"
+},{begin:/\.\./,relevance:0}]}]}}})());hljs.registerLanguage("dockerfile",(()=>{"use strict";return e=>({
+name:"Dockerfile",aliases:["docker"],case_insensitive:!0,
+keywords:"from maintainer expose env arg user onbuild stopsignal",
+contains:[e.HASH_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.NUMBER_MODE,{
+beginKeywords:"run cmd entrypoint volume add copy workdir label healthcheck shell",
+starts:{end:/[^\\]$/,subLanguage:"bash"}}],illegal:"</"})})());hljs.registerLanguage("javascript",(()=>{"use strict"
+;const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],s=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"])
+;function r(e){return i("(?=",e,")")}function i(...e){return e.map((e=>{
+return(n=e)?"string"==typeof n?n:n.source:null;var n})).join("")}return t=>{
+const c=e,o={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/,
+isTrulyOpeningTag:(e,n)=>{const a=e[0].length+e.index,s=e.input[a]
+;"<"!==s?">"===s&&(((e,{after:n})=>{const a="</"+e[0].slice(1)
+;return-1!==e.input.indexOf(a,n)})(e,{after:a
+})||n.ignoreMatch()):n.ignoreMatch()}},l={$pattern:e,keyword:n.join(" "),
+literal:a.join(" "),built_in:s.join(" ")
+},b="\\.([0-9](_?[0-9])*)",g="0|[1-9](_?[0-9])*|0[0-7]*[89][0-9]*",d={
+className:"number",variants:[{
+begin:`(\\b(${g})((${b})|\\.)?|(${b}))[eE][+-]?([0-9](_?[0-9])*)\\b`},{
+begin:`\\b(${g})\\b((${b})\\b|\\.)?|(${b})\\b`},{
+begin:"\\b(0|[1-9](_?[0-9])*)n\\b"},{
+begin:"\\b0[xX][0-9a-fA-F](_?[0-9a-fA-F])*n?\\b"},{
+begin:"\\b0[bB][0-1](_?[0-1])*n?\\b"},{begin:"\\b0[oO][0-7](_?[0-7])*n?\\b"},{
+begin:"\\b0[0-7]+n?\\b"}],relevance:0},E={className:"subst",begin:"\\$\\{",
+end:"\\}",keywords:l,contains:[]},u={begin:"html`",end:"",starts:{end:"`",
+returnEnd:!1,contains:[t.BACKSLASH_ESCAPE,E],subLanguage:"xml"}},_={
+begin:"css`",end:"",starts:{end:"`",returnEnd:!1,
+contains:[t.BACKSLASH_ESCAPE,E],subLanguage:"css"}},m={className:"string",
+begin:"`",end:"`",contains:[t.BACKSLASH_ESCAPE,E]},N={className:"comment",
+variants:[t.COMMENT("/\\*\\*","\\*/",{relevance:0,contains:[{className:"doctag",
+begin:"@[A-Za-z]+",contains:[{className:"type",begin:"\\{",end:"\\}",relevance:0
+},{className:"variable",begin:c+"(?=\\s*(-)|$)",endsParent:!0,relevance:0},{
+begin:/(?=[^\n])\s/,relevance:0}]}]
+}),t.C_BLOCK_COMMENT_MODE,t.C_LINE_COMMENT_MODE]
+},y=[t.APOS_STRING_MODE,t.QUOTE_STRING_MODE,u,_,m,d,t.REGEXP_MODE]
+;E.contains=y.concat({begin:/\{/,end:/\}/,keywords:l,contains:["self"].concat(y)
+});const f=[].concat(N,E.contains),A=f.concat([{begin:/\(/,end:/\)/,keywords:l,
+contains:["self"].concat(f)}]),p={className:"params",begin:/\(/,end:/\)/,
+excludeBegin:!0,excludeEnd:!0,keywords:l,contains:A};return{name:"Javascript",
+aliases:["js","jsx","mjs","cjs"],keywords:l,exports:{PARAMS_CONTAINS:A},
+illegal:/#(?![$_A-z])/,contains:[t.SHEBANG({label:"shebang",binary:"node",
+relevance:5}),{label:"use_strict",className:"meta",relevance:10,
+begin:/^\s*['"]use (strict|asm)['"]/
+},t.APOS_STRING_MODE,t.QUOTE_STRING_MODE,u,_,m,N,d,{
+begin:i(/[{,\n]\s*/,r(i(/(((\/\/.*$)|(\/\*(\*[^/]|[^*])*\*\/))\s*)*/,c+"\\s*:"))),
+relevance:0,contains:[{className:"attr",begin:c+r("\\s*:"),relevance:0}]},{
+begin:"("+t.RE_STARTERS_RE+"|\\b(case|return|throw)\\b)\\s*",
+keywords:"return throw case",contains:[N,t.REGEXP_MODE,{className:"function",
+begin:"(\\([^()]*(\\([^()]*(\\([^()]*\\))*[^()]*\\))*[^()]*\\)|"+t.UNDERSCORE_IDENT_RE+")\\s*=>",
+returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{
+begin:t.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0
+},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:l,contains:A}]}]
+},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{
+variants:[{begin:"<>",end:"</>"},{begin:o.begin,"on:begin":o.isTrulyOpeningTag,
+end:o.end}],subLanguage:"xml",contains:[{begin:o.begin,end:o.end,skip:!0,
+contains:["self"]}]}],relevance:0},{className:"function",
+beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:l,
+contains:["self",t.inherit(t.TITLE_MODE,{begin:c}),p],illegal:/%/},{
+beginKeywords:"while if switch catch for"},{className:"function",
+begin:t.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\))*[^()]*\\))*[^()]*\\)\\s*\\{",
+returnBegin:!0,contains:[p,t.inherit(t.TITLE_MODE,{begin:c})]},{variants:[{
+begin:"\\."+c},{begin:"\\$"+c}],relevance:0},{className:"class",
+beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{
+beginKeywords:"extends"},t.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/,
+end:/[{;]/,excludeEnd:!0,contains:[t.inherit(t.TITLE_MODE,{begin:c}),"self",p]
+},{begin:"(get|set)\\s+(?="+c+"\\()",end:/\{/,keywords:"get set",
+contains:[t.inherit(t.TITLE_MODE,{begin:c}),{begin:/\(\)/},p]},{begin:/\$[(.]/}]
+}}})());hljs.registerLanguage("applescript",(()=>{"use strict";return e=>{
+const t=e.inherit(e.QUOTE_STRING_MODE,{illegal:""}),r={className:"params",
+begin:"\\(",end:"\\)",contains:["self",e.C_NUMBER_MODE,t]
+},i=e.COMMENT("--","$"),n=[i,e.COMMENT("\\(\\*","\\*\\)",{contains:["self",i]
+}),e.HASH_COMMENT_MODE];return{name:"AppleScript",aliases:["osascript"],
+keywords:{
+keyword:"about above after against and around as at back before beginning behind below beneath beside between but by considering contain contains continue copy div does eighth else end equal equals error every exit fifth first for fourth from front get given global if ignoring in into is it its last local me middle mod my ninth not of on onto or over prop property put ref reference repeat returning script second set seventh since sixth some tell tenth that the|0 then third through thru timeout times to transaction try until where while whose with without",
+literal:"AppleScript false linefeed return pi quote result space tab true",
+built_in:"alias application boolean class constant date file integer list number real record string text activate beep count delay launch log offset read round run say summarize write character characters contents day frontmost id item length month name paragraph paragraphs rest reverse running time version weekday word words year"
+},contains:[t,e.C_NUMBER_MODE,{className:"built_in",
+begin:"\\b(clipboard info|the clipboard|info for|list (disks|folder)|mount volume|path to|(close|open for) access|(get|set) eof|current date|do shell script|get volume settings|random number|set volume|system attribute|system info|time to GMT|(load|run|store) script|scripting components|ASCII (character|number)|localized string|choose (application|color|file|file name|folder|from list|remote application|URL)|display (alert|dialog))\\b|^\\s*return\\b"
+},{className:"literal",
+begin:"\\b(text item delimiters|current application|missing value)\\b"},{
+className:"keyword",
+begin:"\\b(apart from|aside from|instead of|out of|greater than|isn't|(doesn't|does not) (equal|come before|come after|contain)|(greater|less) than( or equal)?|(starts?|ends|begins?) with|contained by|comes (before|after)|a (ref|reference)|POSIX file|POSIX path|(date|time) string|quoted form)\\b"
+},{beginKeywords:"on",illegal:"[${=;\\n]",contains:[e.UNDERSCORE_TITLE_MODE,r]
+}].concat(n),illegal:"//|->|=>|\\[\\["}}})());hljs.registerLanguage("erlang",(()=>{"use strict";return e=>{
+const n="[a-z'][a-zA-Z0-9_']*",r="("+n+":"+n+"|"+n+")",a={
+keyword:"after and andalso|10 band begin bnot bor bsl bzr bxor case catch cond div end fun if let not of orelse|10 query receive rem try when xor",
+literal:"false true"},i=e.COMMENT("%","$"),s={className:"number",
+begin:"\\b(\\d+(_\\d+)*#[a-fA-F0-9]+(_[a-fA-F0-9]+)*|\\d+(_\\d+)*(\\.\\d+(_\\d+)*)?([eE][-+]?\\d+)?)",
+relevance:0},c={begin:"fun\\s+"+n+"/\\d+"},t={begin:r+"\\(",end:"\\)",
+returnBegin:!0,relevance:0,contains:[{begin:r,relevance:0},{begin:"\\(",
+end:"\\)",endsWithParent:!0,returnEnd:!0,relevance:0}]},d={begin:/\{/,end:/\}/,
+relevance:0},o={begin:"\\b_([A-Z][A-Za-z0-9_]*)?",relevance:0},l={
+begin:"[A-Z][a-zA-Z0-9_]*",relevance:0},b={begin:"#"+e.UNDERSCORE_IDENT_RE,
+relevance:0,returnBegin:!0,contains:[{begin:"#"+e.UNDERSCORE_IDENT_RE,
+relevance:0},{begin:/\{/,end:/\}/,relevance:0}]},g={
+beginKeywords:"fun receive if try case",end:"end",keywords:a}
+;g.contains=[i,c,e.inherit(e.APOS_STRING_MODE,{className:""
+}),g,t,e.QUOTE_STRING_MODE,s,d,o,l,b]
+;const E=[i,c,g,t,e.QUOTE_STRING_MODE,s,d,o,l,b]
+;t.contains[1].contains=E,d.contains=E,b.contains[1].contains=E;const u={
+className:"params",begin:"\\(",end:"\\)",contains:E};return{name:"Erlang",
+aliases:["erl"],keywords:a,illegal:"(</|\\*=|\\+=|-=|/\\*|\\*/|\\(\\*|\\*\\))",
+contains:[{className:"function",begin:"^"+n+"\\s*\\(",end:"->",returnBegin:!0,
+illegal:"\\(|#|//|/\\*|\\\\|:|;",contains:[u,e.inherit(e.TITLE_MODE,{begin:n})],
+starts:{end:";|\\.",keywords:a,contains:E}},i,{begin:"^-",end:"\\.",relevance:0,
+excludeEnd:!0,returnBegin:!0,keywords:{$pattern:"-"+e.IDENT_RE,
+keyword:"-module -record -undef -export -ifdef -ifndef -author -copyright -doc -vsn -import -include -include_lib -compile -define -else -endif -file -behaviour -behavior -spec"
+},contains:[u]},s,e.QUOTE_STRING_MODE,b,o,l,d,{begin:/\.$/}]}}})());hljs.registerLanguage("ocaml",(()=>{"use strict";return e=>({name:"OCaml",
+aliases:["ml"],keywords:{$pattern:"[a-z_]\\w*!?",
+keyword:"and as assert asr begin class constraint do done downto else end exception external for fun function functor if in include inherit! inherit initializer land lazy let lor lsl lsr lxor match method!|10 method mod module mutable new object of open! open or private rec sig struct then to try type val! val virtual when while with parser value",
+built_in:"array bool bytes char exn|5 float int int32 int64 list lazy_t|5 nativeint|5 string unit in_channel out_channel ref",
+literal:"true false"},illegal:/\/\/|>>/,contains:[{className:"literal",
+begin:"\\[(\\|\\|)?\\]|\\(\\)",relevance:0},e.COMMENT("\\(\\*","\\*\\)",{
+contains:["self"]}),{className:"symbol",begin:"'[A-Za-z_](?!')[\\w']*"},{
+className:"type",begin:"`[A-Z][\\w']*"},{className:"type",
+begin:"\\b[A-Z][\\w']*",relevance:0},{begin:"[a-z_]\\w*'[\\w']*",relevance:0
+},e.inherit(e.APOS_STRING_MODE,{className:"string",relevance:0
+}),e.inherit(e.QUOTE_STRING_MODE,{illegal:null}),{className:"number",
+begin:"\\b(0[xX][a-fA-F0-9_]+[Lln]?|0[oO][0-7_]+[Lln]?|0[bB][01_]+[Lln]?|[0-9][0-9_]*([Lln]|(\\.[0-9_]*)?([eE][-+]?[0-9_]+)?)?)",
+relevance:0},{begin:/->/}]})})());hljs.registerLanguage("nginx",(()=>{"use strict";return e=>{const n={
+className:"variable",variants:[{begin:/\$\d+/},{begin:/\$\{/,end:/\}/},{
+begin:/[$@]/+e.UNDERSCORE_IDENT_RE}]},a={endsWithParent:!0,keywords:{
+$pattern:"[a-z/_]+",
+literal:"on off yes no true false none blocked debug info notice warn error crit select break last permanent redirect kqueue rtsig epoll poll /dev/poll"
+},relevance:0,illegal:"=>",contains:[e.HASH_COMMENT_MODE,{className:"string",
+contains:[e.BACKSLASH_ESCAPE,n],variants:[{begin:/"/,end:/"/},{begin:/'/,end:/'/
+}]},{begin:"([a-z]+):/",end:"\\s",endsWithParent:!0,excludeEnd:!0,contains:[n]
+},{className:"regexp",contains:[e.BACKSLASH_ESCAPE,n],variants:[{begin:"\\s\\^",
+end:"\\s|\\{|;",returnEnd:!0},{begin:"~\\*?\\s+",end:"\\s|\\{|;",returnEnd:!0},{
+begin:"\\*(\\.[a-z\\-]+)+"},{begin:"([a-z\\-]+\\.)+\\*"}]},{className:"number",
+begin:"\\b\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}(:\\d{1,5})?\\b"},{
+className:"number",begin:"\\b\\d+[kKmMgGdshdwy]*\\b",relevance:0},n]};return{
+name:"Nginx config",aliases:["nginxconf"],contains:[e.HASH_COMMENT_MODE,{
+begin:e.UNDERSCORE_IDENT_RE+"\\s+\\{",returnBegin:!0,end:/\{/,contains:[{
+className:"section",begin:e.UNDERSCORE_IDENT_RE}],relevance:0},{
+begin:e.UNDERSCORE_IDENT_RE+"\\s",end:";|\\{",returnBegin:!0,contains:[{
+className:"attribute",begin:e.UNDERSCORE_IDENT_RE,starts:a}],relevance:0}],
+illegal:"[^\\s\\}]"}}})());hljs.registerLanguage("x86asm",(()=>{"use strict";return s=>({
+name:"Intel x86 Assembly",case_insensitive:!0,keywords:{
+$pattern:"[.%]?"+s.IDENT_RE,
+keyword:"lock rep repe repz repne repnz xaquire xrelease bnd nobnd aaa aad aam aas adc add and arpl bb0_reset bb1_reset bound bsf bsr bswap bt btc btr bts call cbw cdq cdqe clc cld cli clts cmc cmp cmpsb cmpsd cmpsq cmpsw cmpxchg cmpxchg486 cmpxchg8b cmpxchg16b cpuid cpu_read cpu_write cqo cwd cwde daa das dec div dmint emms enter equ f2xm1 fabs fadd faddp fbld fbstp fchs fclex fcmovb fcmovbe fcmove fcmovnb fcmovnbe fcmovne fcmovnu fcmovu fcom fcomi fcomip fcomp fcompp fcos fdecstp fdisi fdiv fdivp fdivr fdivrp femms feni ffree ffreep fiadd ficom ficomp fidiv fidivr fild fimul fincstp finit fist fistp fisttp fisub fisubr fld fld1 fldcw fldenv fldl2e fldl2t fldlg2 fldln2 fldpi fldz fmul fmulp fnclex fndisi fneni fninit fnop fnsave fnstcw fnstenv fnstsw fpatan fprem fprem1 fptan frndint frstor fsave fscale fsetpm fsin fsincos fsqrt fst fstcw fstenv fstp fstsw fsub fsubp fsubr fsubrp ftst fucom fucomi fucomip fucomp fucompp fxam fxch fxtract fyl2x fyl2xp1 hlt ibts icebp idiv imul in inc incbin insb insd insw int int01 int1 int03 int3 into invd invpcid invlpg invlpga iret iretd iretq iretw jcxz jecxz jrcxz jmp jmpe lahf lar lds lea leave les lfence lfs lgdt lgs lidt lldt lmsw loadall loadall286 lodsb lodsd lodsq lodsw loop loope loopne loopnz loopz lsl lss ltr mfence monitor mov movd movq movsb movsd movsq movsw movsx movsxd movzx mul mwait neg nop not or out outsb outsd outsw packssdw packsswb packuswb paddb paddd paddsb paddsiw paddsw paddusb paddusw paddw pand pandn pause paveb pavgusb pcmpeqb pcmpeqd pcmpeqw pcmpgtb pcmpgtd pcmpgtw pdistib pf2id pfacc pfadd pfcmpeq pfcmpge pfcmpgt pfmax pfmin pfmul pfrcp pfrcpit1 pfrcpit2 pfrsqit1 pfrsqrt pfsub pfsubr pi2fd pmachriw pmaddwd pmagw pmulhriw pmulhrwa pmulhrwc pmulhw pmullw pmvgezb pmvlzb pmvnzb pmvzb pop popa popad popaw popf popfd popfq popfw por prefetch prefetchw pslld psllq psllw psrad psraw psrld psrlq psrlw psubb psubd psubsb psubsiw psubsw psubusb psubusw psubw punpckhbw punpckhdq punpckhwd punpcklbw punpckldq punpcklwd push pusha pushad pushaw pushf pushfd pushfq pushfw pxor rcl rcr rdshr rdmsr rdpmc rdtsc rdtscp ret retf retn rol ror rdm rsdc rsldt rsm rsts sahf sal salc sar sbb scasb scasd scasq scasw sfence sgdt shl shld shr shrd sidt sldt skinit smi smint smintold smsw stc std sti stosb stosd stosq stosw str sub svdc svldt svts swapgs syscall sysenter sysexit sysret test ud0 ud1 ud2b ud2 ud2a umov verr verw fwait wbinvd wrshr wrmsr xadd xbts xchg xlatb xlat xor cmove cmovz cmovne cmovnz cmova cmovnbe cmovae cmovnb cmovb cmovnae cmovbe cmovna cmovg cmovnle cmovge cmovnl cmovl cmovnge cmovle cmovng cmovc cmovnc cmovo cmovno cmovs cmovns cmovp cmovpe cmovnp cmovpo je jz jne jnz ja jnbe jae jnb jb jnae jbe jna jg jnle jge jnl jl jnge jle jng jc jnc jo jno js jns jpo jnp jpe jp sete setz setne setnz seta setnbe setae setnb setnc setb setnae setcset setbe setna setg setnle setge setnl setl setnge setle setng sets setns seto setno setpe setp setpo setnp addps addss andnps andps cmpeqps cmpeqss cmpleps cmpless cmpltps cmpltss cmpneqps cmpneqss cmpnleps cmpnless cmpnltps cmpnltss cmpordps cmpordss cmpunordps cmpunordss cmpps cmpss comiss cvtpi2ps cvtps2pi cvtsi2ss cvtss2si cvttps2pi cvttss2si divps divss ldmxcsr maxps maxss minps minss movaps movhps movlhps movlps movhlps movmskps movntps movss movups mulps mulss orps rcpps rcpss rsqrtps rsqrtss shufps sqrtps sqrtss stmxcsr subps subss ucomiss unpckhps unpcklps xorps fxrstor fxrstor64 fxsave fxsave64 xgetbv xsetbv xsave xsave64 xsaveopt xsaveopt64 xrstor xrstor64 prefetchnta prefetcht0 prefetcht1 prefetcht2 maskmovq movntq pavgb pavgw pextrw pinsrw pmaxsw pmaxub pminsw pminub pmovmskb pmulhuw psadbw pshufw pf2iw pfnacc pfpnacc pi2fw pswapd maskmovdqu clflush movntdq movnti movntpd movdqa movdqu movdq2q movq2dq paddq pmuludq pshufd pshufhw pshuflw pslldq psrldq psubq punpckhqdq punpcklqdq addpd addsd andnpd andpd cmpeqpd cmpeqsd cmplepd cmplesd cmpltpd cmpltsd cmpneqpd cmpneqsd cmpnlepd cmpnlesd cmpnltpd cmpnltsd cmpordpd cmpordsd cmpunordpd cmpunordsd cmppd comisd cvtdq2pd cvtdq2ps cvtpd2dq cvtpd2pi cvtpd2ps cvtpi2pd cvtps2dq cvtps2pd cvtsd2si cvtsd2ss cvtsi2sd cvtss2sd cvttpd2pi cvttpd2dq cvttps2dq cvttsd2si divpd divsd maxpd maxsd minpd minsd movapd movhpd movlpd movmskpd movupd mulpd mulsd orpd shufpd sqrtpd sqrtsd subpd subsd ucomisd unpckhpd unpcklpd xorpd addsubpd addsubps haddpd haddps hsubpd hsubps lddqu movddup movshdup movsldup clgi stgi vmcall vmclear vmfunc vmlaunch vmload vmmcall vmptrld vmptrst vmread vmresume vmrun vmsave vmwrite vmxoff vmxon invept invvpid pabsb pabsw pabsd palignr phaddw phaddd phaddsw phsubw phsubd phsubsw pmaddubsw pmulhrsw pshufb psignb psignw psignd extrq insertq movntsd movntss lzcnt blendpd blendps blendvpd blendvps dppd dpps extractps insertps movntdqa mpsadbw packusdw pblendvb pblendw pcmpeqq pextrb pextrd pextrq phminposuw pinsrb pinsrd pinsrq pmaxsb pmaxsd pmaxud pmaxuw pminsb pminsd pminud pminuw pmovsxbw pmovsxbd pmovsxbq pmovsxwd pmovsxwq pmovsxdq pmovzxbw pmovzxbd pmovzxbq pmovzxwd pmovzxwq pmovzxdq pmuldq pmulld ptest roundpd roundps roundsd roundss crc32 pcmpestri pcmpestrm pcmpistri pcmpistrm pcmpgtq popcnt getsec pfrcpv pfrsqrtv movbe aesenc aesenclast aesdec aesdeclast aesimc aeskeygenassist vaesenc vaesenclast vaesdec vaesdeclast vaesimc vaeskeygenassist vaddpd vaddps vaddsd vaddss vaddsubpd vaddsubps vandpd vandps vandnpd vandnps vblendpd vblendps vblendvpd vblendvps vbroadcastss vbroadcastsd vbroadcastf128 vcmpeq_ospd vcmpeqpd vcmplt_ospd vcmpltpd vcmple_ospd vcmplepd vcmpunord_qpd vcmpunordpd vcmpneq_uqpd vcmpneqpd vcmpnlt_uspd vcmpnltpd vcmpnle_uspd vcmpnlepd vcmpord_qpd vcmpordpd vcmpeq_uqpd vcmpnge_uspd vcmpngepd vcmpngt_uspd vcmpngtpd vcmpfalse_oqpd vcmpfalsepd vcmpneq_oqpd vcmpge_ospd vcmpgepd vcmpgt_ospd vcmpgtpd vcmptrue_uqpd vcmptruepd vcmplt_oqpd vcmple_oqpd vcmpunord_spd vcmpneq_uspd vcmpnlt_uqpd vcmpnle_uqpd vcmpord_spd vcmpeq_uspd vcmpnge_uqpd vcmpngt_uqpd vcmpfalse_ospd vcmpneq_ospd vcmpge_oqpd vcmpgt_oqpd vcmptrue_uspd vcmppd vcmpeq_osps vcmpeqps vcmplt_osps vcmpltps vcmple_osps vcmpleps vcmpunord_qps vcmpunordps vcmpneq_uqps vcmpneqps vcmpnlt_usps vcmpnltps vcmpnle_usps vcmpnleps vcmpord_qps vcmpordps vcmpeq_uqps vcmpnge_usps vcmpngeps vcmpngt_usps vcmpngtps vcmpfalse_oqps vcmpfalseps vcmpneq_oqps vcmpge_osps vcmpgeps vcmpgt_osps vcmpgtps vcmptrue_uqps vcmptrueps vcmplt_oqps vcmple_oqps vcmpunord_sps vcmpneq_usps vcmpnlt_uqps vcmpnle_uqps vcmpord_sps vcmpeq_usps vcmpnge_uqps vcmpngt_uqps vcmpfalse_osps vcmpneq_osps vcmpge_oqps vcmpgt_oqps vcmptrue_usps vcmpps vcmpeq_ossd vcmpeqsd vcmplt_ossd vcmpltsd vcmple_ossd vcmplesd vcmpunord_qsd vcmpunordsd vcmpneq_uqsd vcmpneqsd vcmpnlt_ussd vcmpnltsd vcmpnle_ussd vcmpnlesd vcmpord_qsd vcmpordsd vcmpeq_uqsd vcmpnge_ussd vcmpngesd vcmpngt_ussd vcmpngtsd vcmpfalse_oqsd vcmpfalsesd vcmpneq_oqsd vcmpge_ossd vcmpgesd vcmpgt_ossd vcmpgtsd vcmptrue_uqsd vcmptruesd vcmplt_oqsd vcmple_oqsd vcmpunord_ssd vcmpneq_ussd vcmpnlt_uqsd vcmpnle_uqsd vcmpord_ssd vcmpeq_ussd vcmpnge_uqsd vcmpngt_uqsd vcmpfalse_ossd vcmpneq_ossd vcmpge_oqsd vcmpgt_oqsd vcmptrue_ussd vcmpsd vcmpeq_osss vcmpeqss vcmplt_osss vcmpltss vcmple_osss vcmpless vcmpunord_qss vcmpunordss vcmpneq_uqss vcmpneqss vcmpnlt_usss vcmpnltss vcmpnle_usss vcmpnless vcmpord_qss vcmpordss vcmpeq_uqss vcmpnge_usss vcmpngess vcmpngt_usss vcmpngtss vcmpfalse_oqss vcmpfalsess vcmpneq_oqss vcmpge_osss vcmpgess vcmpgt_osss vcmpgtss vcmptrue_uqss vcmptruess vcmplt_oqss vcmple_oqss vcmpunord_sss vcmpneq_usss vcmpnlt_uqss vcmpnle_uqss vcmpord_sss vcmpeq_usss vcmpnge_uqss vcmpngt_uqss vcmpfalse_osss vcmpneq_osss vcmpge_oqss vcmpgt_oqss vcmptrue_usss vcmpss vcomisd vcomiss vcvtdq2pd vcvtdq2ps vcvtpd2dq vcvtpd2ps vcvtps2dq vcvtps2pd vcvtsd2si vcvtsd2ss vcvtsi2sd vcvtsi2ss vcvtss2sd vcvtss2si vcvttpd2dq vcvttps2dq vcvttsd2si vcvttss2si vdivpd vdivps vdivsd vdivss vdppd vdpps vextractf128 vextractps vhaddpd vhaddps vhsubpd vhsubps vinsertf128 vinsertps vlddqu vldqqu vldmxcsr vmaskmovdqu vmaskmovps vmaskmovpd vmaxpd vmaxps vmaxsd vmaxss vminpd vminps vminsd vminss vmovapd vmovaps vmovd vmovq vmovddup vmovdqa vmovqqa vmovdqu vmovqqu vmovhlps vmovhpd vmovhps vmovlhps vmovlpd vmovlps vmovmskpd vmovmskps vmovntdq vmovntqq vmovntdqa vmovntpd vmovntps vmovsd vmovshdup vmovsldup vmovss vmovupd vmovups vmpsadbw vmulpd vmulps vmulsd vmulss vorpd vorps vpabsb vpabsw vpabsd vpacksswb vpackssdw vpackuswb vpackusdw vpaddb vpaddw vpaddd vpaddq vpaddsb vpaddsw vpaddusb vpaddusw vpalignr vpand vpandn vpavgb vpavgw vpblendvb vpblendw vpcmpestri vpcmpestrm vpcmpistri vpcmpistrm vpcmpeqb vpcmpeqw vpcmpeqd vpcmpeqq vpcmpgtb vpcmpgtw vpcmpgtd vpcmpgtq vpermilpd vpermilps vperm2f128 vpextrb vpextrw vpextrd vpextrq vphaddw vphaddd vphaddsw vphminposuw vphsubw vphsubd vphsubsw vpinsrb vpinsrw vpinsrd vpinsrq vpmaddwd vpmaddubsw vpmaxsb vpmaxsw vpmaxsd vpmaxub vpmaxuw vpmaxud vpminsb vpminsw vpminsd vpminub vpminuw vpminud vpmovmskb vpmovsxbw vpmovsxbd vpmovsxbq vpmovsxwd vpmovsxwq vpmovsxdq vpmovzxbw vpmovzxbd vpmovzxbq vpmovzxwd vpmovzxwq vpmovzxdq vpmulhuw vpmulhrsw vpmulhw vpmullw vpmulld vpmuludq vpmuldq vpor vpsadbw vpshufb vpshufd vpshufhw vpshuflw vpsignb vpsignw vpsignd vpslldq vpsrldq vpsllw vpslld vpsllq vpsraw vpsrad vpsrlw vpsrld vpsrlq vptest vpsubb vpsubw vpsubd vpsubq vpsubsb vpsubsw vpsubusb vpsubusw vpunpckhbw vpunpckhwd vpunpckhdq vpunpckhqdq vpunpcklbw vpunpcklwd vpunpckldq vpunpcklqdq vpxor vrcpps vrcpss vrsqrtps vrsqrtss vroundpd vroundps vroundsd vroundss vshufpd vshufps vsqrtpd vsqrtps vsqrtsd vsqrtss vstmxcsr vsubpd vsubps vsubsd vsubss vtestps vtestpd vucomisd vucomiss vunpckhpd vunpckhps vunpcklpd vunpcklps vxorpd vxorps vzeroall vzeroupper pclmullqlqdq pclmulhqlqdq pclmullqhqdq pclmulhqhqdq pclmulqdq vpclmullqlqdq vpclmulhqlqdq vpclmullqhqdq vpclmulhqhqdq vpclmulqdq vfmadd132ps vfmadd132pd vfmadd312ps vfmadd312pd vfmadd213ps vfmadd213pd vfmadd123ps vfmadd123pd vfmadd231ps vfmadd231pd vfmadd321ps vfmadd321pd vfmaddsub132ps vfmaddsub132pd vfmaddsub312ps vfmaddsub312pd vfmaddsub213ps vfmaddsub213pd vfmaddsub123ps vfmaddsub123pd vfmaddsub231ps vfmaddsub231pd vfmaddsub321ps vfmaddsub321pd vfmsub132ps vfmsub132pd vfmsub312ps vfmsub312pd vfmsub213ps vfmsub213pd vfmsub123ps vfmsub123pd vfmsub231ps vfmsub231pd vfmsub321ps vfmsub321pd vfmsubadd132ps vfmsubadd132pd vfmsubadd312ps vfmsubadd312pd vfmsubadd213ps vfmsubadd213pd vfmsubadd123ps vfmsubadd123pd vfmsubadd231ps vfmsubadd231pd vfmsubadd321ps vfmsubadd321pd vfnmadd132ps vfnmadd132pd vfnmadd312ps vfnmadd312pd vfnmadd213ps vfnmadd213pd vfnmadd123ps vfnmadd123pd vfnmadd231ps vfnmadd231pd vfnmadd321ps vfnmadd321pd vfnmsub132ps vfnmsub132pd vfnmsub312ps vfnmsub312pd vfnmsub213ps vfnmsub213pd vfnmsub123ps vfnmsub123pd vfnmsub231ps vfnmsub231pd vfnmsub321ps vfnmsub321pd vfmadd132ss vfmadd132sd vfmadd312ss vfmadd312sd vfmadd213ss vfmadd213sd vfmadd123ss vfmadd123sd vfmadd231ss vfmadd231sd vfmadd321ss vfmadd321sd vfmsub132ss vfmsub132sd vfmsub312ss vfmsub312sd vfmsub213ss vfmsub213sd vfmsub123ss vfmsub123sd vfmsub231ss vfmsub231sd vfmsub321ss vfmsub321sd vfnmadd132ss vfnmadd132sd vfnmadd312ss vfnmadd312sd vfnmadd213ss vfnmadd213sd vfnmadd123ss vfnmadd123sd vfnmadd231ss vfnmadd231sd vfnmadd321ss vfnmadd321sd vfnmsub132ss vfnmsub132sd vfnmsub312ss vfnmsub312sd vfnmsub213ss vfnmsub213sd vfnmsub123ss vfnmsub123sd vfnmsub231ss vfnmsub231sd vfnmsub321ss vfnmsub321sd rdfsbase rdgsbase rdrand wrfsbase wrgsbase vcvtph2ps vcvtps2ph adcx adox rdseed clac stac xstore xcryptecb xcryptcbc xcryptctr xcryptcfb xcryptofb montmul xsha1 xsha256 llwpcb slwpcb lwpval lwpins vfmaddpd vfmaddps vfmaddsd vfmaddss vfmaddsubpd vfmaddsubps vfmsubaddpd vfmsubaddps vfmsubpd vfmsubps vfmsubsd vfmsubss vfnmaddpd vfnmaddps vfnmaddsd vfnmaddss vfnmsubpd vfnmsubps vfnmsubsd vfnmsubss vfrczpd vfrczps vfrczsd vfrczss vpcmov vpcomb vpcomd vpcomq vpcomub vpcomud vpcomuq vpcomuw vpcomw vphaddbd vphaddbq vphaddbw vphadddq vphaddubd vphaddubq vphaddubw vphaddudq vphadduwd vphadduwq vphaddwd vphaddwq vphsubbw vphsubdq vphsubwd vpmacsdd vpmacsdqh vpmacsdql vpmacssdd vpmacssdqh vpmacssdql vpmacsswd vpmacssww vpmacswd vpmacsww vpmadcsswd vpmadcswd vpperm vprotb vprotd vprotq vprotw vpshab vpshad vpshaq vpshaw vpshlb vpshld vpshlq vpshlw vbroadcasti128 vpblendd vpbroadcastb vpbroadcastw vpbroadcastd vpbroadcastq vpermd vpermpd vpermps vpermq vperm2i128 vextracti128 vinserti128 vpmaskmovd vpmaskmovq vpsllvd vpsllvq vpsravd vpsrlvd vpsrlvq vgatherdpd vgatherqpd vgatherdps vgatherqps vpgatherdd vpgatherqd vpgatherdq vpgatherqq xabort xbegin xend xtest andn bextr blci blcic blsi blsic blcfill blsfill blcmsk blsmsk blsr blcs bzhi mulx pdep pext rorx sarx shlx shrx tzcnt tzmsk t1mskc valignd valignq vblendmpd vblendmps vbroadcastf32x4 vbroadcastf64x4 vbroadcasti32x4 vbroadcasti64x4 vcompresspd vcompressps vcvtpd2udq vcvtps2udq vcvtsd2usi vcvtss2usi vcvttpd2udq vcvttps2udq vcvttsd2usi vcvttss2usi vcvtudq2pd vcvtudq2ps vcvtusi2sd vcvtusi2ss vexpandpd vexpandps vextractf32x4 vextractf64x4 vextracti32x4 vextracti64x4 vfixupimmpd vfixupimmps vfixupimmsd vfixupimmss vgetexppd vgetexpps vgetexpsd vgetexpss vgetmantpd vgetmantps vgetmantsd vgetmantss vinsertf32x4 vinsertf64x4 vinserti32x4 vinserti64x4 vmovdqa32 vmovdqa64 vmovdqu32 vmovdqu64 vpabsq vpandd vpandnd vpandnq vpandq vpblendmd vpblendmq vpcmpltd vpcmpled vpcmpneqd vpcmpnltd vpcmpnled vpcmpd vpcmpltq vpcmpleq vpcmpneqq vpcmpnltq vpcmpnleq vpcmpq vpcmpequd vpcmpltud vpcmpleud vpcmpnequd vpcmpnltud vpcmpnleud vpcmpud vpcmpequq vpcmpltuq vpcmpleuq vpcmpnequq vpcmpnltuq vpcmpnleuq vpcmpuq vpcompressd vpcompressq vpermi2d vpermi2pd vpermi2ps vpermi2q vpermt2d vpermt2pd vpermt2ps vpermt2q vpexpandd vpexpandq vpmaxsq vpmaxuq vpminsq vpminuq vpmovdb vpmovdw vpmovqb vpmovqd vpmovqw vpmovsdb vpmovsdw vpmovsqb vpmovsqd vpmovsqw vpmovusdb vpmovusdw vpmovusqb vpmovusqd vpmovusqw vpord vporq vprold vprolq vprolvd vprolvq vprord vprorq vprorvd vprorvq vpscatterdd vpscatterdq vpscatterqd vpscatterqq vpsraq vpsravq vpternlogd vpternlogq vptestmd vptestmq vptestnmd vptestnmq vpxord vpxorq vrcp14pd vrcp14ps vrcp14sd vrcp14ss vrndscalepd vrndscaleps vrndscalesd vrndscaless vrsqrt14pd vrsqrt14ps vrsqrt14sd vrsqrt14ss vscalefpd vscalefps vscalefsd vscalefss vscatterdpd vscatterdps vscatterqpd vscatterqps vshuff32x4 vshuff64x2 vshufi32x4 vshufi64x2 kandnw kandw kmovw knotw kortestw korw kshiftlw kshiftrw kunpckbw kxnorw kxorw vpbroadcastmb2q vpbroadcastmw2d vpconflictd vpconflictq vplzcntd vplzcntq vexp2pd vexp2ps vrcp28pd vrcp28ps vrcp28sd vrcp28ss vrsqrt28pd vrsqrt28ps vrsqrt28sd vrsqrt28ss vgatherpf0dpd vgatherpf0dps vgatherpf0qpd vgatherpf0qps vgatherpf1dpd vgatherpf1dps vgatherpf1qpd vgatherpf1qps vscatterpf0dpd vscatterpf0dps vscatterpf0qpd vscatterpf0qps vscatterpf1dpd vscatterpf1dps vscatterpf1qpd vscatterpf1qps prefetchwt1 bndmk bndcl bndcu bndcn bndmov bndldx bndstx sha1rnds4 sha1nexte sha1msg1 sha1msg2 sha256rnds2 sha256msg1 sha256msg2 hint_nop0 hint_nop1 hint_nop2 hint_nop3 hint_nop4 hint_nop5 hint_nop6 hint_nop7 hint_nop8 hint_nop9 hint_nop10 hint_nop11 hint_nop12 hint_nop13 hint_nop14 hint_nop15 hint_nop16 hint_nop17 hint_nop18 hint_nop19 hint_nop20 hint_nop21 hint_nop22 hint_nop23 hint_nop24 hint_nop25 hint_nop26 hint_nop27 hint_nop28 hint_nop29 hint_nop30 hint_nop31 hint_nop32 hint_nop33 hint_nop34 hint_nop35 hint_nop36 hint_nop37 hint_nop38 hint_nop39 hint_nop40 hint_nop41 hint_nop42 hint_nop43 hint_nop44 hint_nop45 hint_nop46 hint_nop47 hint_nop48 hint_nop49 hint_nop50 hint_nop51 hint_nop52 hint_nop53 hint_nop54 hint_nop55 hint_nop56 hint_nop57 hint_nop58 hint_nop59 hint_nop60 hint_nop61 hint_nop62 hint_nop63",
+built_in:"ip eip rip al ah bl bh cl ch dl dh sil dil bpl spl r8b r9b r10b r11b r12b r13b r14b r15b ax bx cx dx si di bp sp r8w r9w r10w r11w r12w r13w r14w r15w eax ebx ecx edx esi edi ebp esp eip r8d r9d r10d r11d r12d r13d r14d r15d rax rbx rcx rdx rsi rdi rbp rsp r8 r9 r10 r11 r12 r13 r14 r15 cs ds es fs gs ss st st0 st1 st2 st3 st4 st5 st6 st7 mm0 mm1 mm2 mm3 mm4 mm5 mm6 mm7 xmm0  xmm1  xmm2  xmm3  xmm4  xmm5  xmm6  xmm7  xmm8  xmm9 xmm10  xmm11 xmm12 xmm13 xmm14 xmm15 xmm16 xmm17 xmm18 xmm19 xmm20 xmm21 xmm22 xmm23 xmm24 xmm25 xmm26 xmm27 xmm28 xmm29 xmm30 xmm31 ymm0  ymm1  ymm2  ymm3  ymm4  ymm5  ymm6  ymm7  ymm8  ymm9 ymm10  ymm11 ymm12 ymm13 ymm14 ymm15 ymm16 ymm17 ymm18 ymm19 ymm20 ymm21 ymm22 ymm23 ymm24 ymm25 ymm26 ymm27 ymm28 ymm29 ymm30 ymm31 zmm0  zmm1  zmm2  zmm3  zmm4  zmm5  zmm6  zmm7  zmm8  zmm9 zmm10  zmm11 zmm12 zmm13 zmm14 zmm15 zmm16 zmm17 zmm18 zmm19 zmm20 zmm21 zmm22 zmm23 zmm24 zmm25 zmm26 zmm27 zmm28 zmm29 zmm30 zmm31 k0 k1 k2 k3 k4 k5 k6 k7 bnd0 bnd1 bnd2 bnd3 cr0 cr1 cr2 cr3 cr4 cr8 dr0 dr1 dr2 dr3 dr8 tr3 tr4 tr5 tr6 tr7 r0 r1 r2 r3 r4 r5 r6 r7 r0b r1b r2b r3b r4b r5b r6b r7b r0w r1w r2w r3w r4w r5w r6w r7w r0d r1d r2d r3d r4d r5d r6d r7d r0h r1h r2h r3h r0l r1l r2l r3l r4l r5l r6l r7l r8l r9l r10l r11l r12l r13l r14l r15l db dw dd dq dt ddq do dy dz resb resw resd resq rest resdq reso resy resz incbin equ times byte word dword qword nosplit rel abs seg wrt strict near far a32 ptr",
+meta:"%define %xdefine %+ %undef %defstr %deftok %assign %strcat %strlen %substr %rotate %elif %else %endif %if %ifmacro %ifctx %ifidn %ifidni %ifid %ifnum %ifstr %iftoken %ifempty %ifenv %error %warning %fatal %rep %endrep %include %push %pop %repl %pathsearch %depend %use %arg %stacksize %local %line %comment %endcomment .nolist __FILE__ __LINE__ __SECT__  __BITS__ __OUTPUT_FORMAT__ __DATE__ __TIME__ __DATE_NUM__ __TIME_NUM__ __UTC_DATE__ __UTC_TIME__ __UTC_DATE_NUM__ __UTC_TIME_NUM__  __PASS__ struc endstruc istruc at iend align alignb sectalign daz nodaz up down zero default option assume public bits use16 use32 use64 default section segment absolute extern global common cpu float __utf16__ __utf16le__ __utf16be__ __utf32__ __utf32le__ __utf32be__ __float8__ __float16__ __float32__ __float64__ __float80m__ __float80e__ __float128l__ __float128h__ __Infinity__ __QNaN__ __SNaN__ Inf NaN QNaN SNaN float8 float16 float32 float64 float80m float80e float128l float128h __FLOAT_DAZ__ __FLOAT_ROUND__ __FLOAT__"
+},contains:[s.COMMENT(";","$",{relevance:0}),{className:"number",variants:[{
+begin:"\\b(?:([0-9][0-9_]*)?\\.[0-9_]*(?:[eE][+-]?[0-9_]+)?|(0[Xx])?[0-9][0-9_]*\\.?[0-9_]*(?:[pP](?:[+-]?[0-9_]+)?)?)\\b",
+relevance:0},{begin:"\\$[0-9][0-9A-Fa-f]*",relevance:0},{
+begin:"\\b(?:[0-9A-Fa-f][0-9A-Fa-f_]*[Hh]|[0-9][0-9_]*[DdTt]?|[0-7][0-7_]*[QqOo]|[0-1][0-1_]*[BbYy])\\b"
+},{
+begin:"\\b(?:0[Xx][0-9A-Fa-f_]+|0[DdTt][0-9_]+|0[QqOo][0-7_]+|0[BbYy][0-1_]+)\\b"
+}]},s.QUOTE_STRING_MODE,{className:"string",variants:[{begin:"'",end:"[^\\\\]'"
+},{begin:"`",end:"[^\\\\]`"}],relevance:0},{className:"symbol",variants:[{
+begin:"^\\s*[A-Za-z._?][A-Za-z0-9_$#@~.?]*(:|\\s+label)"},{
+begin:"^\\s*%%[A-Za-z0-9_$#@~.?]*:"}],relevance:0},{className:"subst",
+begin:"%[0-9]+",relevance:0},{className:"subst",begin:"%!S+",relevance:0},{
+className:"meta",begin:/^\s*\.[\w_-]+/}]})})());hljs.registerLanguage("asciidoc",(()=>{"use strict";return e=>({name:"AsciiDoc",
+aliases:["adoc"],contains:[e.COMMENT("^/{4,}\\n","\\n/{4,}$",{relevance:10
+}),e.COMMENT("^//","$",{relevance:0}),{className:"title",begin:"^\\.\\w.*$"},{
+begin:"^[=\\*]{4,}\\n",end:"\\n^[=\\*]{4,}$",relevance:10},{className:"section",
+relevance:10,variants:[{begin:"^(={1,5}) .+?( \\1)?$"},{
+begin:"^[^\\[\\]\\n]+?\\n[=\\-~\\^\\+]{2,}$"}]},{className:"meta",
+begin:"^:.+?:",end:"\\s",excludeEnd:!0,relevance:10},{className:"meta",
+begin:"^\\[.+?\\]$",relevance:0},{className:"quote",begin:"^_{4,}\\n",
+end:"\\n_{4,}$",relevance:10},{className:"code",begin:"^[\\-\\.]{4,}\\n",
+end:"\\n[\\-\\.]{4,}$",relevance:10},{begin:"^\\+{4,}\\n",end:"\\n\\+{4,}$",
+contains:[{begin:"<",end:">",subLanguage:"xml",relevance:0}],relevance:10},{
+className:"bullet",begin:"^(\\*+|-+|\\.+|[^\\n]+?::)\\s+"},{className:"symbol",
+begin:"^(NOTE|TIP|IMPORTANT|WARNING|CAUTION):\\s+",relevance:10},{
+className:"strong",begin:"\\B\\*(?![\\*\\s])",end:"(\\n{2}|\\*)",contains:[{
+begin:"\\\\*\\w",relevance:0}]},{className:"emphasis",begin:"\\B'(?!['\\s])",
+end:"(\\n{2}|')",contains:[{begin:"\\\\'\\w",relevance:0}],relevance:0},{
+className:"emphasis",begin:"_(?![_\\s])",end:"(\\n{2}|_)",relevance:0},{
+className:"string",variants:[{begin:"``.+?''"},{begin:"`.+?'"}]},{
+className:"code",begin:"(`.+?`|\\+.+?\\+)",relevance:0},{className:"code",
+begin:"^[ \\t]",end:"$",relevance:0},{begin:"^'{3,}[ \\t]*$",relevance:10},{
+begin:"(link:)?(http|https|ftp|file|irc|image:?):\\S+\\[.*?\\]",returnBegin:!0,
+contains:[{begin:"(link|image:?):",relevance:0},{className:"link",begin:"\\w",
+end:"[^\\[]+",relevance:0},{className:"string",begin:"\\[",end:"\\]",
+excludeBegin:!0,excludeEnd:!0,relevance:0}],relevance:10}]})})());hljs.registerLanguage("perl",(()=>{"use strict";function e(...e){
+return e.map((e=>{return(n=e)?"string"==typeof n?n:n.source:null;var n
+})).join("")}return n=>{var t={$pattern:/[\w.]+/,
+keyword:"getpwent getservent quotemeta msgrcv scalar kill dbmclose undef lc ma syswrite tr send umask sysopen shmwrite vec qx utime local oct semctl localtime readpipe do return format read sprintf dbmopen pop getpgrp not getpwnam rewinddir qq fileno qw endprotoent wait sethostent bless s|0 opendir continue each sleep endgrent shutdown dump chomp connect getsockname die socketpair close flock exists index shmget sub for endpwent redo lstat msgctl setpgrp abs exit select print ref gethostbyaddr unshift fcntl syscall goto getnetbyaddr join gmtime symlink semget splice x|0 getpeername recv log setsockopt cos last reverse gethostbyname getgrnam study formline endhostent times chop length gethostent getnetent pack getprotoent getservbyname rand mkdir pos chmod y|0 substr endnetent printf next open msgsnd readdir use unlink getsockopt getpriority rindex wantarray hex system getservbyport endservent int chr untie rmdir prototype tell listen fork shmread ucfirst setprotoent else sysseek link getgrgid shmctl waitpid unpack getnetbyname reset chdir grep split require caller lcfirst until warn while values shift telldir getpwuid my getprotobynumber delete and sort uc defined srand accept package seekdir getprotobyname semop our rename seek if q|0 chroot sysread setpwent no crypt getc chown sqrt write setnetent setpriority foreach tie sin msgget map stat getlogin unless elsif truncate exec keys glob tied closedir ioctl socket readlink eval xor readline binmode setservent eof ord bind alarm pipe atan2 getgrent exp time push setgrent gt lt or ne m|0 break given say state when"
+},s={className:"subst",begin:"[$@]\\{",end:"\\}",keywords:t},r={begin:/->\{/,
+end:/\}/},i={variants:[{begin:/\$\d/},{
+begin:e(/[$%@](\^\w\b|#\w+(::\w+)*|\{\w+\}|\w+(::\w*)*)/,"(?![A-Za-z])(?![@$%])")
+},{begin:/[$%@][^\s\w{]/,relevance:0}]
+},a=[n.BACKSLASH_ESCAPE,s,i],o=[i,n.HASH_COMMENT_MODE,n.COMMENT(/^=\w/,/=cut/,{
+endsWithParent:!0}),r,{className:"string",contains:a,variants:[{
+begin:"q[qwxr]?\\s*\\(",end:"\\)",relevance:5},{begin:"q[qwxr]?\\s*\\[",
+end:"\\]",relevance:5},{begin:"q[qwxr]?\\s*\\{",end:"\\}",relevance:5},{
+begin:"q[qwxr]?\\s*\\|",end:"\\|",relevance:5},{begin:"q[qwxr]?\\s*<",end:">",
+relevance:5},{begin:"qw\\s+q",end:"q",relevance:5},{begin:"'",end:"'",
+contains:[n.BACKSLASH_ESCAPE]},{begin:'"',end:'"'},{begin:"`",end:"`",
+contains:[n.BACKSLASH_ESCAPE]},{begin:/\{\w+\}/,contains:[],relevance:0},{
+begin:"-?\\w+\\s*=>",contains:[],relevance:0}]},{className:"number",
+begin:"(\\b0[0-7_]+)|(\\b0x[0-9a-fA-F_]+)|(\\b[1-9][0-9_]*(\\.[0-9_]+)?)|[0_]\\b",
+relevance:0},{
+begin:"(\\/\\/|"+n.RE_STARTERS_RE+"|\\b(split|return|print|reverse|grep)\\b)\\s*",
+keywords:"split return print reverse grep",relevance:0,
+contains:[n.HASH_COMMENT_MODE,{className:"regexp",
+begin:"(s|tr|y)/(\\\\.|[^/])*/(\\\\.|[^/])*/[a-z]*",relevance:10},{
+className:"regexp",begin:"(m|qr)?/",end:"/[a-z]*",contains:[n.BACKSLASH_ESCAPE],
+relevance:0}]},{className:"function",beginKeywords:"sub",
+end:"(\\s*\\(.*?\\))?[;{]",excludeEnd:!0,relevance:5,contains:[n.TITLE_MODE]},{
+begin:"-\\w\\b",relevance:0},{begin:"^__DATA__$",end:"^__END__$",
+subLanguage:"mojolicious",contains:[{begin:"^@@.*",end:"$",className:"comment"}]
+}];return s.contains=o,r.contains=o,{name:"Perl",aliases:["pl","pm"],keywords:t,
+contains:o}}})());hljs.registerLanguage("pgsql",(()=>{"use strict";return E=>{
+const T=E.COMMENT("--","$"),N="\\$([a-zA-Z_]?|[a-zA-Z_][a-zA-Z_0-9]*)\\$",A="BIGINT INT8 BIGSERIAL SERIAL8 BIT VARYING VARBIT BOOLEAN BOOL BOX BYTEA CHARACTER CHAR VARCHAR CIDR CIRCLE DATE DOUBLE PRECISION FLOAT8 FLOAT INET INTEGER INT INT4 INTERVAL JSON JSONB LINE LSEG|10 MACADDR MACADDR8 MONEY NUMERIC DEC DECIMAL PATH POINT POLYGON REAL FLOAT4 SMALLINT INT2 SMALLSERIAL|10 SERIAL2|10 SERIAL|10 SERIAL4|10 TEXT TIME ZONE TIMETZ|10 TIMESTAMP TIMESTAMPTZ|10 TSQUERY|10 TSVECTOR|10 TXID_SNAPSHOT|10 UUID XML NATIONAL NCHAR INT4RANGE|10 INT8RANGE|10 NUMRANGE|10 TSRANGE|10 TSTZRANGE|10 DATERANGE|10 ANYELEMENT ANYARRAY ANYNONARRAY ANYENUM ANYRANGE CSTRING INTERNAL RECORD PG_DDL_COMMAND VOID UNKNOWN OPAQUE REFCURSOR NAME OID REGPROC|10 REGPROCEDURE|10 REGOPER|10 REGOPERATOR|10 REGCLASS|10 REGTYPE|10 REGROLE|10 REGNAMESPACE|10 REGCONFIG|10 REGDICTIONARY|10 ",R=A.trim().split(" ").map((E=>E.split("|")[0])).join("|"),I="ARRAY_AGG AVG BIT_AND BIT_OR BOOL_AND BOOL_OR COUNT EVERY JSON_AGG JSONB_AGG JSON_OBJECT_AGG JSONB_OBJECT_AGG MAX MIN MODE STRING_AGG SUM XMLAGG CORR COVAR_POP COVAR_SAMP REGR_AVGX REGR_AVGY REGR_COUNT REGR_INTERCEPT REGR_R2 REGR_SLOPE REGR_SXX REGR_SXY REGR_SYY STDDEV STDDEV_POP STDDEV_SAMP VARIANCE VAR_POP VAR_SAMP PERCENTILE_CONT PERCENTILE_DISC ROW_NUMBER RANK DENSE_RANK PERCENT_RANK CUME_DIST NTILE LAG LEAD FIRST_VALUE LAST_VALUE NTH_VALUE NUM_NONNULLS NUM_NULLS ABS CBRT CEIL CEILING DEGREES DIV EXP FLOOR LN LOG MOD PI POWER RADIANS ROUND SCALE SIGN SQRT TRUNC WIDTH_BUCKET RANDOM SETSEED ACOS ACOSD ASIN ASIND ATAN ATAND ATAN2 ATAN2D COS COSD COT COTD SIN SIND TAN TAND BIT_LENGTH CHAR_LENGTH CHARACTER_LENGTH LOWER OCTET_LENGTH OVERLAY POSITION SUBSTRING TREAT TRIM UPPER ASCII BTRIM CHR CONCAT CONCAT_WS CONVERT CONVERT_FROM CONVERT_TO DECODE ENCODE INITCAP LEFT LENGTH LPAD LTRIM MD5 PARSE_IDENT PG_CLIENT_ENCODING QUOTE_IDENT|10 QUOTE_LITERAL|10 QUOTE_NULLABLE|10 REGEXP_MATCH REGEXP_MATCHES REGEXP_REPLACE REGEXP_SPLIT_TO_ARRAY REGEXP_SPLIT_TO_TABLE REPEAT REPLACE REVERSE RIGHT RPAD RTRIM SPLIT_PART STRPOS SUBSTR TO_ASCII TO_HEX TRANSLATE OCTET_LENGTH GET_BIT GET_BYTE SET_BIT SET_BYTE TO_CHAR TO_DATE TO_NUMBER TO_TIMESTAMP AGE CLOCK_TIMESTAMP|10 DATE_PART DATE_TRUNC ISFINITE JUSTIFY_DAYS JUSTIFY_HOURS JUSTIFY_INTERVAL MAKE_DATE MAKE_INTERVAL|10 MAKE_TIME MAKE_TIMESTAMP|10 MAKE_TIMESTAMPTZ|10 NOW STATEMENT_TIMESTAMP|10 TIMEOFDAY TRANSACTION_TIMESTAMP|10 ENUM_FIRST ENUM_LAST ENUM_RANGE AREA CENTER DIAMETER HEIGHT ISCLOSED ISOPEN NPOINTS PCLOSE POPEN RADIUS WIDTH BOX BOUND_BOX CIRCLE LINE LSEG PATH POLYGON ABBREV BROADCAST HOST HOSTMASK MASKLEN NETMASK NETWORK SET_MASKLEN TEXT INET_SAME_FAMILY INET_MERGE MACADDR8_SET7BIT ARRAY_TO_TSVECTOR GET_CURRENT_TS_CONFIG NUMNODE PLAINTO_TSQUERY PHRASETO_TSQUERY WEBSEARCH_TO_TSQUERY QUERYTREE SETWEIGHT STRIP TO_TSQUERY TO_TSVECTOR JSON_TO_TSVECTOR JSONB_TO_TSVECTOR TS_DELETE TS_FILTER TS_HEADLINE TS_RANK TS_RANK_CD TS_REWRITE TSQUERY_PHRASE TSVECTOR_TO_ARRAY TSVECTOR_UPDATE_TRIGGER TSVECTOR_UPDATE_TRIGGER_COLUMN XMLCOMMENT XMLCONCAT XMLELEMENT XMLFOREST XMLPI XMLROOT XMLEXISTS XML_IS_WELL_FORMED XML_IS_WELL_FORMED_DOCUMENT XML_IS_WELL_FORMED_CONTENT XPATH XPATH_EXISTS XMLTABLE XMLNAMESPACES TABLE_TO_XML TABLE_TO_XMLSCHEMA TABLE_TO_XML_AND_XMLSCHEMA QUERY_TO_XML QUERY_TO_XMLSCHEMA QUERY_TO_XML_AND_XMLSCHEMA CURSOR_TO_XML CURSOR_TO_XMLSCHEMA SCHEMA_TO_XML SCHEMA_TO_XMLSCHEMA SCHEMA_TO_XML_AND_XMLSCHEMA DATABASE_TO_XML DATABASE_TO_XMLSCHEMA DATABASE_TO_XML_AND_XMLSCHEMA XMLATTRIBUTES TO_JSON TO_JSONB ARRAY_TO_JSON ROW_TO_JSON JSON_BUILD_ARRAY JSONB_BUILD_ARRAY JSON_BUILD_OBJECT JSONB_BUILD_OBJECT JSON_OBJECT JSONB_OBJECT JSON_ARRAY_LENGTH JSONB_ARRAY_LENGTH JSON_EACH JSONB_EACH JSON_EACH_TEXT JSONB_EACH_TEXT JSON_EXTRACT_PATH JSONB_EXTRACT_PATH JSON_OBJECT_KEYS JSONB_OBJECT_KEYS JSON_POPULATE_RECORD JSONB_POPULATE_RECORD JSON_POPULATE_RECORDSET JSONB_POPULATE_RECORDSET JSON_ARRAY_ELEMENTS JSONB_ARRAY_ELEMENTS JSON_ARRAY_ELEMENTS_TEXT JSONB_ARRAY_ELEMENTS_TEXT JSON_TYPEOF JSONB_TYPEOF JSON_TO_RECORD JSONB_TO_RECORD JSON_TO_RECORDSET JSONB_TO_RECORDSET JSON_STRIP_NULLS JSONB_STRIP_NULLS JSONB_SET JSONB_INSERT JSONB_PRETTY CURRVAL LASTVAL NEXTVAL SETVAL COALESCE NULLIF GREATEST LEAST ARRAY_APPEND ARRAY_CAT ARRAY_NDIMS ARRAY_DIMS ARRAY_FILL ARRAY_LENGTH ARRAY_LOWER ARRAY_POSITION ARRAY_POSITIONS ARRAY_PREPEND ARRAY_REMOVE ARRAY_REPLACE ARRAY_TO_STRING ARRAY_UPPER CARDINALITY STRING_TO_ARRAY UNNEST ISEMPTY LOWER_INC UPPER_INC LOWER_INF UPPER_INF RANGE_MERGE GENERATE_SERIES GENERATE_SUBSCRIPTS CURRENT_DATABASE CURRENT_QUERY CURRENT_SCHEMA|10 CURRENT_SCHEMAS|10 INET_CLIENT_ADDR INET_CLIENT_PORT INET_SERVER_ADDR INET_SERVER_PORT ROW_SECURITY_ACTIVE FORMAT_TYPE TO_REGCLASS TO_REGPROC TO_REGPROCEDURE TO_REGOPER TO_REGOPERATOR TO_REGTYPE TO_REGNAMESPACE TO_REGROLE COL_DESCRIPTION OBJ_DESCRIPTION SHOBJ_DESCRIPTION TXID_CURRENT TXID_CURRENT_IF_ASSIGNED TXID_CURRENT_SNAPSHOT TXID_SNAPSHOT_XIP TXID_SNAPSHOT_XMAX TXID_SNAPSHOT_XMIN TXID_VISIBLE_IN_SNAPSHOT TXID_STATUS CURRENT_SETTING SET_CONFIG BRIN_SUMMARIZE_NEW_VALUES BRIN_SUMMARIZE_RANGE BRIN_DESUMMARIZE_RANGE GIN_CLEAN_PENDING_LIST SUPPRESS_REDUNDANT_UPDATES_TRIGGER LO_FROM_BYTEA LO_PUT LO_GET LO_CREAT LO_CREATE LO_UNLINK LO_IMPORT LO_EXPORT LOREAD LOWRITE GROUPING CAST".split(" ").map((E=>E.split("|")[0])).join("|")
+;return{name:"PostgreSQL",aliases:["postgres","postgresql"],case_insensitive:!0,
+keywords:{
+keyword:"ABORT ALTER ANALYZE BEGIN CALL CHECKPOINT|10 CLOSE CLUSTER COMMENT COMMIT COPY CREATE DEALLOCATE DECLARE DELETE DISCARD DO DROP END EXECUTE EXPLAIN FETCH GRANT IMPORT INSERT LISTEN LOAD LOCK MOVE NOTIFY PREPARE REASSIGN|10 REFRESH REINDEX RELEASE RESET REVOKE ROLLBACK SAVEPOINT SECURITY SELECT SET SHOW START TRUNCATE UNLISTEN|10 UPDATE VACUUM|10 VALUES AGGREGATE COLLATION CONVERSION|10 DATABASE DEFAULT PRIVILEGES DOMAIN TRIGGER EXTENSION FOREIGN WRAPPER|10 TABLE FUNCTION GROUP LANGUAGE LARGE OBJECT MATERIALIZED VIEW OPERATOR CLASS FAMILY POLICY PUBLICATION|10 ROLE RULE SCHEMA SEQUENCE SERVER STATISTICS SUBSCRIPTION SYSTEM TABLESPACE CONFIGURATION DICTIONARY PARSER TEMPLATE TYPE USER MAPPING PREPARED ACCESS METHOD CAST AS TRANSFORM TRANSACTION OWNED TO INTO SESSION AUTHORIZATION INDEX PROCEDURE ASSERTION ALL ANALYSE AND ANY ARRAY ASC ASYMMETRIC|10 BOTH CASE CHECK COLLATE COLUMN CONCURRENTLY|10 CONSTRAINT CROSS DEFERRABLE RANGE DESC DISTINCT ELSE EXCEPT FOR FREEZE|10 FROM FULL HAVING ILIKE IN INITIALLY INNER INTERSECT IS ISNULL JOIN LATERAL LEADING LIKE LIMIT NATURAL NOT NOTNULL NULL OFFSET ON ONLY OR ORDER OUTER OVERLAPS PLACING PRIMARY REFERENCES RETURNING SIMILAR SOME SYMMETRIC TABLESAMPLE THEN TRAILING UNION UNIQUE USING VARIADIC|10 VERBOSE WHEN WHERE WINDOW WITH BY RETURNS INOUT OUT SETOF|10 IF STRICT CURRENT CONTINUE OWNER LOCATION OVER PARTITION WITHIN BETWEEN ESCAPE EXTERNAL INVOKER DEFINER WORK RENAME VERSION CONNECTION CONNECT TABLES TEMP TEMPORARY FUNCTIONS SEQUENCES TYPES SCHEMAS OPTION CASCADE RESTRICT ADD ADMIN EXISTS VALID VALIDATE ENABLE DISABLE REPLICA|10 ALWAYS PASSING COLUMNS PATH REF VALUE OVERRIDING IMMUTABLE STABLE VOLATILE BEFORE AFTER EACH ROW PROCEDURAL ROUTINE NO HANDLER VALIDATOR OPTIONS STORAGE OIDS|10 WITHOUT INHERIT DEPENDS CALLED INPUT LEAKPROOF|10 COST ROWS NOWAIT SEARCH UNTIL ENCRYPTED|10 PASSWORD CONFLICT|10 INSTEAD INHERITS CHARACTERISTICS WRITE CURSOR ALSO STATEMENT SHARE EXCLUSIVE INLINE ISOLATION REPEATABLE READ COMMITTED SERIALIZABLE UNCOMMITTED LOCAL GLOBAL SQL PROCEDURES RECURSIVE SNAPSHOT ROLLUP CUBE TRUSTED|10 INCLUDE FOLLOWING PRECEDING UNBOUNDED RANGE GROUPS UNENCRYPTED|10 SYSID FORMAT DELIMITER HEADER QUOTE ENCODING FILTER OFF FORCE_QUOTE FORCE_NOT_NULL FORCE_NULL COSTS BUFFERS TIMING SUMMARY DISABLE_PAGE_SKIPPING RESTART CYCLE GENERATED IDENTITY DEFERRED IMMEDIATE LEVEL LOGGED UNLOGGED OF NOTHING NONE EXCLUDE ATTRIBUTE USAGE ROUTINES TRUE FALSE NAN INFINITY ALIAS BEGIN CONSTANT DECLARE END EXCEPTION RETURN PERFORM|10 RAISE GET DIAGNOSTICS STACKED|10 FOREACH LOOP ELSIF EXIT WHILE REVERSE SLICE DEBUG LOG INFO NOTICE WARNING ASSERT OPEN SUPERUSER NOSUPERUSER CREATEDB NOCREATEDB CREATEROLE NOCREATEROLE INHERIT NOINHERIT LOGIN NOLOGIN REPLICATION NOREPLICATION BYPASSRLS NOBYPASSRLS ",
+built_in:"CURRENT_TIME CURRENT_TIMESTAMP CURRENT_USER CURRENT_CATALOG|10 CURRENT_DATE LOCALTIME LOCALTIMESTAMP CURRENT_ROLE|10 CURRENT_SCHEMA|10 SESSION_USER PUBLIC FOUND NEW OLD TG_NAME|10 TG_WHEN|10 TG_LEVEL|10 TG_OP|10 TG_RELID|10 TG_RELNAME|10 TG_TABLE_NAME|10 TG_TABLE_SCHEMA|10 TG_NARGS|10 TG_ARGV|10 TG_EVENT|10 TG_TAG|10 ROW_COUNT RESULT_OID|10 PG_CONTEXT|10 RETURNED_SQLSTATE COLUMN_NAME CONSTRAINT_NAME PG_DATATYPE_NAME|10 MESSAGE_TEXT TABLE_NAME SCHEMA_NAME PG_EXCEPTION_DETAIL|10 PG_EXCEPTION_HINT|10 PG_EXCEPTION_CONTEXT|10 SQLSTATE SQLERRM|10 SUCCESSFUL_COMPLETION WARNING DYNAMIC_RESULT_SETS_RETURNED IMPLICIT_ZERO_BIT_PADDING NULL_VALUE_ELIMINATED_IN_SET_FUNCTION PRIVILEGE_NOT_GRANTED PRIVILEGE_NOT_REVOKED STRING_DATA_RIGHT_TRUNCATION DEPRECATED_FEATURE NO_DATA NO_ADDITIONAL_DYNAMIC_RESULT_SETS_RETURNED SQL_STATEMENT_NOT_YET_COMPLETE CONNECTION_EXCEPTION CONNECTION_DOES_NOT_EXIST CONNECTION_FAILURE SQLCLIENT_UNABLE_TO_ESTABLISH_SQLCONNECTION SQLSERVER_REJECTED_ESTABLISHMENT_OF_SQLCONNECTION TRANSACTION_RESOLUTION_UNKNOWN PROTOCOL_VIOLATION TRIGGERED_ACTION_EXCEPTION FEATURE_NOT_SUPPORTED INVALID_TRANSACTION_INITIATION LOCATOR_EXCEPTION INVALID_LOCATOR_SPECIFICATION INVALID_GRANTOR INVALID_GRANT_OPERATION INVALID_ROLE_SPECIFICATION DIAGNOSTICS_EXCEPTION STACKED_DIAGNOSTICS_ACCESSED_WITHOUT_ACTIVE_HANDLER CASE_NOT_FOUND CARDINALITY_VIOLATION DATA_EXCEPTION ARRAY_SUBSCRIPT_ERROR CHARACTER_NOT_IN_REPERTOIRE DATETIME_FIELD_OVERFLOW DIVISION_BY_ZERO ERROR_IN_ASSIGNMENT ESCAPE_CHARACTER_CONFLICT INDICATOR_OVERFLOW INTERVAL_FIELD_OVERFLOW INVALID_ARGUMENT_FOR_LOGARITHM INVALID_ARGUMENT_FOR_NTILE_FUNCTION INVALID_ARGUMENT_FOR_NTH_VALUE_FUNCTION INVALID_ARGUMENT_FOR_POWER_FUNCTION INVALID_ARGUMENT_FOR_WIDTH_BUCKET_FUNCTION INVALID_CHARACTER_VALUE_FOR_CAST INVALID_DATETIME_FORMAT INVALID_ESCAPE_CHARACTER INVALID_ESCAPE_OCTET INVALID_ESCAPE_SEQUENCE NONSTANDARD_USE_OF_ESCAPE_CHARACTER INVALID_INDICATOR_PARAMETER_VALUE INVALID_PARAMETER_VALUE INVALID_REGULAR_EXPRESSION INVALID_ROW_COUNT_IN_LIMIT_CLAUSE INVALID_ROW_COUNT_IN_RESULT_OFFSET_CLAUSE INVALID_TABLESAMPLE_ARGUMENT INVALID_TABLESAMPLE_REPEAT INVALID_TIME_ZONE_DISPLACEMENT_VALUE INVALID_USE_OF_ESCAPE_CHARACTER MOST_SPECIFIC_TYPE_MISMATCH NULL_VALUE_NOT_ALLOWED NULL_VALUE_NO_INDICATOR_PARAMETER NUMERIC_VALUE_OUT_OF_RANGE SEQUENCE_GENERATOR_LIMIT_EXCEEDED STRING_DATA_LENGTH_MISMATCH STRING_DATA_RIGHT_TRUNCATION SUBSTRING_ERROR TRIM_ERROR UNTERMINATED_C_STRING ZERO_LENGTH_CHARACTER_STRING FLOATING_POINT_EXCEPTION INVALID_TEXT_REPRESENTATION INVALID_BINARY_REPRESENTATION BAD_COPY_FILE_FORMAT UNTRANSLATABLE_CHARACTER NOT_AN_XML_DOCUMENT INVALID_XML_DOCUMENT INVALID_XML_CONTENT INVALID_XML_COMMENT INVALID_XML_PROCESSING_INSTRUCTION INTEGRITY_CONSTRAINT_VIOLATION RESTRICT_VIOLATION NOT_NULL_VIOLATION FOREIGN_KEY_VIOLATION UNIQUE_VIOLATION CHECK_VIOLATION EXCLUSION_VIOLATION INVALID_CURSOR_STATE INVALID_TRANSACTION_STATE ACTIVE_SQL_TRANSACTION BRANCH_TRANSACTION_ALREADY_ACTIVE HELD_CURSOR_REQUIRES_SAME_ISOLATION_LEVEL INAPPROPRIATE_ACCESS_MODE_FOR_BRANCH_TRANSACTION INAPPROPRIATE_ISOLATION_LEVEL_FOR_BRANCH_TRANSACTION NO_ACTIVE_SQL_TRANSACTION_FOR_BRANCH_TRANSACTION READ_ONLY_SQL_TRANSACTION SCHEMA_AND_DATA_STATEMENT_MIXING_NOT_SUPPORTED NO_ACTIVE_SQL_TRANSACTION IN_FAILED_SQL_TRANSACTION IDLE_IN_TRANSACTION_SESSION_TIMEOUT INVALID_SQL_STATEMENT_NAME TRIGGERED_DATA_CHANGE_VIOLATION INVALID_AUTHORIZATION_SPECIFICATION INVALID_PASSWORD DEPENDENT_PRIVILEGE_DESCRIPTORS_STILL_EXIST DEPENDENT_OBJECTS_STILL_EXIST INVALID_TRANSACTION_TERMINATION SQL_ROUTINE_EXCEPTION FUNCTION_EXECUTED_NO_RETURN_STATEMENT MODIFYING_SQL_DATA_NOT_PERMITTED PROHIBITED_SQL_STATEMENT_ATTEMPTED READING_SQL_DATA_NOT_PERMITTED INVALID_CURSOR_NAME EXTERNAL_ROUTINE_EXCEPTION CONTAINING_SQL_NOT_PERMITTED MODIFYING_SQL_DATA_NOT_PERMITTED PROHIBITED_SQL_STATEMENT_ATTEMPTED READING_SQL_DATA_NOT_PERMITTED EXTERNAL_ROUTINE_INVOCATION_EXCEPTION INVALID_SQLSTATE_RETURNED NULL_VALUE_NOT_ALLOWED TRIGGER_PROTOCOL_VIOLATED SRF_PROTOCOL_VIOLATED EVENT_TRIGGER_PROTOCOL_VIOLATED SAVEPOINT_EXCEPTION INVALID_SAVEPOINT_SPECIFICATION INVALID_CATALOG_NAME INVALID_SCHEMA_NAME TRANSACTION_ROLLBACK TRANSACTION_INTEGRITY_CONSTRAINT_VIOLATION SERIALIZATION_FAILURE STATEMENT_COMPLETION_UNKNOWN DEADLOCK_DETECTED SYNTAX_ERROR_OR_ACCESS_RULE_VIOLATION SYNTAX_ERROR INSUFFICIENT_PRIVILEGE CANNOT_COERCE GROUPING_ERROR WINDOWING_ERROR INVALID_RECURSION INVALID_FOREIGN_KEY INVALID_NAME NAME_TOO_LONG RESERVED_NAME DATATYPE_MISMATCH INDETERMINATE_DATATYPE COLLATION_MISMATCH INDETERMINATE_COLLATION WRONG_OBJECT_TYPE GENERATED_ALWAYS UNDEFINED_COLUMN UNDEFINED_FUNCTION UNDEFINED_TABLE UNDEFINED_PARAMETER UNDEFINED_OBJECT DUPLICATE_COLUMN DUPLICATE_CURSOR DUPLICATE_DATABASE DUPLICATE_FUNCTION DUPLICATE_PREPARED_STATEMENT DUPLICATE_SCHEMA DUPLICATE_TABLE DUPLICATE_ALIAS DUPLICATE_OBJECT AMBIGUOUS_COLUMN AMBIGUOUS_FUNCTION AMBIGUOUS_PARAMETER AMBIGUOUS_ALIAS INVALID_COLUMN_REFERENCE INVALID_COLUMN_DEFINITION INVALID_CURSOR_DEFINITION INVALID_DATABASE_DEFINITION INVALID_FUNCTION_DEFINITION INVALID_PREPARED_STATEMENT_DEFINITION INVALID_SCHEMA_DEFINITION INVALID_TABLE_DEFINITION INVALID_OBJECT_DEFINITION WITH_CHECK_OPTION_VIOLATION INSUFFICIENT_RESOURCES DISK_FULL OUT_OF_MEMORY TOO_MANY_CONNECTIONS CONFIGURATION_LIMIT_EXCEEDED PROGRAM_LIMIT_EXCEEDED STATEMENT_TOO_COMPLEX TOO_MANY_COLUMNS TOO_MANY_ARGUMENTS OBJECT_NOT_IN_PREREQUISITE_STATE OBJECT_IN_USE CANT_CHANGE_RUNTIME_PARAM LOCK_NOT_AVAILABLE OPERATOR_INTERVENTION QUERY_CANCELED ADMIN_SHUTDOWN CRASH_SHUTDOWN CANNOT_CONNECT_NOW DATABASE_DROPPED SYSTEM_ERROR IO_ERROR UNDEFINED_FILE DUPLICATE_FILE SNAPSHOT_TOO_OLD CONFIG_FILE_ERROR LOCK_FILE_EXISTS FDW_ERROR FDW_COLUMN_NAME_NOT_FOUND FDW_DYNAMIC_PARAMETER_VALUE_NEEDED FDW_FUNCTION_SEQUENCE_ERROR FDW_INCONSISTENT_DESCRIPTOR_INFORMATION FDW_INVALID_ATTRIBUTE_VALUE FDW_INVALID_COLUMN_NAME FDW_INVALID_COLUMN_NUMBER FDW_INVALID_DATA_TYPE FDW_INVALID_DATA_TYPE_DESCRIPTORS FDW_INVALID_DESCRIPTOR_FIELD_IDENTIFIER FDW_INVALID_HANDLE FDW_INVALID_OPTION_INDEX FDW_INVALID_OPTION_NAME FDW_INVALID_STRING_LENGTH_OR_BUFFER_LENGTH FDW_INVALID_STRING_FORMAT FDW_INVALID_USE_OF_NULL_POINTER FDW_TOO_MANY_HANDLES FDW_OUT_OF_MEMORY FDW_NO_SCHEMAS FDW_OPTION_NAME_NOT_FOUND FDW_REPLY_HANDLE FDW_SCHEMA_NOT_FOUND FDW_TABLE_NOT_FOUND FDW_UNABLE_TO_CREATE_EXECUTION FDW_UNABLE_TO_CREATE_REPLY FDW_UNABLE_TO_ESTABLISH_CONNECTION PLPGSQL_ERROR RAISE_EXCEPTION NO_DATA_FOUND TOO_MANY_ROWS ASSERT_FAILURE INTERNAL_ERROR DATA_CORRUPTED INDEX_CORRUPTED "
+},illegal:/:==|\W\s*\(\*|(^|\s)\$[a-z]|\{\{|[a-z]:\s*$|\.\.\.|TO:|DO:/,
+contains:[{className:"keyword",variants:[{begin:/\bTEXT\s*SEARCH\b/},{
+begin:/\b(PRIMARY|FOREIGN|FOR(\s+NO)?)\s+KEY\b/},{
+begin:/\bPARALLEL\s+(UNSAFE|RESTRICTED|SAFE)\b/},{
+begin:/\bSTORAGE\s+(PLAIN|EXTERNAL|EXTENDED|MAIN)\b/},{
+begin:/\bMATCH\s+(FULL|PARTIAL|SIMPLE)\b/},{begin:/\bNULLS\s+(FIRST|LAST)\b/},{
+begin:/\bEVENT\s+TRIGGER\b/},{begin:/\b(MAPPING|OR)\s+REPLACE\b/},{
+begin:/\b(FROM|TO)\s+(PROGRAM|STDIN|STDOUT)\b/},{
+begin:/\b(SHARE|EXCLUSIVE)\s+MODE\b/},{
+begin:/\b(LEFT|RIGHT)\s+(OUTER\s+)?JOIN\b/},{
+begin:/\b(FETCH|MOVE)\s+(NEXT|PRIOR|FIRST|LAST|ABSOLUTE|RELATIVE|FORWARD|BACKWARD)\b/
+},{begin:/\bPRESERVE\s+ROWS\b/},{begin:/\bDISCARD\s+PLANS\b/},{
+begin:/\bREFERENCING\s+(OLD|NEW)\b/},{begin:/\bSKIP\s+LOCKED\b/},{
+begin:/\bGROUPING\s+SETS\b/},{
+begin:/\b(BINARY|INSENSITIVE|SCROLL|NO\s+SCROLL)\s+(CURSOR|FOR)\b/},{
+begin:/\b(WITH|WITHOUT)\s+HOLD\b/},{
+begin:/\bWITH\s+(CASCADED|LOCAL)\s+CHECK\s+OPTION\b/},{
+begin:/\bEXCLUDE\s+(TIES|NO\s+OTHERS)\b/},{
+begin:/\bFORMAT\s+(TEXT|XML|JSON|YAML)\b/},{
+begin:/\bSET\s+((SESSION|LOCAL)\s+)?NAMES\b/},{begin:/\bIS\s+(NOT\s+)?UNKNOWN\b/
+},{begin:/\bSECURITY\s+LABEL\b/},{begin:/\bSTANDALONE\s+(YES|NO|NO\s+VALUE)\b/
+},{begin:/\bWITH\s+(NO\s+)?DATA\b/},{begin:/\b(FOREIGN|SET)\s+DATA\b/},{
+begin:/\bSET\s+(CATALOG|CONSTRAINTS)\b/},{begin:/\b(WITH|FOR)\s+ORDINALITY\b/},{
+begin:/\bIS\s+(NOT\s+)?DOCUMENT\b/},{
+begin:/\bXML\s+OPTION\s+(DOCUMENT|CONTENT)\b/},{
+begin:/\b(STRIP|PRESERVE)\s+WHITESPACE\b/},{
+begin:/\bNO\s+(ACTION|MAXVALUE|MINVALUE)\b/},{
+begin:/\bPARTITION\s+BY\s+(RANGE|LIST|HASH)\b/},{begin:/\bAT\s+TIME\s+ZONE\b/},{
+begin:/\bGRANTED\s+BY\b/},{begin:/\bRETURN\s+(QUERY|NEXT)\b/},{
+begin:/\b(ATTACH|DETACH)\s+PARTITION\b/},{
+begin:/\bFORCE\s+ROW\s+LEVEL\s+SECURITY\b/},{
+begin:/\b(INCLUDING|EXCLUDING)\s+(COMMENTS|CONSTRAINTS|DEFAULTS|IDENTITY|INDEXES|STATISTICS|STORAGE|ALL)\b/
+},{begin:/\bAS\s+(ASSIGNMENT|IMPLICIT|PERMISSIVE|RESTRICTIVE|ENUM|RANGE)\b/}]},{
+begin:/\b(FORMAT|FAMILY|VERSION)\s*\(/},{begin:/\bINCLUDE\s*\(/,
+keywords:"INCLUDE"},{begin:/\bRANGE(?!\s*(BETWEEN|UNBOUNDED|CURRENT|[-0-9]+))/
+},{
+begin:/\b(VERSION|OWNER|TEMPLATE|TABLESPACE|CONNECTION\s+LIMIT|PROCEDURE|RESTRICT|JOIN|PARSER|COPY|START|END|COLLATION|INPUT|ANALYZE|STORAGE|LIKE|DEFAULT|DELIMITER|ENCODING|COLUMN|CONSTRAINT|TABLE|SCHEMA)\s*=/
+},{begin:/\b(PG_\w+?|HAS_[A-Z_]+_PRIVILEGE)\b/,relevance:10},{
+begin:/\bEXTRACT\s*\(/,end:/\bFROM\b/,returnEnd:!0,keywords:{
+type:"CENTURY DAY DECADE DOW DOY EPOCH HOUR ISODOW ISOYEAR MICROSECONDS MILLENNIUM MILLISECONDS MINUTE MONTH QUARTER SECOND TIMEZONE TIMEZONE_HOUR TIMEZONE_MINUTE WEEK YEAR"
+}},{begin:/\b(XMLELEMENT|XMLPI)\s*\(\s*NAME/,keywords:{keyword:"NAME"}},{
+begin:/\b(XMLPARSE|XMLSERIALIZE)\s*\(\s*(DOCUMENT|CONTENT)/,keywords:{
+keyword:"DOCUMENT CONTENT"}},{beginKeywords:"CACHE INCREMENT MAXVALUE MINVALUE",
+end:E.C_NUMBER_RE,returnEnd:!0,keywords:"BY CACHE INCREMENT MAXVALUE MINVALUE"
+},{className:"type",begin:/\b(WITH|WITHOUT)\s+TIME\s+ZONE\b/},{className:"type",
+begin:/\bINTERVAL\s+(YEAR|MONTH|DAY|HOUR|MINUTE|SECOND)(\s+TO\s+(MONTH|HOUR|MINUTE|SECOND))?\b/
+},{
+begin:/\bRETURNS\s+(LANGUAGE_HANDLER|TRIGGER|EVENT_TRIGGER|FDW_HANDLER|INDEX_AM_HANDLER|TSM_HANDLER)\b/,
+keywords:{keyword:"RETURNS",
+type:"LANGUAGE_HANDLER TRIGGER EVENT_TRIGGER FDW_HANDLER INDEX_AM_HANDLER TSM_HANDLER"
+}},{begin:"\\b("+I+")\\s*\\("},{begin:"\\.("+R+")\\b"},{
+begin:"\\b("+R+")\\s+PATH\\b",keywords:{keyword:"PATH",
+type:A.replace("PATH ","")}},{className:"type",begin:"\\b("+R+")\\b"},{
+className:"string",begin:"'",end:"'",contains:[{begin:"''"}]},{
+className:"string",begin:"(e|E|u&|U&)'",end:"'",contains:[{begin:"\\\\."}],
+relevance:10},E.END_SAME_AS_BEGIN({begin:N,end:N,contains:[{
+subLanguage:["pgsql","perl","python","tcl","r","lua","java","php","ruby","bash","scheme","xml","json"],
+endsWithParent:!0}]}),{begin:'"',end:'"',contains:[{begin:'""'}]
+},E.C_NUMBER_MODE,E.C_BLOCK_COMMENT_MODE,T,{className:"meta",variants:[{
+begin:"%(ROW)?TYPE",relevance:10},{begin:"\\$\\d+"},{begin:"^#\\w",end:"$"}]},{
+className:"symbol",begin:"<<\\s*[a-zA-Z_][a-zA-Z_0-9$]*\\s*>>",relevance:10}]}}
+})());hljs.registerLanguage("gradle",(()=>{"use strict";return e=>({name:"Gradle",
+case_insensitive:!0,keywords:{
+keyword:"task project allprojects subprojects artifacts buildscript configurations dependencies repositories sourceSets description delete from into include exclude source classpath destinationDir includes options sourceCompatibility targetCompatibility group flatDir doLast doFirst flatten todir fromdir ant def abstract break case catch continue default do else extends final finally for if implements instanceof native new private protected public return static switch synchronized throw throws transient try volatile while strictfp package import false null super this true antlrtask checkstyle codenarc copy boolean byte char class double float int interface long short void compile runTime file fileTree abs any append asList asWritable call collect compareTo count div dump each eachByte eachFile eachLine every find findAll flatten getAt getErr getIn getOut getText grep immutable inject inspect intersect invokeMethods isCase join leftShift minus multiply newInputStream newOutputStream newPrintWriter newReader newWriter next plus pop power previous print println push putAt read readBytes readLines reverse reverseEach round size sort splitEachLine step subMap times toInteger toList tokenize upto waitForOrKill withPrintWriter withReader withStream withWriter withWriterAppend write writeLine"
+},
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.NUMBER_MODE,e.REGEXP_MODE]
+})})());hljs.registerLanguage("csharp",(()=>{"use strict";return e=>{var n={
+keyword:["abstract","as","base","break","case","class","const","continue","do","else","event","explicit","extern","finally","fixed","for","foreach","goto","if","implicit","in","interface","internal","is","lock","namespace","new","operator","out","override","params","private","protected","public","readonly","record","ref","return","sealed","sizeof","stackalloc","static","struct","switch","this","throw","try","typeof","unchecked","unsafe","using","virtual","void","volatile","while"].concat(["add","alias","and","ascending","async","await","by","descending","equals","from","get","global","group","init","into","join","let","nameof","not","notnull","on","or","orderby","partial","remove","select","set","unmanaged","value|0","var","when","where","with","yield"]).join(" "),
+built_in:"bool byte char decimal delegate double dynamic enum float int long nint nuint object sbyte short string ulong unit ushort",
+literal:"default false null true"},a=e.inherit(e.TITLE_MODE,{
+begin:"[a-zA-Z](\\.?\\w)*"}),i={className:"number",variants:[{
+begin:"\\b(0b[01']+)"},{
+begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{
+begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"
+}],relevance:0},s={className:"string",begin:'@"',end:'"',contains:[{begin:'""'}]
+},t=e.inherit(s,{illegal:/\n/}),r={className:"subst",begin:/\{/,end:/\}/,
+keywords:n},l=e.inherit(r,{illegal:/\n/}),c={className:"string",begin:/\$"/,
+end:'"',illegal:/\n/,contains:[{begin:/\{\{/},{begin:/\}\}/
+},e.BACKSLASH_ESCAPE,l]},o={className:"string",begin:/\$@"/,end:'"',contains:[{
+begin:/\{\{/},{begin:/\}\}/},{begin:'""'},r]},d=e.inherit(o,{illegal:/\n/,
+contains:[{begin:/\{\{/},{begin:/\}\}/},{begin:'""'},l]})
+;r.contains=[o,c,s,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,i,e.C_BLOCK_COMMENT_MODE],
+l.contains=[d,c,t,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,i,e.inherit(e.C_BLOCK_COMMENT_MODE,{
+illegal:/\n/})];var g={variants:[o,c,s,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]
+},E={begin:"<",end:">",contains:[{beginKeywords:"in out"},a]
+},_=e.IDENT_RE+"(<"+e.IDENT_RE+"(\\s*,\\s*"+e.IDENT_RE+")*>)?(\\[\\])?",b={
+begin:"@"+e.IDENT_RE,relevance:0};return{name:"C#",aliases:["cs","c#"],
+keywords:n,illegal:/::/,contains:[e.COMMENT("///","$",{returnBegin:!0,
+contains:[{className:"doctag",variants:[{begin:"///",relevance:0},{
+begin:"\x3c!--|--\x3e"},{begin:"</?",end:">"}]}]
+}),e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{className:"meta",begin:"#",
+end:"$",keywords:{
+"meta-keyword":"if else elif endif define undef warning error line region endregion pragma checksum"
+}},g,i,{beginKeywords:"class interface",relevance:0,end:/[{;=]/,
+illegal:/[^\s:,]/,contains:[{beginKeywords:"where class"
+},a,E,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{beginKeywords:"namespace",
+relevance:0,end:/[{;=]/,illegal:/[^\s:]/,
+contains:[a,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{
+beginKeywords:"record",relevance:0,end:/[{;=]/,illegal:/[^\s:]/,
+contains:[a,E,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{className:"meta",
+begin:"^\\s*\\[",excludeBegin:!0,end:"\\]",excludeEnd:!0,contains:[{
+className:"meta-string",begin:/"/,end:/"/}]},{
+beginKeywords:"new return throw await else",relevance:0},{className:"function",
+begin:"("+_+"\\s+)+"+e.IDENT_RE+"\\s*(<.+>)?\\s*\\(",returnBegin:!0,
+end:/\s*[{;=]/,excludeEnd:!0,keywords:n,contains:[{
+beginKeywords:"public private protected static internal protected abstract async extern override unsafe virtual new sealed partial",
+relevance:0},{begin:e.IDENT_RE+"\\s*(<.+>)?\\s*\\(",returnBegin:!0,
+contains:[e.TITLE_MODE,E],relevance:0},{className:"params",begin:/\(/,end:/\)/,
+excludeBegin:!0,excludeEnd:!0,keywords:n,relevance:0,
+contains:[g,i,e.C_BLOCK_COMMENT_MODE]
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},b]}}})());hljs.registerLanguage("scss",(()=>{"use strict";return e=>{var t="@[a-z-]+",i={
+className:"variable",begin:"(\\$[a-zA-Z-][a-zA-Z0-9_-]*)\\b"},r={
+className:"number",begin:"#[0-9A-Fa-f]+"}
+;return e.CSS_NUMBER_MODE,e.QUOTE_STRING_MODE,
+e.APOS_STRING_MODE,e.C_BLOCK_COMMENT_MODE,{name:"SCSS",case_insensitive:!0,
+illegal:"[=/|']",contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{
+className:"selector-id",begin:"#[A-Za-z0-9_-]+",relevance:0},{
+className:"selector-class",begin:"\\.[A-Za-z0-9_-]+",relevance:0},{
+className:"selector-attr",begin:"\\[",end:"\\]",illegal:"$"},{
+className:"selector-tag",
+begin:"\\b(a|abbr|acronym|address|area|article|aside|audio|b|base|big|blockquote|body|br|button|canvas|caption|cite|code|col|colgroup|command|datalist|dd|del|details|dfn|div|dl|dt|em|embed|fieldset|figcaption|figure|footer|form|frame|frameset|(h[1-6])|head|header|hgroup|hr|html|i|iframe|img|input|ins|kbd|keygen|label|legend|li|link|map|mark|meta|meter|nav|noframes|noscript|object|ol|optgroup|option|output|p|param|pre|progress|q|rp|rt|ruby|samp|script|section|select|small|span|strike|strong|style|sub|sup|table|tbody|td|textarea|tfoot|th|thead|time|title|tr|tt|ul|var|video)\\b",
+relevance:0},{className:"selector-pseudo",
+begin:":(visited|valid|root|right|required|read-write|read-only|out-range|optional|only-of-type|only-child|nth-of-type|nth-last-of-type|nth-last-child|nth-child|not|link|left|last-of-type|last-child|lang|invalid|indeterminate|in-range|hover|focus|first-of-type|first-line|first-letter|first-child|first|enabled|empty|disabled|default|checked|before|after|active)"
+},{className:"selector-pseudo",
+begin:"::(after|before|choices|first-letter|first-line|repeat-index|repeat-item|selection|value)"
+},i,{className:"attribute",
+begin:"\\b(src|z-index|word-wrap|word-spacing|word-break|width|widows|white-space|visibility|vertical-align|unicode-bidi|transition-timing-function|transition-property|transition-duration|transition-delay|transition|transform-style|transform-origin|transform|top|text-underline-position|text-transform|text-shadow|text-rendering|text-overflow|text-indent|text-decoration-style|text-decoration-line|text-decoration-color|text-decoration|text-align-last|text-align|tab-size|table-layout|right|resize|quotes|position|pointer-events|perspective-origin|perspective|page-break-inside|page-break-before|page-break-after|padding-top|padding-right|padding-left|padding-bottom|padding|overflow-y|overflow-x|overflow-wrap|overflow|outline-width|outline-style|outline-offset|outline-color|outline|orphans|order|opacity|object-position|object-fit|normal|none|nav-up|nav-right|nav-left|nav-index|nav-down|min-width|min-height|max-width|max-height|mask|marks|margin-top|margin-right|margin-left|margin-bottom|margin|list-style-type|list-style-position|list-style-image|list-style|line-height|letter-spacing|left|justify-content|initial|inherit|ime-mode|image-orientation|image-resolution|image-rendering|icon|hyphens|height|font-weight|font-variant-ligatures|font-variant|font-style|font-stretch|font-size-adjust|font-size|font-language-override|font-kerning|font-feature-settings|font-family|font|float|flex-wrap|flex-shrink|flex-grow|flex-flow|flex-direction|flex-basis|flex|filter|empty-cells|display|direction|cursor|counter-reset|counter-increment|content|column-width|column-span|column-rule-width|column-rule-style|column-rule-color|column-rule|column-gap|column-fill|column-count|columns|color|clip-path|clip|clear|caption-side|break-inside|break-before|break-after|box-sizing|box-shadow|box-decoration-break|bottom|border-width|border-top-width|border-top-style|border-top-right-radius|border-top-left-radius|border-top-color|border-top|border-style|border-spacing|border-right-width|border-right-style|border-right-color|border-right|border-radius|border-left-width|border-left-style|border-left-color|border-left|border-image-width|border-image-source|border-image-slice|border-image-repeat|border-image-outset|border-image|border-color|border-collapse|border-bottom-width|border-bottom-style|border-bottom-right-radius|border-bottom-left-radius|border-bottom-color|border-bottom|border|background-size|background-repeat|background-position|background-origin|background-image|background-color|background-clip|background-attachment|background-blend-mode|background|backface-visibility|auto|animation-timing-function|animation-play-state|animation-name|animation-iteration-count|animation-fill-mode|animation-duration|animation-direction|animation-delay|animation|align-self|align-items|align-content)\\b",
+illegal:"[^\\s]"},{
+begin:"\\b(whitespace|wait|w-resize|visible|vertical-text|vertical-ideographic|uppercase|upper-roman|upper-alpha|underline|transparent|top|thin|thick|text|text-top|text-bottom|tb-rl|table-header-group|table-footer-group|sw-resize|super|strict|static|square|solid|small-caps|separate|se-resize|scroll|s-resize|rtl|row-resize|ridge|right|repeat|repeat-y|repeat-x|relative|progress|pointer|overline|outside|outset|oblique|nowrap|not-allowed|normal|none|nw-resize|no-repeat|no-drop|newspaper|ne-resize|n-resize|move|middle|medium|ltr|lr-tb|lowercase|lower-roman|lower-alpha|loose|list-item|line|line-through|line-edge|lighter|left|keep-all|justify|italic|inter-word|inter-ideograph|inside|inset|inline|inline-block|inherit|inactive|ideograph-space|ideograph-parenthesis|ideograph-numeric|ideograph-alpha|horizontal|hidden|help|hand|groove|fixed|ellipsis|e-resize|double|dotted|distribute|distribute-space|distribute-letter|distribute-all-lines|disc|disabled|default|decimal|dashed|crosshair|collapse|col-resize|circle|char|center|capitalize|break-word|break-all|bottom|both|bolder|bold|block|bidi-override|below|baseline|auto|always|all-scroll|absolute|table|table-cell)\\b"
+},{begin:":",end:";",
+contains:[i,r,e.CSS_NUMBER_MODE,e.QUOTE_STRING_MODE,e.APOS_STRING_MODE,{
+className:"meta",begin:"!important"}]},{begin:"@(page|font-face)",lexemes:t,
+keywords:"@page @font-face"},{begin:"@",end:"[{;]",returnBegin:!0,
+keywords:"and or not only",contains:[{begin:t,className:"keyword"
+},i,e.QUOTE_STRING_MODE,e.APOS_STRING_MODE,r,e.CSS_NUMBER_MODE]}]}}})());hljs.registerLanguage("bnf",(()=>{"use strict";return e=>({
+name:"Backus\u2013Naur Form",contains:[{className:"attribute",begin:/</,end:/>/
+},{begin:/::=/,end:/$/,contains:[{begin:/</,end:/>/
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]
+}]})})());hljs.registerLanguage("c",(()=>{"use strict";return e=>{const t=(e=>{
+function t(e){return"(?:"+e+")?"}var n=e.COMMENT("//","$",{contains:[{
+begin:/\\\n/}]
+}),r="[a-zA-Z_]\\w*::",a="(decltype\\(auto\\)|"+t(r)+"[a-zA-Z_]\\w*"+t("<.*?>")+")",i={
+className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},s={className:"string",
+variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]},{
+begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",
+end:"'",illegal:"."},e.END_SAME_AS_BEGIN({
+begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},c={
+className:"number",variants:[{begin:"\\b(0b[01']+)"},{
+begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{
+begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"
+}],relevance:0},o={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{
+"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"
+},contains:[{begin:/\\\n/,relevance:0},e.inherit(s,{className:"meta-string"}),{
+className:"meta-string",begin:/<.*?>/,end:/$/,illegal:"\\n"
+},n,e.C_BLOCK_COMMENT_MODE]},l={className:"title",begin:t(r)+e.IDENT_RE,
+relevance:0},d=t(r)+e.IDENT_RE+"\\s*\\(",u={
+keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq",
+built_in:"std string wstring cin cout cerr clog stdin stdout stderr stringstream istringstream ostringstream auto_ptr deque list queue stack vector map set pair bitset multiset multimap unordered_set unordered_map unordered_multiset unordered_multimap priority_queue make_pair array shared_ptr abort terminate abs acos asin atan2 atan calloc ceil cosh cos exit exp fabs floor fmod fprintf fputs free frexp fscanf future isalnum isalpha iscntrl isdigit isgraph islower isprint ispunct isspace isupper isxdigit tolower toupper labs ldexp log10 log malloc realloc memchr memcmp memcpy memset modf pow printf putchar puts scanf sinh sin snprintf sprintf sqrt sscanf strcat strchr strcmp strcpy strcspn strlen strncat strncmp strncpy strpbrk strrchr strspn strstr tanh tan vfprintf vprintf vsprintf endl initializer_list unique_ptr _Bool complex _Complex imaginary _Imaginary",
+literal:"true false nullptr NULL"},m=[o,i,n,e.C_BLOCK_COMMENT_MODE,c,s],p={
+variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{
+beginKeywords:"new throw return else",end:/;/}],keywords:u,contains:m.concat([{
+begin:/\(/,end:/\)/,keywords:u,contains:m.concat(["self"]),relevance:0}]),
+relevance:0},_={className:"function",begin:"("+a+"[\\*&\\s]+)+"+d,
+returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:u,illegal:/[^\w\s\*&:<>]/,
+contains:[{begin:"decltype\\(auto\\)",keywords:u,relevance:0},{begin:d,
+returnBegin:!0,contains:[l],relevance:0},{className:"params",begin:/\(/,
+end:/\)/,keywords:u,relevance:0,contains:[n,e.C_BLOCK_COMMENT_MODE,s,c,i,{
+begin:/\(/,end:/\)/,keywords:u,relevance:0,
+contains:["self",n,e.C_BLOCK_COMMENT_MODE,s,c,i]}]
+},i,n,e.C_BLOCK_COMMENT_MODE,o]};return{
+aliases:["c","cc","h","c++","h++","hpp","hh","hxx","cxx"],keywords:u,
+disableAutodetect:!0,illegal:"</",contains:[].concat(p,_,m,[o,{
+begin:"\\b(deque|list|queue|priority_queue|pair|stack|vector|map|set|bitset|multiset|multimap|unordered_map|unordered_set|unordered_multiset|unordered_multimap|array)\\s*<",
+end:">",keywords:u,contains:["self",i]},{begin:e.IDENT_RE+"::",keywords:u},{
+className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/,
+contains:[{beginKeywords:"final class struct"},e.TITLE_MODE]}]),exports:{
+preprocessor:o,strings:s,keywords:u}}})(e)
+;return t.name="C",t.aliases=["c","h"],t}})());hljs.registerLanguage("kotlin",(()=>{"use strict";return e=>{const n={
+keyword:"abstract as val var vararg get set class object open private protected public noinline crossinline dynamic final enum if else do while for when throw try catch finally import package is in fun override companion reified inline lateinit init interface annotation data sealed internal infix operator out by constructor super tailrec where const inner suspend typealias external expect actual",
+built_in:"Byte Short Char Int Long Boolean Float Double Void Unit Nothing",
+literal:"true false null"},a={className:"symbol",begin:e.UNDERSCORE_IDENT_RE+"@"
+},s={className:"subst",begin:/\$\{/,end:/\}/,contains:[e.C_NUMBER_MODE]},i={
+className:"variable",begin:"\\$"+e.UNDERSCORE_IDENT_RE},t={className:"string",
+variants:[{begin:'"""',end:'"""(?=[^"])',contains:[i,s]},{begin:"'",end:"'",
+illegal:/\n/,contains:[e.BACKSLASH_ESCAPE]},{begin:'"',end:'"',illegal:/\n/,
+contains:[e.BACKSLASH_ESCAPE,i,s]}]};s.contains.push(t);const l={
+className:"meta",
+begin:"@(?:file|property|field|get|set|receiver|param|setparam|delegate)\\s*:(?:\\s*"+e.UNDERSCORE_IDENT_RE+")?"
+},r={className:"meta",begin:"@"+e.UNDERSCORE_IDENT_RE,contains:[{begin:/\(/,
+end:/\)/,contains:[e.inherit(t,{className:"meta-string"})]}]
+},c=e.COMMENT("/\\*","\\*/",{contains:[e.C_BLOCK_COMMENT_MODE]}),o={variants:[{
+className:"type",begin:e.UNDERSCORE_IDENT_RE},{begin:/\(/,end:/\)/,contains:[]}]
+},d=o;return d.variants[1].contains=[o],o.variants[1].contains=[d],{
+name:"Kotlin",aliases:["kt"],keywords:n,contains:[e.COMMENT("/\\*\\*","\\*/",{
+relevance:0,contains:[{className:"doctag",begin:"@[A-Za-z]+"}]
+}),e.C_LINE_COMMENT_MODE,c,{className:"keyword",
+begin:/\b(break|continue|return|this)\b/,starts:{contains:[{className:"symbol",
+begin:/@\w+/}]}},a,l,r,{className:"function",beginKeywords:"fun",end:"[(]|$",
+returnBegin:!0,excludeEnd:!0,keywords:n,
+illegal:/fun\s+(<.*>)?[^\s\(]+(\s+[^\s\(]+)\s*=/,relevance:5,contains:[{
+begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0,
+contains:[e.UNDERSCORE_TITLE_MODE]},{className:"type",begin:/</,end:/>/,
+keywords:"reified",relevance:0},{className:"params",begin:/\(/,end:/\)/,
+endsParent:!0,keywords:n,relevance:0,contains:[{begin:/:/,end:/[=,\/]/,
+endsWithParent:!0,contains:[o,e.C_LINE_COMMENT_MODE,c],relevance:0
+},e.C_LINE_COMMENT_MODE,c,l,r,t,e.C_NUMBER_MODE]},c]},{className:"class",
+beginKeywords:"class interface trait",end:/[:\{(]|$/,excludeEnd:!0,
+illegal:"extends implements",contains:[{
+beginKeywords:"public protected internal private constructor"
+},e.UNDERSCORE_TITLE_MODE,{className:"type",begin:/</,end:/>/,excludeBegin:!0,
+excludeEnd:!0,relevance:0},{className:"type",begin:/[,:]\s*/,end:/[<\(,]|$/,
+excludeBegin:!0,returnEnd:!0},l,r]},t,{className:"meta",begin:"^#!/usr/bin/env",
+end:"$",illegal:"\n"},{className:"number",
+begin:"\\b(0[bB]([01]+[01_]+[01]+|[01]+)|0[xX]([a-fA-F0-9]+[a-fA-F0-9_]+[a-fA-F0-9]+|[a-fA-F0-9]+)|(([\\d]+[\\d_]+[\\d]+|[\\d]+)(\\.([\\d]+[\\d_]+[\\d]+|[\\d]+))?|\\.([\\d]+[\\d_]+[\\d]+|[\\d]+))([eE][-+]?\\d+)?)[lLfF]?",
+relevance:0}]}}})());hljs.registerLanguage("dns",(()=>{"use strict";return d=>({name:"DNS Zone",
+aliases:["bind","zone"],keywords:{
+keyword:"IN A AAAA AFSDB APL CAA CDNSKEY CDS CERT CNAME DHCID DLV DNAME DNSKEY DS HIP IPSECKEY KEY KX LOC MX NAPTR NS NSEC NSEC3 NSEC3PARAM PTR RRSIG RP SIG SOA SRV SSHFP TA TKEY TLSA TSIG TXT"
+},contains:[d.COMMENT(";","$",{relevance:0}),{className:"meta",
+begin:/^\$(TTL|GENERATE|INCLUDE|ORIGIN)\b/},{className:"number",
+begin:"((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:)))\\b"
+},{className:"number",
+begin:"((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]).){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\b"
+},d.inherit(d.NUMBER_MODE,{begin:/\b\d+[dhwm]?/})]})})());hljs.registerLanguage("typescript",(()=>{"use strict"
+;const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],s=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"])
+;function t(e){return i("(?=",e,")")}function i(...e){return e.map((e=>{
+return(n=e)?"string"==typeof n?n:n.source:null;var n})).join("")}return r=>{
+const c={$pattern:e,
+keyword:n.concat(["type","namespace","typedef","interface","public","private","protected","implements","declare","abstract","readonly"]).join(" "),
+literal:a.join(" "),
+built_in:s.concat(["any","void","number","boolean","string","object","never","enum"]).join(" ")
+},o={className:"meta",begin:"@[A-Za-z$_][0-9A-Za-z$_]*"},l=(e,n,a)=>{
+const s=e.contains.findIndex((e=>e.label===n))
+;if(-1===s)throw Error("can not find mode to replace");e.contains.splice(s,1,a)
+},b=(r=>{const c=e,o={begin:/<[A-Za-z0-9\\._:-]+/,
+end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(e,n)=>{
+const a=e[0].length+e.index,s=e.input[a];"<"!==s?">"===s&&(((e,{after:n})=>{
+const a="</"+e[0].slice(1);return-1!==e.input.indexOf(a,n)})(e,{after:a
+})||n.ignoreMatch()):n.ignoreMatch()}},l={$pattern:e,keyword:n.join(" "),
+literal:a.join(" "),built_in:s.join(" ")
+},b="\\.([0-9](_?[0-9])*)",d="0|[1-9](_?[0-9])*|0[0-7]*[89][0-9]*",g={
+className:"number",variants:[{
+begin:`(\\b(${d})((${b})|\\.)?|(${b}))[eE][+-]?([0-9](_?[0-9])*)\\b`},{
+begin:`\\b(${d})\\b((${b})\\b|\\.)?|(${b})\\b`},{
+begin:"\\b(0|[1-9](_?[0-9])*)n\\b"},{
+begin:"\\b0[xX][0-9a-fA-F](_?[0-9a-fA-F])*n?\\b"},{
+begin:"\\b0[bB][0-1](_?[0-1])*n?\\b"},{begin:"\\b0[oO][0-7](_?[0-7])*n?\\b"},{
+begin:"\\b0[0-7]+n?\\b"}],relevance:0},u={className:"subst",begin:"\\$\\{",
+end:"\\}",keywords:l,contains:[]},E={begin:"html`",end:"",starts:{end:"`",
+returnEnd:!1,contains:[r.BACKSLASH_ESCAPE,u],subLanguage:"xml"}},m={
+begin:"css`",end:"",starts:{end:"`",returnEnd:!1,
+contains:[r.BACKSLASH_ESCAPE,u],subLanguage:"css"}},_={className:"string",
+begin:"`",end:"`",contains:[r.BACKSLASH_ESCAPE,u]},y={className:"comment",
+variants:[r.COMMENT("/\\*\\*","\\*/",{relevance:0,contains:[{className:"doctag",
+begin:"@[A-Za-z]+",contains:[{className:"type",begin:"\\{",end:"\\}",relevance:0
+},{className:"variable",begin:c+"(?=\\s*(-)|$)",endsParent:!0,relevance:0},{
+begin:/(?=[^\n])\s/,relevance:0}]}]
+}),r.C_BLOCK_COMMENT_MODE,r.C_LINE_COMMENT_MODE]
+},p=[r.APOS_STRING_MODE,r.QUOTE_STRING_MODE,E,m,_,g,r.REGEXP_MODE]
+;u.contains=p.concat({begin:/\{/,end:/\}/,keywords:l,contains:["self"].concat(p)
+});const N=[].concat(y,u.contains),f=N.concat([{begin:/\(/,end:/\)/,keywords:l,
+contains:["self"].concat(N)}]),A={className:"params",begin:/\(/,end:/\)/,
+excludeBegin:!0,excludeEnd:!0,keywords:l,contains:f};return{name:"Javascript",
+aliases:["js","jsx","mjs","cjs"],keywords:l,exports:{PARAMS_CONTAINS:f},
+illegal:/#(?![$_A-z])/,contains:[r.SHEBANG({label:"shebang",binary:"node",
+relevance:5}),{label:"use_strict",className:"meta",relevance:10,
+begin:/^\s*['"]use (strict|asm)['"]/
+},r.APOS_STRING_MODE,r.QUOTE_STRING_MODE,E,m,_,y,g,{
+begin:i(/[{,\n]\s*/,t(i(/(((\/\/.*$)|(\/\*(\*[^/]|[^*])*\*\/))\s*)*/,c+"\\s*:"))),
+relevance:0,contains:[{className:"attr",begin:c+t("\\s*:"),relevance:0}]},{
+begin:"("+r.RE_STARTERS_RE+"|\\b(case|return|throw)\\b)\\s*",
+keywords:"return throw case",contains:[y,r.REGEXP_MODE,{className:"function",
+begin:"(\\([^()]*(\\([^()]*(\\([^()]*\\))*[^()]*\\))*[^()]*\\)|"+r.UNDERSCORE_IDENT_RE+")\\s*=>",
+returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{
+begin:r.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0
+},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:l,contains:f}]}]
+},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{
+variants:[{begin:"<>",end:"</>"},{begin:o.begin,"on:begin":o.isTrulyOpeningTag,
+end:o.end}],subLanguage:"xml",contains:[{begin:o.begin,end:o.end,skip:!0,
+contains:["self"]}]}],relevance:0},{className:"function",
+beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:l,
+contains:["self",r.inherit(r.TITLE_MODE,{begin:c}),A],illegal:/%/},{
+beginKeywords:"while if switch catch for"},{className:"function",
+begin:r.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\))*[^()]*\\))*[^()]*\\)\\s*\\{",
+returnBegin:!0,contains:[A,r.inherit(r.TITLE_MODE,{begin:c})]},{variants:[{
+begin:"\\."+c},{begin:"\\$"+c}],relevance:0},{className:"class",
+beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{
+beginKeywords:"extends"},r.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/,
+end:/[{;]/,excludeEnd:!0,contains:[r.inherit(r.TITLE_MODE,{begin:c}),"self",A]
+},{begin:"(get|set)\\s+(?="+c+"\\()",end:/\{/,keywords:"get set",
+contains:[r.inherit(r.TITLE_MODE,{begin:c}),{begin:/\(\)/},A]},{begin:/\$[(.]/}]
+}})(r)
+;return Object.assign(b.keywords,c),b.exports.PARAMS_CONTAINS.push(o),b.contains=b.contains.concat([o,{
+beginKeywords:"namespace",end:/\{/,excludeEnd:!0},{beginKeywords:"interface",
+end:/\{/,excludeEnd:!0,keywords:"interface extends"
+}]),l(b,"shebang",r.SHEBANG()),l(b,"use_strict",{className:"meta",relevance:10,
+begin:/^\s*['"]use strict['"]/
+}),b.contains.find((e=>"function"===e.className)).relevance=0,Object.assign(b,{
+name:"TypeScript",aliases:["ts"]}),b}})());hljs.registerLanguage("avrasm",(()=>{"use strict";return r=>({
+name:"AVR Assembly",case_insensitive:!0,keywords:{$pattern:"\\.?"+r.IDENT_RE,
+keyword:"adc add adiw and andi asr bclr bld brbc brbs brcc brcs break breq brge brhc brhs brid brie brlo brlt brmi brne brpl brsh brtc brts brvc brvs bset bst call cbi cbr clc clh cli cln clr cls clt clv clz com cp cpc cpi cpse dec eicall eijmp elpm eor fmul fmuls fmulsu icall ijmp in inc jmp ld ldd ldi lds lpm lsl lsr mov movw mul muls mulsu neg nop or ori out pop push rcall ret reti rjmp rol ror sbc sbr sbrc sbrs sec seh sbi sbci sbic sbis sbiw sei sen ser ses set sev sez sleep spm st std sts sub subi swap tst wdr",
+built_in:"r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12 r13 r14 r15 r16 r17 r18 r19 r20 r21 r22 r23 r24 r25 r26 r27 r28 r29 r30 r31 x|0 xh xl y|0 yh yl z|0 zh zl ucsr1c udr1 ucsr1a ucsr1b ubrr1l ubrr1h ucsr0c ubrr0h tccr3c tccr3a tccr3b tcnt3h tcnt3l ocr3ah ocr3al ocr3bh ocr3bl ocr3ch ocr3cl icr3h icr3l etimsk etifr tccr1c ocr1ch ocr1cl twcr twdr twar twsr twbr osccal xmcra xmcrb eicra spmcsr spmcr portg ddrg ping portf ddrf sreg sph spl xdiv rampz eicrb eimsk gimsk gicr eifr gifr timsk tifr mcucr mcucsr tccr0 tcnt0 ocr0 assr tccr1a tccr1b tcnt1h tcnt1l ocr1ah ocr1al ocr1bh ocr1bl icr1h icr1l tccr2 tcnt2 ocr2 ocdr wdtcr sfior eearh eearl eedr eecr porta ddra pina portb ddrb pinb portc ddrc pinc portd ddrd pind spdr spsr spcr udr0 ucsr0a ucsr0b ubrr0l acsr admux adcsr adch adcl porte ddre pine pinf",
+meta:".byte .cseg .db .def .device .dseg .dw .endmacro .equ .eseg .exit .include .list .listmac .macro .nolist .org .set"
+},contains:[r.C_BLOCK_COMMENT_MODE,r.COMMENT(";","$",{relevance:0
+}),r.C_NUMBER_MODE,r.BINARY_NUMBER_MODE,{className:"number",
+begin:"\\b(\\$[a-zA-Z0-9]+|0o[0-7]+)"},r.QUOTE_STRING_MODE,{className:"string",
+begin:"'",end:"[^\\\\]'",illegal:"[^\\\\][^']"},{className:"symbol",
+begin:"^[A-Za-z0-9_.$]+:"},{className:"meta",begin:"#",end:"$"},{
+className:"subst",begin:"@[0-9]+"}]})})());hljs.registerLanguage("openscad",(()=>{"use strict";return e=>{const n={
+className:"keyword",begin:"\\$(f[asn]|t|vp[rtd]|children)"},r={
+className:"number",begin:"\\b\\d+(\\.\\d+)?(e-?\\d+)?",relevance:0
+},s=e.inherit(e.QUOTE_STRING_MODE,{illegal:null}),a={className:"function",
+beginKeywords:"module function",end:/=|\{/,contains:[{className:"params",
+begin:"\\(",end:"\\)",contains:["self",r,s,n,{className:"literal",
+begin:"false|true|PI|undef"}]},e.UNDERSCORE_TITLE_MODE]};return{name:"OpenSCAD",
+aliases:["scad"],keywords:{
+keyword:"function module include use for intersection_for if else \\%",
+literal:"false true PI undef",
+built_in:"circle square polygon text sphere cube cylinder polyhedron translate rotate scale resize mirror multmatrix color offset hull minkowski union difference intersection abs sign sin cos tan acos asin atan atan2 floor round ceil ln log pow sqrt exp rands min max concat lookup str chr search version version_num norm cross parent_module echo import import_dxf dxf_linear_extrude linear_extrude rotate_extrude surface projection render children dxf_cross dxf_dim let assign"
+},contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,r,{className:"meta",
+keywords:{"meta-keyword":"include use"},begin:"include|use <",end:">"},s,n,{
+begin:"[*!#%]",relevance:0},a]}}})());hljs.registerLanguage("objectivec",(()=>{"use strict";return e=>{
+const n=/[a-zA-Z@][a-zA-Z0-9_]*/,_={$pattern:n,
+keyword:"@interface @class @protocol @implementation"};return{
+name:"Objective-C",aliases:["mm","objc","obj-c","obj-c++","objective-c++"],
+keywords:{$pattern:n,
+keyword:"int float while char export sizeof typedef const struct for union unsigned long volatile static bool mutable if do return goto void enum else break extern asm case short default double register explicit signed typename this switch continue wchar_t inline readonly assign readwrite self @synchronized id typeof nonatomic super unichar IBOutlet IBAction strong weak copy in out inout bycopy byref oneway __strong __weak __block __autoreleasing @private @protected @public @try @property @end @throw @catch @finally @autoreleasepool @synthesize @dynamic @selector @optional @required @encode @package @import @defs @compatibility_alias __bridge __bridge_transfer __bridge_retained __bridge_retain __covariant __contravariant __kindof _Nonnull _Nullable _Null_unspecified __FUNCTION__ __PRETTY_FUNCTION__ __attribute__ getter setter retain unsafe_unretained nonnull nullable null_unspecified null_resettable class instancetype NS_DESIGNATED_INITIALIZER NS_UNAVAILABLE NS_REQUIRES_SUPER NS_RETURNS_INNER_POINTER NS_INLINE NS_AVAILABLE NS_DEPRECATED NS_ENUM NS_OPTIONS NS_SWIFT_UNAVAILABLE NS_ASSUME_NONNULL_BEGIN NS_ASSUME_NONNULL_END NS_REFINED_FOR_SWIFT NS_SWIFT_NAME NS_SWIFT_NOTHROW NS_DURING NS_HANDLER NS_ENDHANDLER NS_VALUERETURN NS_VOIDRETURN",
+literal:"false true FALSE TRUE nil YES NO NULL",
+built_in:"BOOL dispatch_once_t dispatch_queue_t dispatch_sync dispatch_async dispatch_once"
+},illegal:"</",contains:[{className:"built_in",
+begin:"\\b(AV|CA|CF|CG|CI|CL|CM|CN|CT|MK|MP|MTK|MTL|NS|SCN|SK|UI|WK|XC)\\w+"
+},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.C_NUMBER_MODE,e.QUOTE_STRING_MODE,e.APOS_STRING_MODE,{
+className:"string",variants:[{begin:'@"',end:'"',illegal:"\\n",
+contains:[e.BACKSLASH_ESCAPE]}]},{className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,
+keywords:{
+"meta-keyword":"if else elif endif define undef warning error line pragma ifdef ifndef include"
+},contains:[{begin:/\\\n/,relevance:0},e.inherit(e.QUOTE_STRING_MODE,{
+className:"meta-string"}),{className:"meta-string",begin:/<.*?>/,end:/$/,
+illegal:"\\n"},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{
+className:"class",begin:"("+_.keyword.split(" ").join("|")+")\\b",end:/(\{|$)/,
+excludeEnd:!0,keywords:_,contains:[e.UNDERSCORE_TITLE_MODE]},{
+begin:"\\."+e.UNDERSCORE_IDENT_RE,relevance:0}]}}})());hljs.registerLanguage("fortran",(()=>{"use strict";return e=>{const n={
+variants:[e.COMMENT("!","$",{relevance:0}),e.COMMENT("^C[ ]","$",{relevance:0
+}),e.COMMENT("^C$","$",{relevance:0})]},a={className:"function",
+beginKeywords:"subroutine function program",illegal:"[${=\\n]",
+contains:[e.UNDERSCORE_TITLE_MODE,{className:"params",begin:"\\(",end:"\\)"}]}
+;return{name:"Fortran",case_insensitive:!0,aliases:["f90","f95"],keywords:{
+literal:".False. .True.",
+keyword:"kind do concurrent local shared while private call intrinsic where elsewhere type endtype endmodule endselect endinterface end enddo endif if forall endforall only contains default return stop then block endblock endassociate public subroutine|10 function program .and. .or. .not. .le. .eq. .ge. .gt. .lt. goto save else use module select case access blank direct exist file fmt form formatted iostat name named nextrec number opened rec recl sequential status unformatted unit continue format pause cycle exit c_null_char c_alert c_backspace c_form_feed flush wait decimal round iomsg synchronous nopass non_overridable pass protected volatile abstract extends import non_intrinsic value deferred generic final enumerator class associate bind enum c_int c_short c_long c_long_long c_signed_char c_size_t c_int8_t c_int16_t c_int32_t c_int64_t c_int_least8_t c_int_least16_t c_int_least32_t c_int_least64_t c_int_fast8_t c_int_fast16_t c_int_fast32_t c_int_fast64_t c_intmax_t C_intptr_t c_float c_double c_long_double c_float_complex c_double_complex c_long_double_complex c_bool c_char c_null_ptr c_null_funptr c_new_line c_carriage_return c_horizontal_tab c_vertical_tab iso_c_binding c_loc c_funloc c_associated  c_f_pointer c_ptr c_funptr iso_fortran_env character_storage_size error_unit file_storage_size input_unit iostat_end iostat_eor numeric_storage_size output_unit c_f_procpointer ieee_arithmetic ieee_support_underflow_control ieee_get_underflow_mode ieee_set_underflow_mode newunit contiguous recursive pad position action delim readwrite eor advance nml interface procedure namelist include sequence elemental pure impure integer real character complex logical codimension dimension allocatable|10 parameter external implicit|10 none double precision assign intent optional pointer target in out common equivalence data",
+built_in:"alog alog10 amax0 amax1 amin0 amin1 amod cabs ccos cexp clog csin csqrt dabs dacos dasin datan datan2 dcos dcosh ddim dexp dint dlog dlog10 dmax1 dmin1 dmod dnint dsign dsin dsinh dsqrt dtan dtanh float iabs idim idint idnint ifix isign max0 max1 min0 min1 sngl algama cdabs cdcos cdexp cdlog cdsin cdsqrt cqabs cqcos cqexp cqlog cqsin cqsqrt dcmplx dconjg derf derfc dfloat dgamma dimag dlgama iqint qabs qacos qasin qatan qatan2 qcmplx qconjg qcos qcosh qdim qerf qerfc qexp qgamma qimag qlgama qlog qlog10 qmax1 qmin1 qmod qnint qsign qsin qsinh qsqrt qtan qtanh abs acos aimag aint anint asin atan atan2 char cmplx conjg cos cosh exp ichar index int log log10 max min nint sign sin sinh sqrt tan tanh print write dim lge lgt lle llt mod nullify allocate deallocate adjustl adjustr all allocated any associated bit_size btest ceiling count cshift date_and_time digits dot_product eoshift epsilon exponent floor fraction huge iand ibclr ibits ibset ieor ior ishft ishftc lbound len_trim matmul maxexponent maxloc maxval merge minexponent minloc minval modulo mvbits nearest pack present product radix random_number random_seed range repeat reshape rrspacing scale scan selected_int_kind selected_real_kind set_exponent shape size spacing spread sum system_clock tiny transpose trim ubound unpack verify achar iachar transfer dble entry dprod cpu_time command_argument_count get_command get_command_argument get_environment_variable is_iostat_end ieee_arithmetic ieee_support_underflow_control ieee_get_underflow_mode ieee_set_underflow_mode is_iostat_eor move_alloc new_line selected_char_kind same_type_as extends_type_of acosh asinh atanh bessel_j0 bessel_j1 bessel_jn bessel_y0 bessel_y1 bessel_yn erf erfc erfc_scaled gamma log_gamma hypot norm2 atomic_define atomic_ref execute_command_line leadz trailz storage_size merge_bits bge bgt ble blt dshiftl dshiftr findloc iall iany iparity image_index lcobound ucobound maskl maskr num_images parity popcnt poppar shifta shiftl shiftr this_image sync change team co_broadcast co_max co_min co_sum co_reduce"
+},illegal:/\/\*/,contains:[{className:"string",relevance:0,
+variants:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]},a,{begin:/^C\s*=(?!=)/,
+relevance:0},n,{className:"number",
+begin:"(?=\\b|\\+|-|\\.)(?:\\.|\\d+\\.?)\\d*([de][+-]?\\d+)?(_[a-z_\\d]+)?",
+relevance:0}]}}})());hljs.registerLanguage("http",(()=>{"use strict";return e=>{
+var n="HTTP/[0-9\\.]+";return{name:"HTTP",aliases:["https"],illegal:"\\S",
+contains:[{begin:"^"+n,end:"$",contains:[{className:"number",
+begin:"\\b\\d{3}\\b"}]},{begin:"^[A-Z]+ (.*?) "+n+"$",returnBegin:!0,end:"$",
+contains:[{className:"string",begin:" ",end:" ",excludeBegin:!0,excludeEnd:!0},{
+begin:n},{className:"keyword",begin:"[A-Z]+"}]},{className:"attribute",
+begin:"^\\w",end:": ",excludeEnd:!0,illegal:"\\n|\\s|=",starts:{end:"$",
+relevance:0}},{begin:"\\n\\n",starts:{subLanguage:[],endsWithParent:!0}}]}}
+})());hljs.registerLanguage("latex",(()=>{"use strict";return e=>{const n=[{
+begin:/\^{6}[0-9a-f]{6}/},{begin:/\^{5}[0-9a-f]{5}/},{begin:/\^{4}[0-9a-f]{4}/
+},{begin:/\^{3}[0-9a-f]{3}/},{begin:/\^{2}[0-9a-f]{2}/},{
+begin:/\^{2}[\u0000-\u007f]/}],a=[{className:"keyword",begin:/\\/,relevance:0,
+contains:[{endsParent:!0,begin:((...e)=>"("+e.map((e=>{
+return(n=e)?"string"==typeof n?n:n.source:null;var n
+})).join("|")+")")(...["(?:NeedsTeXFormat|RequirePackage|GetIdInfo)","Provides(?:Expl)?(?:Package|Class|File)","(?:DeclareOption|ProcessOptions)","(?:documentclass|usepackage|input|include)","makeat(?:letter|other)","ExplSyntax(?:On|Off)","(?:new|renew|provide)?command","(?:re)newenvironment","(?:New|Renew|Provide|Declare)(?:Expandable)?DocumentCommand","(?:New|Renew|Provide|Declare)DocumentEnvironment","(?:(?:e|g|x)?def|let)","(?:begin|end)","(?:part|chapter|(?:sub){0,2}section|(?:sub)?paragraph)","caption","(?:label|(?:eq|page|name)?ref|(?:paren|foot|super)?cite)","(?:alpha|beta|[Gg]amma|[Dd]elta|(?:var)?epsilon|zeta|eta|[Tt]heta|vartheta)","(?:iota|(?:var)?kappa|[Ll]ambda|mu|nu|[Xx]i|[Pp]i|varpi|(?:var)rho)","(?:[Ss]igma|varsigma|tau|[Uu]psilon|[Pp]hi|varphi|chi|[Pp]si|[Oo]mega)","(?:frac|sum|prod|lim|infty|times|sqrt|leq|geq|left|right|middle|[bB]igg?)","(?:[lr]angle|q?quad|[lcvdi]?dots|d?dot|hat|tilde|bar)"].map((e=>e+"(?![a-zA-Z@:_])")))
+},{endsParent:!0,
+begin:RegExp(["(?:__)?[a-zA-Z]{2,}_[a-zA-Z](?:_?[a-zA-Z])+:[a-zA-Z]*","[lgc]__?[a-zA-Z](?:_?[a-zA-Z])*_[a-zA-Z]{2,}","[qs]__?[a-zA-Z](?:_?[a-zA-Z])+","use(?:_i)?:[a-zA-Z]*","(?:else|fi|or):","(?:if|cs|exp):w","(?:hbox|vbox):n","::[a-zA-Z]_unbraced","::[a-zA-Z:]"].map((e=>e+"(?![a-zA-Z:_])")).join("|"))
+},{endsParent:!0,variants:n},{endsParent:!0,relevance:0,variants:[{
+begin:/[a-zA-Z@]+/},{begin:/[^a-zA-Z@]?/}]}]},{className:"params",relevance:0,
+begin:/#+\d?/},{variants:n},{className:"built_in",relevance:0,begin:/[$&^_]/},{
+className:"meta",begin:"% !TeX",end:"$",relevance:10},e.COMMENT("%","$",{
+relevance:0})],i={begin:/\{/,end:/\}/,relevance:0,contains:["self",...a]
+},t=e.inherit(i,{relevance:0,endsParent:!0,contains:[i,...a]}),r={begin:/\[/,
+end:/\]/,endsParent:!0,relevance:0,contains:[i,...a]},s={begin:/\s+/,relevance:0
+},c=[t],l=[r],o=(e,n)=>({contains:[s],starts:{relevance:0,contains:e,starts:n}
+}),d=(e,n)=>({begin:"\\\\"+e+"(?![a-zA-Z@:_])",keywords:{$pattern:/\\[a-zA-Z]+/,
+keyword:"\\"+e},relevance:0,contains:[s],starts:n}),g=(n,a)=>e.inherit({
+begin:"\\\\begin(?=\\s*\\r?\\n?\\s*\\{"+n+"\\})",keywords:{
+$pattern:/\\[a-zA-Z]+/,keyword:"\\begin"},relevance:0
+},o(c,a)),m=(n="string")=>e.END_SAME_AS_BEGIN({className:n,begin:/(.|\r?\n)/,
+end:/(.|\r?\n)/,excludeBegin:!0,excludeEnd:!0,endsParent:!0}),b=e=>({
+className:"string",end:"(?=\\\\end\\{"+e+"\\})"}),p=(e="string")=>({relevance:0,
+begin:/\{/,starts:{endsParent:!0,contains:[{className:e,end:/(?=\})/,
+endsParent:!0,contains:[{begin:/\{/,end:/\}/,relevance:0,contains:["self"]}]}]}
+});return{name:"LaTeX",aliases:["TeX"],
+contains:[...["verb","lstinline"].map((e=>d(e,{contains:[m()]}))),d("mint",o(c,{
+contains:[m()]})),d("mintinline",o(c,{contains:[p(),m()]})),d("url",{
+contains:[p("link"),p("link")]}),d("hyperref",{contains:[p("link")]
+}),d("href",o(l,{contains:[p("link")]
+})),...[].concat(...["","\\*"].map((e=>[g("verbatim"+e,b("verbatim"+e)),g("filecontents"+e,o(c,b("filecontents"+e))),...["","B","L"].map((n=>g(n+"Verbatim"+e,o(l,b(n+"Verbatim"+e)))))]))),g("minted",o(l,o(c,b("minted")))),...a]
+}}})());hljs.registerLanguage("glsl",(()=>{"use strict";return e=>({name:"GLSL",
+keywords:{
+keyword:"break continue discard do else for if return while switch case default attribute binding buffer ccw centroid centroid varying coherent column_major const cw depth_any depth_greater depth_less depth_unchanged early_fragment_tests equal_spacing flat fractional_even_spacing fractional_odd_spacing highp in index inout invariant invocations isolines layout line_strip lines lines_adjacency local_size_x local_size_y local_size_z location lowp max_vertices mediump noperspective offset origin_upper_left out packed patch pixel_center_integer point_mode points precise precision quads r11f_g11f_b10f r16 r16_snorm r16f r16i r16ui r32f r32i r32ui r8 r8_snorm r8i r8ui readonly restrict rg16 rg16_snorm rg16f rg16i rg16ui rg32f rg32i rg32ui rg8 rg8_snorm rg8i rg8ui rgb10_a2 rgb10_a2ui rgba16 rgba16_snorm rgba16f rgba16i rgba16ui rgba32f rgba32i rgba32ui rgba8 rgba8_snorm rgba8i rgba8ui row_major sample shared smooth std140 std430 stream triangle_strip triangles triangles_adjacency uniform varying vertices volatile writeonly",
+type:"atomic_uint bool bvec2 bvec3 bvec4 dmat2 dmat2x2 dmat2x3 dmat2x4 dmat3 dmat3x2 dmat3x3 dmat3x4 dmat4 dmat4x2 dmat4x3 dmat4x4 double dvec2 dvec3 dvec4 float iimage1D iimage1DArray iimage2D iimage2DArray iimage2DMS iimage2DMSArray iimage2DRect iimage3D iimageBuffer iimageCube iimageCubeArray image1D image1DArray image2D image2DArray image2DMS image2DMSArray image2DRect image3D imageBuffer imageCube imageCubeArray int isampler1D isampler1DArray isampler2D isampler2DArray isampler2DMS isampler2DMSArray isampler2DRect isampler3D isamplerBuffer isamplerCube isamplerCubeArray ivec2 ivec3 ivec4 mat2 mat2x2 mat2x3 mat2x4 mat3 mat3x2 mat3x3 mat3x4 mat4 mat4x2 mat4x3 mat4x4 sampler1D sampler1DArray sampler1DArrayShadow sampler1DShadow sampler2D sampler2DArray sampler2DArrayShadow sampler2DMS sampler2DMSArray sampler2DRect sampler2DRectShadow sampler2DShadow sampler3D samplerBuffer samplerCube samplerCubeArray samplerCubeArrayShadow samplerCubeShadow image1D uimage1DArray uimage2D uimage2DArray uimage2DMS uimage2DMSArray uimage2DRect uimage3D uimageBuffer uimageCube uimageCubeArray uint usampler1D usampler1DArray usampler2D usampler2DArray usampler2DMS usampler2DMSArray usampler2DRect usampler3D samplerBuffer usamplerCube usamplerCubeArray uvec2 uvec3 uvec4 vec2 vec3 vec4 void",
+built_in:"gl_MaxAtomicCounterBindings gl_MaxAtomicCounterBufferSize gl_MaxClipDistances gl_MaxClipPlanes gl_MaxCombinedAtomicCounterBuffers gl_MaxCombinedAtomicCounters gl_MaxCombinedImageUniforms gl_MaxCombinedImageUnitsAndFragmentOutputs gl_MaxCombinedTextureImageUnits gl_MaxComputeAtomicCounterBuffers gl_MaxComputeAtomicCounters gl_MaxComputeImageUniforms gl_MaxComputeTextureImageUnits gl_MaxComputeUniformComponents gl_MaxComputeWorkGroupCount gl_MaxComputeWorkGroupSize gl_MaxDrawBuffers gl_MaxFragmentAtomicCounterBuffers gl_MaxFragmentAtomicCounters gl_MaxFragmentImageUniforms gl_MaxFragmentInputComponents gl_MaxFragmentInputVectors gl_MaxFragmentUniformComponents gl_MaxFragmentUniformVectors gl_MaxGeometryAtomicCounterBuffers gl_MaxGeometryAtomicCounters gl_MaxGeometryImageUniforms gl_MaxGeometryInputComponents gl_MaxGeometryOutputComponents gl_MaxGeometryOutputVertices gl_MaxGeometryTextureImageUnits gl_MaxGeometryTotalOutputComponents gl_MaxGeometryUniformComponents gl_MaxGeometryVaryingComponents gl_MaxImageSamples gl_MaxImageUnits gl_MaxLights gl_MaxPatchVertices gl_MaxProgramTexelOffset gl_MaxTessControlAtomicCounterBuffers gl_MaxTessControlAtomicCounters gl_MaxTessControlImageUniforms gl_MaxTessControlInputComponents gl_MaxTessControlOutputComponents gl_MaxTessControlTextureImageUnits gl_MaxTessControlTotalOutputComponents gl_MaxTessControlUniformComponents gl_MaxTessEvaluationAtomicCounterBuffers gl_MaxTessEvaluationAtomicCounters gl_MaxTessEvaluationImageUniforms gl_MaxTessEvaluationInputComponents gl_MaxTessEvaluationOutputComponents gl_MaxTessEvaluationTextureImageUnits gl_MaxTessEvaluationUniformComponents gl_MaxTessGenLevel gl_MaxTessPatchComponents gl_MaxTextureCoords gl_MaxTextureImageUnits gl_MaxTextureUnits gl_MaxVaryingComponents gl_MaxVaryingFloats gl_MaxVaryingVectors gl_MaxVertexAtomicCounterBuffers gl_MaxVertexAtomicCounters gl_MaxVertexAttribs gl_MaxVertexImageUniforms gl_MaxVertexOutputComponents gl_MaxVertexOutputVectors gl_MaxVertexTextureImageUnits gl_MaxVertexUniformComponents gl_MaxVertexUniformVectors gl_MaxViewports gl_MinProgramTexelOffset gl_BackColor gl_BackLightModelProduct gl_BackLightProduct gl_BackMaterial gl_BackSecondaryColor gl_ClipDistance gl_ClipPlane gl_ClipVertex gl_Color gl_DepthRange gl_EyePlaneQ gl_EyePlaneR gl_EyePlaneS gl_EyePlaneT gl_Fog gl_FogCoord gl_FogFragCoord gl_FragColor gl_FragCoord gl_FragData gl_FragDepth gl_FrontColor gl_FrontFacing gl_FrontLightModelProduct gl_FrontLightProduct gl_FrontMaterial gl_FrontSecondaryColor gl_GlobalInvocationID gl_InstanceID gl_InvocationID gl_Layer gl_LightModel gl_LightSource gl_LocalInvocationID gl_LocalInvocationIndex gl_ModelViewMatrix gl_ModelViewMatrixInverse gl_ModelViewMatrixInverseTranspose gl_ModelViewMatrixTranspose gl_ModelViewProjectionMatrix gl_ModelViewProjectionMatrixInverse gl_ModelViewProjectionMatrixInverseTranspose gl_ModelViewProjectionMatrixTranspose gl_MultiTexCoord0 gl_MultiTexCoord1 gl_MultiTexCoord2 gl_MultiTexCoord3 gl_MultiTexCoord4 gl_MultiTexCoord5 gl_MultiTexCoord6 gl_MultiTexCoord7 gl_Normal gl_NormalMatrix gl_NormalScale gl_NumSamples gl_NumWorkGroups gl_ObjectPlaneQ gl_ObjectPlaneR gl_ObjectPlaneS gl_ObjectPlaneT gl_PatchVerticesIn gl_Point gl_PointCoord gl_PointSize gl_Position gl_PrimitiveID gl_PrimitiveIDIn gl_ProjectionMatrix gl_ProjectionMatrixInverse gl_ProjectionMatrixInverseTranspose gl_ProjectionMatrixTranspose gl_SampleID gl_SampleMask gl_SampleMaskIn gl_SamplePosition gl_SecondaryColor gl_TessCoord gl_TessLevelInner gl_TessLevelOuter gl_TexCoord gl_TextureEnvColor gl_TextureMatrix gl_TextureMatrixInverse gl_TextureMatrixInverseTranspose gl_TextureMatrixTranspose gl_Vertex gl_VertexID gl_ViewportIndex gl_WorkGroupID gl_WorkGroupSize gl_in gl_out EmitStreamVertex EmitVertex EndPrimitive EndStreamPrimitive abs acos acosh all any asin asinh atan atanh atomicAdd atomicAnd atomicCompSwap atomicCounter atomicCounterDecrement atomicCounterIncrement atomicExchange atomicMax atomicMin atomicOr atomicXor barrier bitCount bitfieldExtract bitfieldInsert bitfieldReverse ceil clamp cos cosh cross dFdx dFdy degrees determinant distance dot equal exp exp2 faceforward findLSB findMSB floatBitsToInt floatBitsToUint floor fma fract frexp ftransform fwidth greaterThan greaterThanEqual groupMemoryBarrier imageAtomicAdd imageAtomicAnd imageAtomicCompSwap imageAtomicExchange imageAtomicMax imageAtomicMin imageAtomicOr imageAtomicXor imageLoad imageSize imageStore imulExtended intBitsToFloat interpolateAtCentroid interpolateAtOffset interpolateAtSample inverse inversesqrt isinf isnan ldexp length lessThan lessThanEqual log log2 matrixCompMult max memoryBarrier memoryBarrierAtomicCounter memoryBarrierBuffer memoryBarrierImage memoryBarrierShared min mix mod modf noise1 noise2 noise3 noise4 normalize not notEqual outerProduct packDouble2x32 packHalf2x16 packSnorm2x16 packSnorm4x8 packUnorm2x16 packUnorm4x8 pow radians reflect refract round roundEven shadow1D shadow1DLod shadow1DProj shadow1DProjLod shadow2D shadow2DLod shadow2DProj shadow2DProjLod sign sin sinh smoothstep sqrt step tan tanh texelFetch texelFetchOffset texture texture1D texture1DLod texture1DProj texture1DProjLod texture2D texture2DLod texture2DProj texture2DProjLod texture3D texture3DLod texture3DProj texture3DProjLod textureCube textureCubeLod textureGather textureGatherOffset textureGatherOffsets textureGrad textureGradOffset textureLod textureLodOffset textureOffset textureProj textureProjGrad textureProjGradOffset textureProjLod textureProjLodOffset textureProjOffset textureQueryLevels textureQueryLod textureSize transpose trunc uaddCarry uintBitsToFloat umulExtended unpackDouble2x32 unpackHalf2x16 unpackSnorm2x16 unpackSnorm4x8 unpackUnorm2x16 unpackUnorm4x8 usubBorrow",
+literal:"true false"},illegal:'"',
+contains:[e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.C_NUMBER_MODE,{
+className:"meta",begin:"#",end:"$"}]})})());hljs.registerLanguage("plaintext",(()=>{"use strict";return t=>({
+name:"Plain text",aliases:["text","txt"],disableAutodetect:!0})})());hljs.registerLanguage("dos",(()=>{"use strict";return e=>{
+const t=e.COMMENT(/^\s*@?rem\b/,/$/,{relevance:10});return{
+name:"Batch file (DOS)",aliases:["bat","cmd"],case_insensitive:!0,
+illegal:/\/\*/,keywords:{
+keyword:"if else goto for in do call exit not exist errorlevel defined equ neq lss leq gtr geq",
+built_in:"prn nul lpt3 lpt2 lpt1 con com4 com3 com2 com1 aux shift cd dir echo setlocal endlocal set pause copy append assoc at attrib break cacls cd chcp chdir chkdsk chkntfs cls cmd color comp compact convert date dir diskcomp diskcopy doskey erase fs find findstr format ftype graftabl help keyb label md mkdir mode more move path pause print popd pushd promt rd recover rem rename replace restore rmdir shift sort start subst time title tree type ver verify vol ping net ipconfig taskkill xcopy ren del"
+},contains:[{className:"variable",begin:/%%[^ ]|%[^ ]+?%|![^ ]+?!/},{
+className:"function",begin:"^\\s*[A-Za-z._?][A-Za-z0-9_$#@~.?]*(:|\\s+label)",
+end:"goto:eof",contains:[e.inherit(e.TITLE_MODE,{
+begin:"([_a-zA-Z]\\w*\\.)*([_a-zA-Z]\\w*:)?[_a-zA-Z]\\w*"}),t]},{
+className:"number",begin:"\\b\\d+",relevance:0},t]}}})());hljs.registerLanguage("django",(()=>{"use strict";return e=>{const t={
+begin:/\|[A-Za-z]+:?/,keywords:{
+name:"truncatewords removetags linebreaksbr yesno get_digit timesince random striptags filesizeformat escape linebreaks length_is ljust rjust cut urlize fix_ampersands title floatformat capfirst pprint divisibleby add make_list unordered_list urlencode timeuntil urlizetrunc wordcount stringformat linenumbers slice date dictsort dictsortreversed default_if_none pluralize lower join center default truncatewords_html upper length phone2numeric wordwrap time addslashes slugify first escapejs force_escape iriencode last safe safeseq truncatechars localize unlocalize localtime utc timezone"
+},contains:[e.QUOTE_STRING_MODE,e.APOS_STRING_MODE]};return{name:"Django",
+aliases:["jinja"],case_insensitive:!0,subLanguage:"xml",
+contains:[e.COMMENT(/\{%\s*comment\s*%\}/,/\{%\s*endcomment\s*%\}/),e.COMMENT(/\{#/,/#\}/),{
+className:"template-tag",begin:/\{%/,end:/%\}/,contains:[{className:"name",
+begin:/\w+/,keywords:{
+name:"comment endcomment load templatetag ifchanged endifchanged if endif firstof for endfor ifnotequal endifnotequal widthratio extends include spaceless endspaceless regroup ifequal endifequal ssi now with cycle url filter endfilter debug block endblock else autoescape endautoescape csrf_token empty elif endwith static trans blocktrans endblocktrans get_static_prefix get_media_prefix plural get_current_language language get_available_languages get_current_language_bidi get_language_info get_language_info_list localize endlocalize localtime endlocaltime timezone endtimezone get_current_timezone verbatim"
+},starts:{endsWithParent:!0,keywords:"in by as",contains:[t],relevance:0}}]},{
+className:"template-variable",begin:/\{\{/,end:/\}\}/,contains:[t]}]}}})());hljs.registerLanguage("profile",(()=>{"use strict";return e=>({
+name:"Python profiler",contains:[e.C_NUMBER_MODE,{
+begin:"[a-zA-Z_][\\da-zA-Z_]+\\.[\\da-zA-Z_]{1,3}",end:":",excludeEnd:!0},{
+begin:"(ncalls|tottime|cumtime)",end:"$",
+keywords:"ncalls tottime|10 cumtime|10 filename",relevance:10},{
+begin:"function calls",end:"$",contains:[e.C_NUMBER_MODE],relevance:10
+},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{className:"string",begin:"\\(",
+end:"\\)$",excludeBegin:!0,excludeEnd:!0,relevance:0}]})})());hljs.registerLanguage("actionscript",(()=>{"use strict";return e=>({
+name:"ActionScript",aliases:["as"],keywords:{
+keyword:"as break case catch class const continue default delete do dynamic each else extends final finally for function get if implements import in include instanceof interface internal is namespace native new override package private protected public return set static super switch this throw try typeof use var void while with",
+literal:"true false null undefined"},
+contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.C_NUMBER_MODE,{
+className:"class",beginKeywords:"package",end:/\{/,contains:[e.TITLE_MODE]},{
+className:"class",beginKeywords:"class interface",end:/\{/,excludeEnd:!0,
+contains:[{beginKeywords:"extends implements"},e.TITLE_MODE]},{className:"meta",
+beginKeywords:"import include",end:";",keywords:{"meta-keyword":"import include"
+}},{className:"function",beginKeywords:"function",end:"[{;]",excludeEnd:!0,
+illegal:"\\S",contains:[e.TITLE_MODE,{className:"params",begin:"\\(",end:"\\)",
+contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{
+className:"rest_arg",begin:"[.]{3}",end:"[a-zA-Z_$][a-zA-Z0-9_$]*",relevance:10
+}]},{begin:":\\s*([*]|[a-zA-Z_$][a-zA-Z0-9_$]*)"}]},e.METHOD_GUARD],illegal:/#/
+})})());hljs.registerLanguage("groovy",(()=>{"use strict";function e(e,n={}){
+return n.variants=e,n}return n=>{
+const a="[A-Za-z0-9_$]+",t=e([n.C_LINE_COMMENT_MODE,n.C_BLOCK_COMMENT_MODE,n.COMMENT("/\\*\\*","\\*/",{
+relevance:0,contains:[{begin:/\w+@/,relevance:0},{className:"doctag",
+begin:"@[A-Za-z]+"}]})]),s={className:"regexp",begin:/~?\/[^\/\n]+\//,
+contains:[n.BACKSLASH_ESCAPE]
+},i=e([n.BINARY_NUMBER_MODE,n.C_NUMBER_MODE]),r=e([{begin:/"""/,end:/"""/},{
+begin:/'''/,end:/'''/},{begin:"\\$/",end:"/\\$",relevance:10
+},n.APOS_STRING_MODE,n.QUOTE_STRING_MODE],{className:"string"});return{
+name:"Groovy",keywords:{built_in:"this super",literal:"true false null",
+keyword:"byte short char int long boolean float double void def as in assert trait abstract static volatile transient public private protected synchronized final class interface enum if else for while switch case break default continue throw throws try catch finally implements extends new import package return instanceof"
+},contains:[n.SHEBANG({binary:"groovy",relevance:10}),t,r,s,i,{
+className:"class",beginKeywords:"class interface trait enum",end:/\{/,
+illegal:":",contains:[{beginKeywords:"extends implements"
+},n.UNDERSCORE_TITLE_MODE]},{className:"meta",begin:"@[A-Za-z]+",relevance:0},{
+className:"attr",begin:a+"[ \t]*:"},{begin:/\?/,end:/:/,relevance:0,
+contains:[t,r,s,i,"self"]},{className:"symbol",
+begin:"^[ \t]*"+(l=a+":",((...e)=>e.map((e=>(e=>e?"string"==typeof e?e:e.source:null)(e))).join(""))("(?=",l,")")),
+excludeBegin:!0,end:a+":",relevance:0}],illegal:/#|<\//};var l}})());hljs.registerLanguage("css",(()=>{"use strict";return e=>{
+var n="[a-zA-Z-][a-zA-Z0-9_-]*",a={
+begin:/([*]\s?)?(?:[A-Z_.\-\\]+|--[a-zA-Z0-9_-]+)\s*(\/\*\*\/)?:/,
+returnBegin:!0,end:";",endsWithParent:!0,contains:[{className:"attribute",
+begin:/\S/,end:":",excludeEnd:!0,starts:{endsWithParent:!0,excludeEnd:!0,
+contains:[{begin:/[\w-]+\(/,returnBegin:!0,contains:[{className:"built_in",
+begin:/[\w-]+/},{begin:/\(/,end:/\)/,
+contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.CSS_NUMBER_MODE]}]
+},e.CSS_NUMBER_MODE,e.QUOTE_STRING_MODE,e.APOS_STRING_MODE,e.C_BLOCK_COMMENT_MODE,{
+className:"number",begin:"#[0-9A-Fa-f]+"},{className:"meta",begin:"!important"}]
+}}]};return{name:"CSS",case_insensitive:!0,illegal:/[=|'\$]/,
+contains:[e.C_BLOCK_COMMENT_MODE,{className:"selector-id",
+begin:/#[A-Za-z0-9_-]+/},{className:"selector-class",begin:"\\."+n},{
+className:"selector-attr",begin:/\[/,end:/\]/,illegal:"$",
+contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]},{className:"selector-pseudo",
+begin:/:(:)?[a-zA-Z0-9_+()"'.-]+/},{begin:"@(page|font-face)",
+lexemes:"@[a-z-]+",keywords:"@page @font-face"},{begin:"@",end:"[{;]",
+illegal:/:/,returnBegin:!0,contains:[{className:"keyword",
+begin:/@-?\w[\w]*(-\w+)*/},{begin:/\s/,endsWithParent:!0,excludeEnd:!0,
+relevance:0,keywords:"and or not only",contains:[{begin:/[a-z-]+:/,
+className:"attribute"},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,e.CSS_NUMBER_MODE]
+}]},{className:"selector-tag",begin:n,relevance:0},{begin:/\{/,end:/\}/,
+illegal:/\S/,contains:[e.C_BLOCK_COMMENT_MODE,{begin:/;/},a]}]}}})());hljs.registerLanguage("vhdl",(()=>{"use strict";return e=>({name:"VHDL",
+case_insensitive:!0,keywords:{
+keyword:"abs access after alias all and architecture array assert assume assume_guarantee attribute begin block body buffer bus case component configuration constant context cover disconnect downto default else elsif end entity exit fairness file for force function generate generic group guarded if impure in inertial inout is label library linkage literal loop map mod nand new next nor not null of on open or others out package parameter port postponed procedure process property protected pure range record register reject release rem report restrict restrict_guarantee return rol ror select sequence severity shared signal sla sll sra srl strong subtype then to transport type unaffected units until use variable view vmode vprop vunit wait when while with xnor xor",
+built_in:"boolean bit character integer time delay_length natural positive string bit_vector file_open_kind file_open_status std_logic std_logic_vector unsigned signed boolean_vector integer_vector std_ulogic std_ulogic_vector unresolved_unsigned u_unsigned unresolved_signed u_signed real_vector time_vector",
+literal:"false true note warning error failure line text side width"},
+illegal:/\{/,
+contains:[e.C_BLOCK_COMMENT_MODE,e.COMMENT("--","$"),e.QUOTE_STRING_MODE,{
+className:"number",
+begin:"\\b(\\d(_|\\d)*#\\w+(\\.\\w+)?#([eE][-+]?\\d(_|\\d)*)?|\\d(_|\\d)*(\\.\\d(_|\\d)*)?([eE][-+]?\\d(_|\\d)*)?)",
+relevance:0},{className:"string",begin:"'(U|X|0|1|Z|W|L|H|-)'",
+contains:[e.BACKSLASH_ESCAPE]},{className:"symbol",
+begin:"'[A-Za-z](_?[A-Za-z0-9])*",contains:[e.BACKSLASH_ESCAPE]}]})})());
\ No newline at end of file
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/README
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/README	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight/README	(revision 12)
@@ -0,0 +1,102 @@
+
+Current Version: 10.4.0
+
+  Download: https://highlightjs.org/download/
+   Classes: https://highlightjs.readthedocs.io/en/latest/css-classes-reference.html
+ Languages: https://github.com/highlightjs/highlight.js/blob/master/SUPPORTED_LANGUAGES.md
+
+Downloaded Hljs languages:
+
+Common:
+======
+ .properties
+ Apache config
+ Bash
+ C
+ C#
+ C++
+ C-like foundation grammar for C/C++ grammars
+ CSS
+ CoffeeScript
+ Diff
+ Go
+ HTML, XML
+ HTTP
+ JSON
+ Java
+ JavaScript
+ Kotlin
+ Less
+ Lua
+ Makefile
+ Markdown
+ Nginx config
+ Objective-C
+ PHP
+ PHP Template
+ Perl
+ Plain text
+ Python
+ Python REPL
+ Ruby
+ Rust
+ SCSS
+ SQL
+ Shell Session
+ Swift
+ TOML, also INI
+ TypeScript
+ YAML
+
+Other:
+=====
+
+ ARM Assembly
+ AVR Assembly
+ ActionScript
+ Ada
+ Apache Access Log
+ AppleScript
+ Arduino
+ AsciiDoc
+ Augmented Backus-Naur Form
+ Awk
+ Backus–Naur Form
+ Batch file (DOS)
+ C-like foundation grammar for C/C++ grammars
+ CMake
+ D
+ DNS Zone
+ Device Tree
+ Django
+ Dockerfile
+ Erlang
+ Erlang REPL
+ Extended Backus-Naur Form
+ Fortran
+ GLSL
+ GML
+ Gradle
+ Groovy
+ HAML
+ Haskell
+ Intel x86 Assembly
+ LaTeX
+ Lisp
+ MIPS Assembly
+ Microtik RouterOS script
+ OCaml
+ OpenSCAD
+ PostgreSQL and PL/pgSQL
+ PowerShell
+ Prolog
+ Python profiler
+ ReasonML
+ Scala
+ Scheme
+ Scilab
+ Tcl
+ VHDL
+ Vala
+ Verilog
+ Vim Script
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/css/highlightjs-line-numbers.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/css/highlightjs-line-numbers.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/css/highlightjs-line-numbers.css	(revision 12)
@@ -0,0 +1,24 @@
+
+.hljs-ln-numbers {
+  /* for block of numbers: */
+  -webkit-touch-callout: none;
+  -webkit-user-select: none;
+  -khtml-user-select: none;
+  -moz-user-select: none;
+  -ms-user-select: none;
+  user-select: none;
+
+  text-align: right;
+  color: #a4a4a4;
+  border-right: 1px solid #e4e4e4;
+  vertical-align: top;
+  padding-right: 5px !important;
+  padding-left: 5px !important;
+
+  /* your custom style here */
+}
+
+.hljs-ln-code {
+  /* for block of code: */
+  padding-left: 10px !important;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/js/highlightjs-line-numbers.min.js
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/js/highlightjs-line-numbers.min.js	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/2.8.0/js/highlightjs-line-numbers.min.js	(revision 12)
@@ -0,0 +1 @@
+!function(r,o){"use strict";var e,i="hljs-ln",l="hljs-ln-line",h="hljs-ln-code",s="hljs-ln-numbers",c="hljs-ln-n",m="data-line-number",a=/\r\n|\r|\n/g;function u(e){for(var n=e.toString(),t=e.anchorNode;"TD"!==t.nodeName;)t=t.parentNode;for(var r=e.focusNode;"TD"!==r.nodeName;)r=r.parentNode;var o=parseInt(t.dataset.lineNumber),a=parseInt(r.dataset.lineNumber);if(o==a)return n;var i,l=t.textContent,s=r.textContent;for(a<o&&(i=o,o=a,a=i,i=l,l=s,s=i);0!==n.indexOf(l);)l=l.slice(1);for(;-1===n.lastIndexOf(s);)s=s.slice(0,-1);for(var c=l,u=function(e){for(var n=e;"TABLE"!==n.nodeName;)n=n.parentNode;return n}(t),d=o+1;d<a;++d){var f=p('.{0}[{1}="{2}"]',[h,m,d]);c+="\n"+u.querySelector(f).textContent}return c+="\n"+s}function n(e){try{var n=o.querySelectorAll("code.hljs,code.nohighlight");for(var t in n)n.hasOwnProperty(t)&&(n[t].classList.contains("nohljsln")||d(n[t],e))}catch(e){r.console.error("LineNumbers error: ",e)}}function d(e,n){"object"==typeof e&&r.setTimeout(function(){e.innerHTML=f(e,n)},0)}function f(e,n){var t,r,o=(t=e,{singleLine:function(e){return!!e.singleLine&&e.singleLine}(r=(r=n)||{}),startFrom:function(e,n){var t=1;isFinite(n.startFrom)&&(t=n.startFrom);var r=function(e,n){return e.hasAttribute(n)?e.getAttribute(n):null}(e,"data-ln-start-from");return null!==r&&(t=function(e,n){if(!e)return n;var t=Number(e);return isFinite(t)?t:n}(r,1)),t}(t,r)});return function e(n){var t=n.childNodes;for(var r in t){var o;t.hasOwnProperty(r)&&(o=t[r],0<(o.textContent.trim().match(a)||[]).length&&(0<o.childNodes.length?e(o):v(o.parentNode)))}}(e),function(e,n){var t=g(e);""===t[t.length-1].trim()&&t.pop();if(1<t.length||n.singleLine){for(var r="",o=0,a=t.length;o<a;o++)r+=p('<tr><td class="{0} {1}" {3}="{5}"><div class="{2}" {3}="{5}"></div></td><td class="{0} {4}" {3}="{5}">{6}</td></tr>',[l,s,c,m,h,o+n.startFrom,0<t[o].length?t[o]:" "]);return p('<table class="{0}">{1}</table>',[i,r])}return e}(e.innerHTML,o)}function v(e){var n=e.className;if(/hljs-/.test(n)){for(var t=g(e.innerHTML),r=0,o="";r<t.length;r++){o+=p('<span class="{0}">{1}</span>\n',[n,0<t[r].length?t[r]:" "])}e.innerHTML=o.trim()}}function g(e){return 0===e.length?[]:e.split(a)}function p(e,t){return e.replace(/\{(\d+)\}/g,function(e,n){return void 0!==t[n]?t[n]:e})}r.hljs?(r.hljs.initLineNumbersOnLoad=function(e){"interactive"===o.readyState||"complete"===o.readyState?n(e):r.addEventListener("DOMContentLoaded",function(){n(e)})},r.hljs.lineNumbersBlock=d,r.hljs.lineNumbersValue=function(e,n){if("string"!=typeof e)return;var t=document.createElement("code");return t.innerHTML=e,f(t,n)},(e=o.createElement("style")).type="text/css",e.innerHTML=p(".{0}{border-collapse:collapse}.{0} td{padding:0}.{1}:before{content:attr({2})}",[i,c,m]),o.getElementsByTagName("head")[0].appendChild(e)):r.console.error("highlight.js not detected!"),document.addEventListener("copy",function(e){var n,t=window.getSelection();!function(e){for(var n=e;n;){if(n.className&&-1!==n.className.indexOf("hljs-ln-code"))return 1;n=n.parentNode}}(t.anchorNode)||(n=-1!==window.navigator.userAgent.indexOf("Edge")?u(t):t.toString(),e.clipboardData.setData("text/plain",n),e.preventDefault())})}(window,document);
\ No newline at end of file
Index: csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/README
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/README	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.engines/highlight-ln/README	(revision 12)
@@ -0,0 +1,4 @@
+
+Current Version: 2.8.0
+
+ Home: https://github.com/wcoder/highlightjs-line-numbers.js
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono/FiraMono-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Mono.css	(revision 12)
@@ -0,0 +1,45 @@
+
+@font-face {
+  font-family: 'Fira Mono';
+  src: local('Fira Mono Regular'), /*  full font name */
+       local('FiraMono-Regular');  /* Postscript name */
+  src: url('../.fonts/Fira-Mono/FiraMono-Regular.eot');
+  src: url('../.fonts/Fira-Mono/FiraMono-Regular.eot?#iefix') format('embedded-opentype'),
+    url('../.fonts/Fira-Mono/FiraMono-Regular.otf') format('opentype'),
+    url('../.fonts/Fira-Mono/FiraMono-Regular.woff2') format('woff2'),
+    url('../.fonts/Fira-Mono/FiraMono-Regular.woff') format('woff'),
+    url('../.fonts/Fira-Mono/FiraMono-Regular.ttf') format('truetype'),
+    url('../.fonts/Fira-Mono/FiraMono-Regular.svg#FiraMono-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+
+@font-face {
+  font-family: 'Fira Mono';
+  src: local('Fira Mono Medium'), /*  full font name */
+       local('FiraMono-Medium');  /* Postscript name */
+  src: url('../.fonts/Fira-Mono/FiraMono-Medium.eot');
+  src: url('../.fonts/Fira-Mono/FiraMono-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Mono/FiraMono-Medium.otf') format('opentype'),
+       url('../.fonts/Fira-Mono/FiraMono-Medium.woff2') format('woff2'),
+       url('../.fonts/Fira-Mono/FiraMono-Medium.woff') format('woff'),
+       url('../.fonts/Fira-Mono/FiraMono-Medium.ttf') format('truetype'),
+       url('../.fonts/Fira-Mono/FiraMono-Medium.svg#FiraMono-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}/* font converted using font-converter.net. thank you! */
+
+@font-face {
+  font-family: 'Fira Mono';
+  src: local('Fira Mono Bold'), /*  full font name */
+       local('FiraMono-Bold');  /* Postscript name */
+  src: url('../.fonts/Fira-Mono/FiraMono-Bold.eot');
+  src: url('../.fonts/Fira-Mono/FiraMono-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Mono/FiraMono-Bold.otf') format('opentype'),
+       url('../.fonts/Fira-Mono/FiraMono-Bold.woff2') format('woff2'),
+       url('../.fonts/Fira-Mono/FiraMono-Bold.woff') format('woff'),
+       url('../.fonts/Fira-Mono/FiraMono-Bold.ttf') format('truetype'),
+       url('../.fonts/Fira-Mono/FiraMono-Bold.svg#FiraMono-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Black.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BlackItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLight.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-MediumItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-Thin.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans/FiraSans-ThinItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Condensed.css	(revision 12)
@@ -0,0 +1,253 @@
+
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Thin'), /*  full font name */
+       local('FiraSansCondensed-Thin');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Thin.svg#FiraSansCondensed-Thin') format('svg');
+  font-weight: 100;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Thin Italic'), /*  full font name */
+       local('FiraSansCondensed-ThinItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ThinItalic.svg#FiraSansCondensed-ThinItalic') format('svg');
+  font-weight: 100;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Extra Light'), /*  full font name */
+       local('FiraSansCondensed-ExtraLight');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLight.svg#FiraSansCondensed-ExtraLight') format('svg');
+  font-weight: 200;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Extra Light Italic'), /*  full font name */
+       local('FiraSansCondensed-ExtraLightItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraLightItalic.svg#FiraSansCondensed-ExtraLightItalic') format('svg');
+  font-weight: 200;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Light'), /*  full font name */
+       local('FiraSansCondensed-Light');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Light.svg#FiraSansCondensed-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Light Italic'), /*  full font name */
+       local('FiraSansCondensed-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-LightItalic.svg#FiraSansCondensed-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Regular'), /*  full font name */
+       local('FiraSansCondensed-Regular');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Regular.svg#FiraSansCondensed-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Italic'), /*  full font name */
+       local('FiraSansCondensed-Italic');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Italic.svg#FiraSansCondensed-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Medium'), /*  full font name */
+       local('FiraSansCondensed-Medium');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Medium.svg#FiraSansCondensed-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Medium Italic'), /*  full font name */
+       local('FiraSansCondensed-MediumItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-MediumItalic.svg#FiraSansCondensed-MediumItalic') format('svg');
+  font-weight: 500;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Semi Bold'), /*  full font name */
+       local('FiraSansCondensed-SemiBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBold.svg#FiraSansCondensed-SemiBold') format('svg');
+  font-weight: 600;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Semi Bold Italic'), /*  full font name */
+       local('FiraSansCondensed-SemiBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-SemiBoldItalic.svg#FiraSansCondensed-SemiBoldItalic') format('svg');
+  font-weight: 600;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Bold'), /*  full font name */
+       local('FiraSansCondensed-Bold');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Bold.svg#FiraSansCondensed-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Bold Italic'), /*  full font name */
+       local('FiraSansCondensed-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BoldItalic.svg#FiraSansCondensed-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Extra Bold'), /*  full font name */
+       local('FiraSansCondensed-ExtraBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBold.svg#FiraSansCondensed-ExtraBold') format('svg');
+  font-weight: 800;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Extra Bold Italic'), /*  full font name */
+       local('FiraSansCondensed-ExtraBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-ExtraBoldItalic.svg#FiraSansCondensed-ExtraBoldItalic') format('svg');
+  font-weight: 800;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Black'), /*  full font name */
+       local('FiraSansCondensed-Black');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-Black.svg#FiraSansCondensed-Black') format('svg');
+  font-weight: 900;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Condensed';
+  src: local('Fira Sans Condensed Black Italic'), /*  full font name */
+       local('FiraSansCondensed-BlackItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.eot');
+  src: url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Condensed/FiraSansCondensed-BlackItalic.svg#FiraSansCondensed-BlackItalic') format('svg');
+  font-weight: 900;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans-Extra-Condensed.css	(revision 12)
@@ -0,0 +1,253 @@
+
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Thin'), /*  full font name */
+       local('FiraSansExtraCondensed-Thin');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Thin.svg#FiraSansExtraCondensed-Thin') format('svg');
+  font-weight: 100;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Thin Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-ThinItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ThinItalic.svg#FiraSansExtraCondensed-ThinItalic') format('svg');
+  font-weight: 100;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Extra Light'), /*  full font name */
+       local('FiraSansExtraCondensed-ExtraLight');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLight.svg#FiraSansExtraCondensed-ExtraLight') format('svg');
+  font-weight: 200;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Extra Light Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-ExtraLightItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraLightItalic.svg#FiraSansExtraCondensed-ExtraLightItalic') format('svg');
+  font-weight: 200;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Light'), /*  full font name */
+       local('FiraSansExtraCondensed-Light');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Light.svg#FiraSansExtraCondensed-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Light Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-LightItalic.svg#FiraSansExtraCondensed-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Regular'), /*  full font name */
+       local('FiraSansExtraCondensed-Regular');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Regular.svg#FiraSansExtraCondensed-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-Italic');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Italic.svg#FiraSansExtraCondensed-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Medium'), /*  full font name */
+       local('FiraSansExtraCondensed-Medium');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Medium.svg#FiraSansExtraCondensed-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Medium Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-MediumItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-MediumItalic.svg#FiraSansExtraCondensed-MediumItalic') format('svg');
+  font-weight: 500;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Semi Bold'), /*  full font name */
+       local('FiraSansExtraCondensed-SemiBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBold.svg#FiraSansExtraCondensed-SemiBold') format('svg');
+  font-weight: 600;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Semi Bold Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-SemiBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-SemiBoldItalic.svg#FiraSansExtraCondensed-SemiBoldItalic') format('svg');
+  font-weight: 600;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Bold'), /*  full font name */
+       local('FiraSansExtraCondensed-Bold');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Bold.svg#FiraSansExtraCondensed-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Bold Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BoldItalic.svg#FiraSansExtraCondensed-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Extra Bold'), /*  full font name */
+       local('FiraSansExtraCondensed-ExtraBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBold.svg#FiraSansExtraCondensed-ExtraBold') format('svg');
+  font-weight: 800;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Extra Bold Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-ExtraBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-ExtraBoldItalic.svg#FiraSansExtraCondensed-ExtraBoldItalic') format('svg');
+  font-weight: 800;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Black'), /*  full font name */
+       local('FiraSansExtraCondensed-Black');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-Black.svg#FiraSansExtraCondensed-Black') format('svg');
+  font-weight: 900;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans Extra Condensed';
+  src: local('Fira Sans Extra Condensed Black Italic'), /*  full font name */
+       local('FiraSansExtraCondensed-BlackItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.eot');
+  src: url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans-Extra-Condensed/FiraSansExtraCondensed-BlackItalic.svg#FiraSansExtraCondensed-BlackItalic') format('svg');
+  font-weight: 900;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Fira-Sans.css	(revision 12)
@@ -0,0 +1,253 @@
+
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Thin'), /*  full font name */
+       local('FiraSans-Thin');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Thin.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Thin.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Thin.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Thin.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Thin.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Thin.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Thin.svg#FiraSans-Thin') format('svg');
+  font-weight: 100;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Thin Italic'), /*  full font name */
+       local('FiraSans-ThinItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-ThinItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-ThinItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ThinItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ThinItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-ThinItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-ThinItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-ThinItalic.svg#FiraSans-ThinItalic') format('svg');
+  font-weight: 100;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Extra Light'), /*  full font name */
+       local('FiraSans-ExtraLight');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraLight.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraLight.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLight.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLight.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLight.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLight.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLight.svg#FiraSans-ExtraLight') format('svg');
+  font-weight: 200;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Extra Light Italic'), /*  full font name */
+       local('FiraSans-ExtraLightItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraLightItalic.svg#FiraSans-ExtraLightItalic') format('svg');
+  font-weight: 200;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Light'), /*  full font name */
+       local('FiraSans-Light');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Light.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Light.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Light.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Light.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Light.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Light.svg#FiraSans-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Light Italic'), /*  full font name */
+       local('FiraSans-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-LightItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-LightItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-LightItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-LightItalic.svg#FiraSans-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Regular'), /*  full font name */
+       local('FiraSans-Regular');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Regular.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Regular.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Regular.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Regular.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Regular.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Regular.svg#FiraSans-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Italic'), /*  full font name */
+       local('FiraSans-Italic');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Italic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Italic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Italic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Italic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Italic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Italic.svg#FiraSans-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Medium'), /*  full font name */
+       local('FiraSans-Medium');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Medium.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Medium.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Medium.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Medium.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Medium.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Medium.svg#FiraSans-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Medium Italic'), /*  full font name */
+       local('FiraSans-MediumItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-MediumItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-MediumItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-MediumItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-MediumItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-MediumItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-MediumItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-MediumItalic.svg#FiraSans-MediumItalic') format('svg');
+  font-weight: 500;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Semi Bold'), /*  full font name */
+       local('FiraSans-SemiBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-SemiBold.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-SemiBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBold.svg#FiraSans-SemiBold') format('svg');
+  font-weight: 600;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Semi Bold Italic'), /*  full font name */
+       local('FiraSans-SemiBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-SemiBoldItalic.svg#FiraSans-SemiBoldItalic') format('svg');
+  font-weight: 600;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Bold'), /*  full font name */
+       local('FiraSans-Bold');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Bold.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Bold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Bold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Bold.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Bold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Bold.svg#FiraSans-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Bold Italic'), /*  full font name */
+       local('FiraSans-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-BoldItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-BoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-BoldItalic.svg#FiraSans-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Extra Bold'), /*  full font name */
+       local('FiraSans-ExtraBold');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraBold.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraBold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBold.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBold.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBold.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBold.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBold.svg#FiraSans-ExtraBold') format('svg');
+  font-weight: 800;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Extra Bold Italic'), /*  full font name */
+       local('FiraSans-ExtraBoldItalic');    /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-ExtraBoldItalic.svg#FiraSans-ExtraBoldItalic') format('svg');
+  font-weight: 800;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Black'), /*  full font name */
+       local('FiraSans-Black');  /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-Black.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-Black.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Black.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-Black.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-Black.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-Black.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-Black.svg#FiraSans-Black') format('svg');
+  font-weight: 900;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Fira Sans';
+  src: local('Fira Sans Black Italic'), /*  full font name */
+       local('FiraSans-BlackItalic');   /* Postscript name */
+  src: url('../.fonts/Fira-Sans/FiraSans-BlackItalic.eot');
+  src: url('../.fonts/Fira-Sans/FiraSans-BlackItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-BlackItalic.otf') format('opentype'),
+       url('../.fonts/Fira-Sans/FiraSans-BlackItalic.woff2') format('woff2'),
+       url('../.fonts/Fira-Sans/FiraSans-BlackItalic.woff') format('woff'),
+       url('../.fonts/Fira-Sans/FiraSans-BlackItalic.ttf') format('truetype'),
+       url('../.fonts/Fira-Sans/FiraSans-BlackItalic.svg#FiraSans-BlackItalic') format('svg');
+  font-weight: 900;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Black.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BlackItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-MediumItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-Thin.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto/Roboto-ThinItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Condensed.css	(revision 12)
@@ -0,0 +1,85 @@
+
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Light'), /*  full font name */
+       local('RobotoCondensed-Light');  /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Light.svg#RobotoCondensed-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Light Italic'), /*  full font name */
+       local('RobotoCondensed-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-LightItalic.svg#RobotoCondensed-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Regular'), /*  full font name */
+       local('RobotoCondensed-Regular');  /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Regular.svg#RobotoCondensed-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Italic'), /*  full font name */
+       local('RobotoCondensed-Italic');  /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Italic.svg#RobotoCondensed-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Bold'), /*  full font name */
+       local('RobotoCondensed-Bold');  /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-Bold.svg#RobotoCondensed-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Condensed';
+  src: local('Roboto Condensed Bold Italic'), /*  full font name */
+       local('Roboto-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.eot');
+  src: url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Condensed/RobotoCondensed-BoldItalic.svg#RobotoCondensed-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Bold.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Italic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Light.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-LightItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Medium.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Regular.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-Thin.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.eot
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.eot
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.otf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/vnd.ms-opentype

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.otf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/vnd.ms-opentype
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.ttf
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = font/sfnt

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.ttf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+font/sfnt
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff2
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff2
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto-Mono.css	(revision 12)
@@ -0,0 +1,141 @@
+
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Thin'), /*  full font name */
+       local('RobotoMono-Thin');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Thin.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Thin.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Thin.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Thin.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Thin.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Thin.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Thin.svg#RobotoMono-Thin') format('svg');
+  font-weight: 100;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Thin Italic'), /*  full font name */
+       local('RobotoMono-ThinItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-ThinItalic.svg#RobotoMono-ThinItalic') format('svg');
+  font-weight: 100;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Light'), /*  full font name */
+       local('RobotoMono-Light');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Light.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Light.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Light.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Light.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Light.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Light.svg#RobotoMono-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Light Italic'), /*  full font name */
+       local('RobotoMono-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-LightItalic.svg#RobotoMono-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Regular'), /*  full font name */
+       local('RobotoMono-Regular');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Regular.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Regular.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Regular.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Regular.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Regular.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Regular.svg#RobotoMono-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Italic'), /*  full font name */
+       local('RobotoMono-Italic');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Italic.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Italic.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Italic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Italic.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Italic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Italic.svg#RobotoMono-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Medium'), /*  full font name */
+       local('RobotoMono-Medium');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Medium.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Medium.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Medium.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Medium.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Medium.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Medium.svg#RobotoMono-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Medium Italic'), /*  full font name */
+       local('RobotoMono-MediumItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-MediumItalic.svg#RobotoMono-MediumItalic') format('svg');
+  font-weight: 500;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Bold'), /*  full font name */
+       local('RobotoMono-Bold');  /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Bold.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Bold.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Bold.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Bold.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Bold.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-Bold.svg#RobotoMono-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto Mono';
+  src: local('Roboto Mono Bold Italic'), /*  full font name */
+       local('Roboto-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.eot');
+  src: url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.woff') format('woff'),
+       url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto-Mono/RobotoMono-BoldItalic.svg#RobotoMono-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/.fonts/Roboto.css	(revision 12)
@@ -0,0 +1,169 @@
+
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Thin'), /*  full font name */
+       local('Roboto-Thin');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Thin.eot');
+  src: url('../.fonts/Roboto/Roboto-Thin.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Thin.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Thin.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Thin.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Thin.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Thin.svg#Roboto-Thin') format('svg');
+  font-weight: 100;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Thin Italic'), /*  full font name */
+       local('Roboto-ThinItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-ThinItalic.eot');
+  src: url('../.fonts/Roboto/Roboto-ThinItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-ThinItalic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-ThinItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-ThinItalic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-ThinItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-ThinItalic.svg#Roboto-ThinItalic') format('svg');
+  font-weight: 100;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Light'), /*  full font name */
+       local('Roboto-Light');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Light.eot');
+  src: url('../.fonts/Roboto/Roboto-Light.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Light.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Light.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Light.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Light.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Light.svg#Roboto-Light') format('svg');
+  font-weight: 300;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Light Italic'), /*  full font name */
+       local('Roboto-LightItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-LightItalic.eot');
+  src: url('../.fonts/Roboto/Roboto-LightItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-LightItalic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-LightItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-LightItalic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-LightItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-LightItalic.svg#Roboto-LightItalic') format('svg');
+  font-weight: 300;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Regular'), /*  full font name */
+       local('Roboto-Regular');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Regular.eot');
+  src: url('../.fonts/Roboto/Roboto-Regular.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Regular.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Regular.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Regular.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Regular.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Regular.svg#Roboto-Regular') format('svg');
+  font-weight: 400;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Italic'), /*  full font name */
+       local('Roboto-Italic');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Italic.eot');
+  src: url('../.fonts/Roboto/Roboto-Italic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Italic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Italic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Italic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Italic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Italic.svg#Roboto-Italic') format('svg');
+  font-weight: 400;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Medium'), /*  full font name */
+       local('Roboto-Medium');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Medium.eot');
+  src: url('../.fonts/Roboto/Roboto-Medium.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Medium.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Medium.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Medium.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Medium.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Medium.svg#Roboto-Medium') format('svg');
+  font-weight: 500;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Medium Italic'), /*  full font name */
+       local('Roboto-MediumItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-MediumItalic.eot');
+  src: url('../.fonts/Roboto/Roboto-MediumItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-MediumItalic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-MediumItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-MediumItalic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-MediumItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-MediumItalic.svg#Roboto-MediumItalic') format('svg');
+  font-weight: 500;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Bold'), /*  full font name */
+       local('Roboto-Bold');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Bold.eot');
+  src: url('../.fonts/Roboto/Roboto-Bold.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Bold.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Bold.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Bold.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Bold.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Bold.svg#Roboto-Bold') format('svg');
+  font-weight: 700;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Bold Italic'), /*  full font name */
+       local('Roboto-BoldItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-BoldItalic.eot');
+  src: url('../.fonts/Roboto/Roboto-BoldItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-BoldItalic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-BoldItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-BoldItalic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-BoldItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-BoldItalic.svg#Roboto-BoldItalic') format('svg');
+  font-weight: 700;
+  font-style: italic;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Black'), /*  full font name */
+       local('Roboto-Black');  /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-Black.eot');
+  src: url('../.fonts/Roboto/Roboto-Black.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-Black.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-Black.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-Black.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-Black.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-Black.svg#Roboto-Black') format('svg');
+  font-weight: 900;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'Roboto';
+  src: local('Roboto Black Italic'), /*  full font name */
+       local('Roboto-BlackItalic');   /* Postscript name */
+  src: url('../.fonts/Roboto/Roboto-BlackItalic.eot');
+  src: url('../.fonts/Roboto/Roboto-BlackItalic.eot?#iefix') format('embedded-opentype'),
+       url('../.fonts/Roboto/Roboto-BlackItalic.otf') format('opentype'),
+       url('../.fonts/Roboto/Roboto-BlackItalic.woff2') format('woff2'),
+       url('../.fonts/Roboto/Roboto-BlackItalic.woff') format('woff'),
+       url('../.fonts/Roboto/Roboto-BlackItalic.ttf') format('truetype'),
+       url('../.fonts/Roboto/Roboto-BlackItalic.svg#Roboto-BlackItalic') format('svg');
+  font-weight: 900;
+  font-style: italic;
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/css/csvn.css
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/css/csvn.css	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/css/csvn.css	(revision 12)
@@ -0,0 +1,1458 @@
+
+/*****************************************************************
+  static CSS: can be included by link rel="stylesheet" href="..."
+ */
+body {
+  margin: 0px;
+  min-width: 380px;
+  background-color: #dfdfdf;
+  color: #545454;
+
+  font-family: 'Roboto';
+  font-size: 16px;
+  font-weight: normal;
+}
+@media screen and (max-width: 1920px) {
+  body {
+    font-size: 14px;
+  }
+}
+
+/******************************
+  Common styles for HTML tags:
+ */
+a {
+  color: #545454;
+  background-color: transparent;
+}
+a, a:hover, a:active, a:focus {
+  outline: 0;
+  text-decoration: none;
+}
+a:hover {
+  color: #b40b22;
+}
+
+p {
+  text-align: justify;
+}
+p code {
+  font-size: 0.875em;   /* 14px   code in paragraph outside <pre> tags */
+  font-size: 0.90625em; /* 14.5px code in paragraph outside <pre> tags */
+}
+h1 {
+  font-family: 'Fira Sans';
+  font-size: 2.5em; /* 40px */
+  font-weight: 500;
+}
+@media screen and (max-width: 768px) {
+  h1 {
+    margin: 1rem 0rem;
+    font-size: 2.125em; /* 34px */
+  }
+}
+h2, h3, h4, h5, h6 {
+  font-family: 'Fira Sans';
+  font-weight: 500;
+}
+
+.leading {
+  font-size: 1.125em; /* 18px */
+  margin: 2em .175em;
+}
+
+/***********
+  Tooltips:
+ */
+.tooltip {
+  position: absolute;
+  z-index: 16000;
+  left: -9999px;
+  text-align: left;
+  padding: 1px 8px;
+  background-color: #fcfcfc;
+  border: 1px solid #71ad93;
+  border-radius: 4px;
+  box-shadow: 0 0 5px #aaa;
+
+  font-family: 'Roboto';
+  font-weight: 400;
+  font-style: normal;
+}
+.tooltip p {
+  white-space: nowrap;
+  margin: 3px 2px 2px 2px;
+  color: #727272;
+  background-color: #fcfcfc;
+  padding: 0px 2px;
+  font-size: 12px;
+}
+
+
+/******************************
+  Files with syntax highlight:
+ */
+pre {
+  font-family: 'Roboto Mono';
+  font-size: 0.875em;
+}
+.tab {
+  color: #c4c4c4;
+}
+/* override/add hljs class properties: */
+.hljs {
+  padding: 0.5em 0.5em 0.5em 1.5em;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+}
+
+/**************************
+  Markdown formated files:
+ */
+.markdown-content {
+  margin: 1em 0px;
+  padding: 0.5em 1em;
+  border: 1px solid #f9f9f9;
+  border-radius: 4px;
+}
+.markdown-content h1, h2, h3, h4, h5, h6 {
+  padding: 0.875rem 0rem 0.2rem;
+}
+/***************************************************************
+  Pseudo paragraps inserted before headers to skip the stiky
+  Main Menu Bar height when we going to anchor in a Markdown
+  document.
+ ***************************************************************/
+.headers-anchor {
+  margin:      0;
+  padding:     0;
+  position:    relative;
+  visibility:  hidden;
+  top:        -90px;
+}
+
+/*****************
+  Useful classes:
+ */
+.full-height {
+  height: 100%;
+}
+.full-width {
+  width: 100%;
+}
+.right {
+  margin: 0rem 0rem 0rem auto;
+}
+.left {
+  margin: 0rem auto 0rem 0rem;
+}
+.center {
+  margin: 0rem auto;
+}
+
+/***********************
+  Whole body container:
+ */
+.pushable {
+  overflow-x: hidden; /* hide popup menu bars */
+  width: 100%;
+}
+.pusher {
+  position: relative;
+  overflow: hidden;
+  min-height: 100%;
+  z-index: 2;
+}
+
+/****************************
+  Default Vertical Segments:
+ */
+.segment {
+  margin: 0px;
+  padding: 1em 0em 1em 0em;
+}
+.description.segment {
+  background-color: #adadad;
+  background-color: #a4a4a4;
+}
+.header.segment {
+  background-color: rgba( 102, 102, 102, 0.97 );
+/*  position: -webkit-sticky;*/
+  position: sticky;
+  top: 0;
+  z-index:10;
+}
+.header.segment > .container {
+  /* border-bottom: 1px solid #e9e9e9; */
+}
+.content.segment {
+  padding: 3rem 0rem 4rem 0rem;
+  background-color: #ffffff;
+}
+.footer.segment {
+  background-color: #dfdfdf; /* the same as body background! */
+  border-top: 1px solid #d9d9d9;
+}
+
+
+/*******************************
+  Default Horizontal Container:
+ */
+.container { margin: -1rem 1rem; }
+@media screen and (max-width: 768px) {
+  .container { margin: -1rem 0rem; }
+}
+@media screen and (min-width: 1920px) {
+  .container { margin: -1rem 8rem; }
+}
+@media screen and (min-width: 1400px) {
+  .container { margin: -1rem 4rem; }
+}
+@media screen and (min-width: 992px) {
+  .container { margin: -1rem 2rem; }
+}
+
+
+/*******************
+  Rows and Columns:
+ */
+.row {
+  display: grid;
+  justify-content: end;
+  grid-template-columns: repeat(24, 1fr);
+  grid-template-rows: 1fr;
+}
+.row:nth-of-type(2n) {
+  background-color: #f8f8f8;
+}
+
+[class^='row'] {
+  padding-top: 4px;
+  padding-bottom: 2px;
+}
+
+ .col-1 { grid-column: span  1; }
+ .col-2 { grid-column: span  2; }
+ .col-3 { grid-column: span  3; }
+ .col-4 { grid-column: span  4; }
+ .col-5 { grid-column: span  5; }
+ .col-6 { grid-column: span  6; }
+ .col-7 { grid-column: span  7; }
+ .col-8 { grid-column: span  8; }
+ .col-9 { grid-column: span  9; }
+.col-10 { grid-column: span 10; }
+.col-11 { grid-column: span 11; }
+.col-12 { grid-column: span 12; }
+.col-13 { grid-column: span 13; }
+.col-14 { grid-column: span 14; }
+.col-15 { grid-column: span 15; }
+.col-16 { grid-column: span 16; }
+.col-17 { grid-column: span 17; }
+.col-18 { grid-column: span 18; }
+.col-19 { grid-column: span 19; }
+.col-20 { grid-column: span 20; }
+.col-21 { grid-column: span 21; }
+.col-22 { grid-column: span 22; }
+.col-23 { grid-column: span 23; }
+.col-24 { grid-column: span 24; }
+
+
+[class^="col-"] {
+  padding: 0;
+  overflow: hidden; /* important for .trunc {} with text-overflow: ellipsis; */
+}
+
+.col-site-desc { grid-column: span 18; }
+.col-site-icon { grid-column: span  6; }
+.col-site-stat { grid-column: span 24; }
+
+.col-name    { grid-column: span  4; }
+.col-desc    { grid-column: span 12; }
+.col-owner   { grid-column: span  4; }
+.col-rev     { grid-column: span  2; }
+.col-idle    { grid-column: span  2; }
+
+.col-path    { grid-column: span 15; }
+.col-size    { grid-column: span  2; } /* 9 digits   max */
+.col-date    { grid-column: span  2; } /* YYYY-MM-DD max */
+.col-links   { grid-column: span  3; }
+
+.col-cmsg    { grid-column: span 18; }
+.col-author  { grid-column: span  2; }
+
+/* порядок media запросов имеет значение */
+@media screen and (min-width: 1921px) {
+  .col-name   { grid-column: span  4; }
+  .col-desc   { grid-column: span 12; }
+  .col-owner  { grid-column: span  4; }
+  .col-rev    { grid-column: span  2; }
+  .col-idle   { grid-column: span  2; }
+
+  .col-path   { grid-column: span 15; }
+  .col-size   { grid-column: span  2; }
+  .col-date   { grid-column: span  2; }
+  .col-links  { grid-column: span  3; }
+
+  .col-cmsg   { grid-column: span 18; }
+  .col-author { grid-column: span  2; }
+}
+@media screen and (max-width: 1920px) {
+  .col-name   { grid-column: span  4; }
+  .col-desc   { grid-column: span 12; }
+  .col-owner  { grid-column: span  4; }
+  .col-rev    { grid-column: span  2; }
+  .col-idle   { grid-column: span  2; }
+
+  .col-path   { grid-column: span 15; }
+  .col-size   { grid-column: span  2; }
+  .col-date   { grid-column: span  2; }
+  .col-links  { grid-column: span  3; }
+
+  .col-cmsg   { grid-column: span 17; }
+  .col-author { grid-column: span  3; }
+}
+@media screen and (max-width: 1440px) {
+  .col-name   { grid-column: span  4; }
+  .col-desc   { grid-column: span 12; }
+  .col-owner  { grid-column: span  4; }
+  .col-rev    { grid-column: span  2; }
+  .col-idle   { grid-column: span  2; }
+
+  .col-path   { grid-column: span 15; }
+  .col-size   { grid-column: span  2; }
+  .col-date   { grid-column: span  2; }
+  .col-links  { grid-column: span  3; }
+
+  .col-cmsg   { grid-column: span 16; }
+  .col-author { grid-column: span  4; }
+}
+@media screen and (max-width: 1200px) {
+  .col-name   { grid-column: span  5; }
+  .col-desc   { grid-column: span 10; }
+  .col-owner  { grid-column: span  4; }
+  .col-rev    { grid-column: span  2; }
+  .col-idle   { grid-column: span  3; }
+
+  .col-path   { grid-column: span 12; }
+  .col-size   { grid-column: span  3; }
+  .col-date   { grid-column: span  3; }
+  .col-links  { grid-column: span  4; }
+
+  .col-cmsg   { grid-column: span 14; }
+  .col-author { grid-column: span  4; }
+}
+@media screen and (max-width: 992px) {
+  .col-name   { grid-column: span  4; }
+  .col-desc   { grid-column: span 10; }
+  .col-owner  { grid-column: span  4; }
+  .col-rev    { grid-column: span  3; }
+  .col-idle   { grid-column: span  3; }
+
+  .col-path   { grid-column: span  8; }
+  .col-size   { grid-column: span  4; }
+  .col-date   { grid-column: span  4; }
+  .col-links  { grid-column: span  5; }
+
+  .col-cmsg   { grid-column: span 12; }
+  .col-author { grid-column: span  5; }
+}
+@media screen and (max-width: 768px) {
+  .col-name   { grid-column: span  5; }
+  .col-desc   { grid-column: span  7; }
+  .col-owner  { grid-column: span  5; }
+  .col-rev    { grid-column: span  3; }
+  .col-idle   { grid-column: span  4; }
+
+  .col-path   { grid-column: span  8; }
+  .col-size   { grid-column: span  4; }
+  .col-date   { grid-column: span  4; }
+  .col-links  { grid-column: span  5; }
+
+  .col-cmsg   { grid-column: span 11; }
+  .col-author { grid-column: span  6; }
+}
+
+@media screen and (max-width: 640px) {
+  .col-site-desc { grid-column: span 24; }
+  .col-site-icon { grid-column: span 24; }
+
+  .col-name   { grid-column: span  9; }
+  .col-desc   { display: none;        }
+  .col-owner  { grid-column: span  7; }
+  .col-rev    { grid-column: span  4; }
+  .col-idle   { grid-column: span  4; }
+
+  .col-path   { grid-column: span  9; }
+  .col-size   { grid-column: span  5; }
+  .col-date   { display: none; }
+  .col-links  { grid-column: span  6; }
+
+  .repo-log-header .col-date, .log .col-date {
+    display: block !important;
+    grid-column: span 5 !important;
+  }
+
+  .col-cmsg   { grid-column: span  9; }
+  .col-author { grid-column: span  6; }
+}
+
+
+/********************************
+  Description segment's classes:
+ */
+.csvn-main-description {
+  margin: 0rem 1rem;
+}
+.csvn-main-description h1 {
+  color: #f0f0ee;
+  margin-top: 1em;
+  margin-bottom: 0em;
+  font-size: 2.25em;
+  font-weight: 500;
+  color: #f0f0ee;
+  text-align: left;
+}
+.csvn-main-description p {
+  color: #5a0510;
+  margin-top: 0em;
+  padding-left: .1em;
+  padding-right: 0.875em;
+  padding-top: .6em;
+  padding-bottom: .1em;
+  font-family: 'Roboto';
+  font-size: 1.125em;
+  font-weight: 400;
+  text-align: justify;
+}
+.banner {
+  margin: 3em auto 1em auto;
+}
+@media screen and (max-width: 640px) {
+  .banner { margin: 1em auto 1em auto; }
+}
+.banner-image {
+  margin: 0em auto;
+  width: 96px;
+  height: 96px;
+  border-radius: 8px;
+  overflow: hidden;
+}
+@media screen and (min-width: 768px) {
+  .banner-image { margin: 0em 2em 0em auto; }
+}
+.banner-image img {
+  max-width: 96px;
+  max-height: 96px;
+}
+.site-stat {
+  color: #f7f5ef;
+  padding: 0.4em 0em 1.5em 0em;
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+  text-align: right;
+}
+
+/***************************
+  Header segment's classes:
+ */
+/* main menu: */
+.csvn-main-menu {
+  display: flex;
+  flex-direction: row;
+  border-bottom: 1px solid #979797;
+  align-items: center;
+  font-size: 1em; /* 16px */
+}
+@media screen and (min-width: 992px) {
+  .csvn-main-menu {
+    font-size: 1.125em; /* 18px */
+  }
+}
+
+.menu {
+  display: flex;
+  flex-direction: row;
+  align-items: center;
+}
+.menu a {
+  color: #f0f0ee;
+  background-color: transparent;
+}
+.menu a:hover {
+  text-shadow:  0px  0px 1px rgba(255,255,255,0.9);
+}
+
+.item {
+  margin: 1rem 0.5rem;
+  white-space: nowrap;
+  overflow-y: hidden;
+}
+.item > .icon {
+  width: 1.625rem;
+  text-align: center;
+  color: #bec3bb;
+}
+
+.left.menu > .item:first-of-type {
+  margin-left: 1rem;
+}
+.right.menu > .item:last-of-type {
+  margin-right: 1rem;
+}
+
+.header > .container > .csvn-main-menu > .right.menu {
+  /*background-color: #fcffff;*/
+}
+.header > .container > .csvn-main-menu > .left.menu {
+  /* background-color: #0f0; */
+}
+
+@media screen and (max-width: 768px) {
+  .header > .container > .csvn-main-menu > .left.menu > .item:not([class^="logo"]) {
+    display: none;
+  }
+  .header > .container > .csvn-main-menu > .right.menu > .item {
+    display: none;
+  }
+
+  .header > .container > .csvn-main-menu > .left.menu {
+    margin-right: -3.5rem !important;
+    margin-left: auto !important;
+  }
+  .header > .container > .csvn-main-menu > .right.menu {
+    margin-right: 0rem !important;
+  }
+}
+
+/* Right menu button (when screen width < 768px) */
+.csvn-main-menu-bars {
+  width: 100%;
+  margin: 0rem 1rem;
+  color: #f0f0ee;
+  background-color: transparent;
+  font-size: 1.5em; /* 24px */
+}
+.csvn-main-menu-bars:hover {
+  text-shadow:  0px  0px 1px rgba(255,255,255,0.9);
+  cursor: pointer;
+}
+@media screen and (min-width: 768px) { /* в зависимости от количества пунктов главного меню */
+  .csvn-main-menu-bars {
+    display: none;
+  }
+}
+
+/* Right popup menu (when screen width < 768px) */
+.csvn-popup-menu-bars {
+  max-width: 320px;
+  position: absolute;
+  top: 101%;
+  right: 1rem;
+  width: 200px;
+  background-color: rgba(102,102,102,0.97);
+  border: 1px solid rgba(108, 108, 108, 0.97);
+  border-radius: 0px 0px 4px 4px;
+  padding: 0.5rem 0.5rem;
+
+  opacity: 0;
+  transform: scaleY(0.0);
+  transform-origin: 0 0;
+  transition: 500ms ease-in-out;
+  z-index: 11;
+}
+@media screen and (max-width: 640px) {
+  .csvn-popup-menu-bars {
+    top: 102%;
+  }
+}
+
+.visible.csvn-popup-menu-bars {
+  opacity: 1;
+  transform: scaleY(1.0);
+}
+
+.csvn-popup-menu-bars > .item {
+  margin: 0.8rem 1rem;
+}
+.csvn-popup-menu-bars > .divider {
+  border-top: 1px solid #bec3bb; /*1px solid rgba(180, 11, 34, 0.6);*/
+  margin: 0.5em 1em;
+  height: 0em;
+}
+
+/*********************************
+  Main Sub Menu wirh search form:
+ */
+.csvn-sub-menu {
+  display: flex;
+  flex-direction: row;
+  align-items: center;
+  font-size: 0.875em; /* 14px */
+  color: #f0f0ee;
+}
+.sub-menu {
+  display: flex;
+  flex-direction: row;
+  align-items: center;
+}
+.sub-menu > .item {
+  margin: auto 0.5rem;
+  white-space: nowrap;
+  overflow-y: hidden;
+}
+.left.sub-menu {
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+.left.sub-menu > .item:first-of-type {
+  margin-left: 2rem;
+}
+.right.sub-menu > .item:last-of-type {
+  margin-right: 1rem;
+}
+.sub-menu a {
+  color: inherit;
+  background-color: transparent;
+}
+.sub-menu a.base {
+  color: inherit;
+}
+.sub-menu a.relative {
+  color: #f0f0ee;
+}
+.sub-menu a:hover {
+  text-shadow:  0px  0px 1px rgba(255,255,255,0.9);
+}
+
+.relative-path {
+  font-family: 'Fira Sans';
+  font-weight: 400;
+  /* color: #f7f5e7; */
+  color: #cadaba;
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+
+.search-form {
+  display: flex;
+  flex-direction: row;
+  margin: 0.2rem 0rem 0.6rem 0rem;
+}
+.search-button {
+  cursor: pointer;
+  margin: 0rem 0.1rem 0rem 0.2rem;
+}
+.search-form > input {
+  margin: 0em;
+  padding-left: 0.4rem;
+  max-width: 120px;
+  flex: 1 0 auto;
+  outline: none;
+  text-align: left;
+  font-family: 'Roboto';
+  background: transparent;
+  border: 1px solid transparent;
+  border-bottom: 1px solid #9b9b9b;
+  color: #f0f0ee;
+  box-shadow: none;
+}
+
+::placeholder {
+  color: #f0f0ee;
+  opacity: 0.4;
+}
+
+
+/****************************
+  Content segment's classes:
+ */
+.csvn-main-content {
+  margin: 0rem 1rem;
+}
+
+
+/******************************
+  Header of repositories list:
+ */
+.repo-list-header {
+  color: #5a0510;
+  font-family: 'Fira Sans';
+  font-weight: 500;
+  margin-bottom: 4px;
+}
+/********************
+  Repo list columns:
+ */
+.repo-name {
+  margin: 0rem 1rem;
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+.repo-desc {
+  margin-right: 1rem;
+  text-align: justify;
+}
+.repo-desc:not(.trunc) {
+  color: #000087;
+}
+.repo-owner {
+  margin-right: 1rem;
+  text-align: right;
+}
+@media screen and (max-width: 992px) {
+  .repo-owner { margin-right: 0.5rem; }
+}
+@media screen and (max-width: 480px) {
+  .repo-owner { margin-right: 1rem; }
+}
+.repo-owner:not(.trunc) {
+  color: #080808;
+}
+.repo-rev {
+  margin-right: 1rem;
+  text-align: right;
+}
+.repo-rev:not(.trunc) {
+  color: #5a0510;
+}
+.repo-idle {
+  margin-right: 1rem;
+}
+.repo-idle:not(.trunc) {
+  color: #080808;
+}
+.trunc {
+  white-space: nowrap !important;
+  overflow: hidden;
+  text-overflow: ellipsis;
+}
+
+/********************************************
+  Section of repos in the repositories list:
+ */
+.section {
+  grid-column: span 24;
+  padding-bottom: 8px;
+  color: #5b5b5b;
+}
+.section-header {
+  padding-top: 6px;
+  padding-bottom: 2px;
+  color: #9b9b9b;
+  margin-bottom: 6px;
+  font-style: italic;
+}
+.section .row:hover {
+  background-color: #f2f3f4;
+}
+
+/****************************
+  Header of repository tree:
+ */
+.repo-tree-header {
+  color: #5a0510;
+  font-family: 'Fira Sans';
+  font-weight: 500;
+  margin-bottom: 4px;
+}
+/********************
+  Tree list columns:
+ */
+.tree-path {
+  margin: 0rem 1rem;
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+.tree-size {
+  margin-right: 1rem;
+  text-align: right;
+}
+.tree-size:not(.trunc) {
+  color: #080808;
+}
+.tree-rev {
+  margin-right: 1rem;
+  text-align: right;
+}
+.tree-rev:not(.trunc) {
+  color: #5a0510;
+}
+.tree-date {
+  margin-right: 1rem;
+}
+.tree-date:not(.trunc) {
+  color: #080808;
+}
+.tree-links {
+  margin-right: 0rem;
+}
+
+/**************************
+  Repository Tree section:
+ */
+.tree {
+  grid-column: span 24;
+  padding-bottom: 8px;
+}
+.tree .row:hover {
+  background-color: #f2f3f4;
+}
+.dir {
+  color: #262626; /* color 235 */
+}
+.file {
+  color: #585858; /* color 240 */
+}
+.exec {
+  color: #007200; /* https://encycolorpedia.ru/007200 */
+}
+.tree a:hover,
+.tree a .dir:hover,
+.tree a .file:hover {
+  color: #b40b22;
+}
+
+/*******************
+  Checkout URL Box:
+ */
+.checkout-box {
+  padding-top: 1em;
+}
+.checkout-header {
+  color: #5a0510;
+  font-family: 'Fira Sans';
+  font-weight: 500;
+  margin-top: 1em;
+  margin-bottom: 4px;
+}
+.checkout-urls {
+  overflow-x: auto;
+  padding-bottom: 4px;
+}
+.checkout-line {
+  display: flex;
+  flex-direction: row;
+  font-family: 'Roboto Mono';
+  font-weight: 400;
+  font-size: 0.875em;
+}
+.checkout-perms {
+  font-weight: bold;
+  padding: 0rem 0.5rem 0rem 1rem;
+}
+.checkout-url {
+  padding-right: 1rem;
+  white-space: nowrap;
+}
+
+
+/*****************************
+  Repolist Prev/Next buttons:
+ */
+.direction {
+  display: block;
+  background-color: #f7f5e7;
+  border-radius: 4px;
+  margin: 1em 0em 2em 0em;
+  padding: 4px 0px 6px 0px;
+  font-size: 1em; /* 16px */
+}
+.col-prev    { grid-column: span 12; }
+.col-next    { grid-column: span 12; }
+
+.prev-direction {
+  display: block;
+  margin-left: 1rem;
+}
+.next-direction {
+  display: block;
+  margin-right: 1rem;
+}
+
+
+/****************
+  Header of log:
+ */
+.repo-log-header {
+  color: #5a0510;
+  font-family: 'Fira Sans';
+  font-weight: 500;
+  margin-bottom: 4px;
+}
+.log-date {
+  margin: 0rem 0rem 0rem 1rem;
+}
+.log .log-date:not(.trunc) {
+  color: #080808;
+}
+.log-cmsg {
+  margin: 0rem 1rem;
+  white-space: pre-wrap;
+  text-align: justify;
+}
+.log-cmsg:not(.trunc) {
+  color: #000087;
+}
+.log-rev {
+  margin-right: 1rem;
+  text-align: right;
+}
+.log-author {
+  margin-right: 1rem;
+}
+.log-author:not(.trunc) {
+  color: #080808;
+}
+
+/***************
+  Log section:
+ */
+.log {
+  grid-column: span 24;
+  padding-bottom: 8px;
+  margin-bottom: 2em;
+}
+.log .row:hover {
+  background-color: #f2f3f4;
+}
+
+/************************
+  Log Prev/Next buttons:
+ */
+.log-direction {
+  display: block;
+  background-color: #f7f5e7;
+  border-radius: 4px;
+  margin: 1em 0em 2em 0em;
+  padding: 4px 0px 6px 0px;
+  font-size: 1em; /* 16px */
+}
+.prev-log-direction {
+  display: block;
+  margin-left: 1rem;
+}
+.next-log-direction {
+  display: block;
+  margin-right: 1rem;
+}
+
+/************************
+  File Links Menu:
+ */
+.top {
+  margin-bottom: -0.7em;
+}
+.bottom {
+  margin-top: -0.8em;
+}
+.file-links-menu {
+  display: flex;
+  flex-direction: row;
+  align-items: flex-end;
+  color: #545454;
+}
+.links-menu {
+  display: flex;
+  flex-direction: row;
+  align-items: center;
+}
+.links-menu > .item {
+  margin: auto 0.5rem auto 0rem;
+  white-space: nowrap;
+  overflow-y: hidden;
+}
+.links-menu .item .icon {
+  color: #545454;
+}
+.file-links-menu a:hover {
+  color: #b40b22;
+}
+.file-links-menu .links-menu .item:last-child {
+  margin-right: 0.4em;
+}
+
+/***************************
+  Footer segment's classes:
+ */
+.csvn-footer {
+  margin: 0rem 1rem;
+}
+.copying {
+  margin: 0.5rem 0rem 4rem;
+  padding-top: 0.5em;
+  border-top: 1px solid #c9c9c9;
+}
+.copying > p {
+  margin: 0.2rem 0rem;
+  font-size: 0.75em; /* 12px */
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+
+/***************************
+  Server Software Versions:
+ */
+.versions {
+  display: flex;
+  flex-direction: row;
+  justify-content: center;
+  margin: 4rem auto 0rem;
+
+  padding-top: 0.5rem;
+  /* border-top: 1px solid #c9c9c9; */
+
+  font-family: 'Fira Sans';
+  font-size: 0.875em;
+  color: #5a0510;
+
+  white-space: nowrap;
+  overflow-x: hidden;
+  text-overflow: ellipsis;
+}
+.prog {
+  padding: 0rem 0.5rem 0rem 0.5rem;
+}
+.prog.svn {
+  border-left: 1px solid #5a0510;
+  border-right: 1px solid #5a0510;
+}
+.version {
+}
+.prog .tm {
+  color: #262626;
+  font-weight: 300;
+}
+
+/*******************************
+  Donate button in status line:
+ */
+a.donate {
+  color: #f7f5ef;
+}
+a.donate:hover {
+  color: #b40b22;
+  cursor: pointer;
+}
+a.donate .icon {
+  margin-left: 0.5em;
+}
+
+/*****************************************************
+  Icons for menu items (used with line-awesome font):
+ */
+.la, .las {
+  display: inline-block;
+  font-style: normal;
+  font-variant: normal;
+  line-height: 1;
+}
+
+.la-code-commit:before {
+  width: 1em;
+  height: 0.7em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20640%20512%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M128%20256c0%2010.8.9%2021.5%202.6%2032H12c-6.6%200-12-5.4-12-12v-40c0-6.6%205.4-12%2012-12h118.6c-1.7%2010.5-2.6%2021.2-2.6%2032zm500-32H509.4c1.8%2010.5%202.6%2021.2%202.6%2032s-.9%2021.5-2.6%2032H628c6.6%200%2012-5.4%2012-12v-40c0-6.6-5.4-12-12-12zm-308-80c-29.9%200-58%2011.7-79.2%2032.8C219.6%20198%20208%20226.1%20208%20256s11.6%2058%2032.8%2079.2C262%20356.3%20290.1%20368%20320%20368s58-11.7%2079.2-32.8C420.4%20314%20432%20285.9%20432%20256s-11.6-58-32.8-79.2C378%20155.7%20349.9%20144%20320%20144m0-48c88.4%200%20160%2071.6%20160%20160s-71.6%20160-160%20160-160-71.6-160-160S231.6%2096%20320%2096z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+
+.la-folder-tree:before {
+  width: 1.1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2.5px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20576%20512%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M288%20224h224a32%2032%200%200%200%2032-32V64a32%2032%200%200%200-32-32H400L368%200h-80a32%2032%200%200%200-32%2032v64H64V8a8%208%200%200%200-8-8H40a8%208%200%200%200-8%208v392a16%2016%200%200%200%2016%2016h208v64a32%2032%200%200%200%2032%2032h224a32%2032%200%200%200%2032-32V352a32%2032%200%200%200-32-32H400l-32-32h-80a32%2032%200%200%200-32%2032v64H64V128h192v64a32%2032%200%200%200%2032%2032zm0%2096h66.74l32%2032H512v128H288zm0-288h66.74l32%2032H512v128H288z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+
+.la-search-left:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 5px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20512%20512%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M508.5%20468.9L387.1%20347.5c-2.3-2.3-5.3-3.5-8.5-3.5h-13.2c31.5-36.5%2050.6-84%2050.6-136C416%2093.1%20322.9%200%20208%200S0%2093.1%200%20208s93.1%20208%20208%20208c52%200%2099.5-19.1%20136-50.6v13.2c0%203.2%201.3%206.2%203.5%208.5l121.4%20121.4c4.7%204.7%2012.3%204.7%2017%200l22.6-22.6c4.7-4.7%204.7-12.3%200-17zM208%20368c-88.4%200-160-71.6-160-160S119.6%2048%20208%2048s160%2071.6%20160%20160-71.6%20160-160%20160z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-search-left:before {
+    top: 3px;
+  }
+}
+
+.la-code-branch:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2011%204%20C%209.355469%204%208%205.355469%208%207%20C%208%208.292969%208.84375%209.394531%2010%209.8125%20L%2010%2022.1875%20C%208.84375%2022.605469%208%2023.707031%208%2025%20C%208%2026.644531%209.355469%2028%2011%2028%20C%2012.644531%2028%2014%2026.644531%2014%2025%20C%2014%2023.730469%2013.183594%2022.65625%2012.0625%2022.21875%20C%2012.207031%2020.988281%2012.683594%2020.382813%2013.4375%2019.875%20C%2014.335938%2019.269531%2015.714844%2018.910156%2017.21875%2018.5625%20C%2018.722656%2018.214844%2020.335938%2017.855469%2021.6875%2016.90625%20C%2022.875%2016.074219%2023.773438%2014.710938%2023.96875%2012.8125%20C%2025.140625%2012.402344%2026%2011.300781%2026%2010%20C%2026%208.355469%2024.644531%207%2023%207%20C%2021.355469%207%2020%208.355469%2020%2010%20C%2020%2011.277344%2020.832031%2012.351563%2021.96875%2012.78125%20C%2021.832031%2014.09375%2021.324219%2014.746094%2020.5625%2015.28125%20C%2019.664063%2015.910156%2018.277344%2016.28125%2016.78125%2016.625%20C%2015.285156%2016.96875%2013.664063%2017.273438%2012.3125%2018.1875%20C%2012.203125%2018.261719%2012.101563%2018.355469%2012%2018.4375%20L%2012%209.8125%20C%2013.15625%209.394531%2014%208.292969%2014%207%20C%2014%205.355469%2012.644531%204%2011%204%20Z%20M%2011%206%20C%2011.5625%206%2012%206.4375%2012%207%20C%2012%207.5625%2011.5625%208%2011%208%20C%2010.4375%208%2010%207.5625%2010%207%20C%2010%206.4375%2010.4375%206%2011%206%20Z%20M%2023%209%20C%2023.5625%209%2024%209.4375%2024%2010%20C%2024%2010.5625%2023.5625%2011%2023%2011%20C%2022.4375%2011%2022%2010.5625%2022%2010%20C%2022%209.4375%2022.4375%209%2023%209%20Z%20M%2011%2024%20C%2011.5625%2024%2012%2024.4375%2012%2025%20C%2012%2025.5625%2011.5625%2026%2011%2026%20C%2010.4375%2026%2010%2025.5625%2010%2025%20C%2010%2024.4375%2010.4375%2024%2011%2024%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-code-branch:before {
+    top: 2px;
+  }
+}
+
+.la-balance-scale:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%205%20C%2014.707031%205%2013.605469%205.84375%2013.1875%207%20L%206%207%20L%206%209%20L%207.40625%209%20L%207.125%209.5%20L%203.125%2016.5%20L%203%2016.75%20L%203%2017%20C%203%2019.75%205.25%2022%208%2022%20C%2010.75%2022%2013%2019.75%2013%2017%20L%2013%2016.75%20L%2012.875%2016.5%20L%208.875%209.5%20L%208.59375%209%20L%2013.1875%209%20C%2013.492188%209.84375%2014.15625%2010.507813%2015%2010.8125%20L%2015%2024%20L%2011%2024%20L%2011%2026%20L%2021%2026%20L%2021%2024%20L%2017%2024%20L%2017%2010.8125%20C%2017.839844%2010.507813%2018.507813%209.839844%2018.8125%209%20L%2023.40625%209%20L%2023.125%209.5%20L%2019.125%2016.5%20L%2019%2016.75%20L%2019%2017%20C%2019%2019.75%2021.25%2022%2024%2022%20C%2026.75%2022%2029%2019.75%2029%2017%20L%2029%2016.75%20L%2028.875%2016.5%20L%2024.875%209.5%20L%2024.59375%209%20L%2026%209%20L%2026%207%20L%2018.8125%207%20C%2018.394531%205.84375%2017.292969%205%2016%205%20Z%20M%2016%207%20C%2016.5625%207%2017%207.4375%2017%208%20C%2017%208.5625%2016.5625%209%2016%209%20C%2015.4375%209%2015%208.5625%2015%208%20C%2015%207.4375%2015.4375%207%2016%207%20Z%20M%208%2012.03125%20L%2010.28125%2016%20L%205.71875%2016%20Z%20M%2024%2012.03125%20L%2026.28125%2016%20L%2021.71875%2016%20Z%20M%205.25%2018%20L%2010.75%2018%20C%2010.347656%2019.160156%209.304688%2020%208%2020%20C%206.695313%2020%205.652344%2019.160156%205.25%2018%20Z%20M%2021.25%2018%20L%2026.75%2018%20C%2026.347656%2019.160156%2025.304688%2020%2024%2020%20C%2022.695313%2020%2021.652344%2019.160156%2021.25%2018%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-balance-scale:before {
+    top: 2px;
+  }
+}
+
+.la-bus:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%209%204%20C%206.800781%204%205%205.800781%205%208%20L%205%2013%20L%203%2013%20L%203%2016%20L%205%2016%20L%205%2027%20C%205%2027.550781%205.449219%2028%206%2028%20L%209%2028%20L%209.34375%2027%20L%2022.65625%2027%20L%2023%2028%20L%2026%2028%20C%2026.550781%2028%2027%2027.550781%2027%2027%20L%2027%2016%20L%2029%2016%20L%2029%2013%20L%2027%2013%20L%2027%208%20C%2027%205.800781%2025.199219%204%2023%204%20Z%20M%209%206%20L%2023%206%20C%2024.117188%206%2025%206.882813%2025%208%20L%207%208%20C%207%206.882813%207.882813%206%209%206%20Z%20M%207%2010%20L%2015%2010%20L%2015%2017%20L%207%2017%20Z%20M%2017%2010%20L%2025%2010%20L%2025%2017%20L%2017%2017%20Z%20M%207%2019%20L%2025%2019%20L%2025%2025%20L%207%2025%20Z%20M%208%2021%20L%208%2023%20L%2012%2023%20L%2012%2021%20Z%20M%2020%2021%20L%2020%2023%20L%2024%2023%20L%2024%2021%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-bus:before {
+    top: 2px;
+  }
+}
+
+.la-cloud-download:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%206%20C%2013.351563%206%2011.050781%207.238281%209.40625%209.0625%20C%209.269531%209.046875%209.148438%209%209%209%20C%206.800781%209%205%2010.800781%205%2013%20C%203.269531%2014.054688%202%2015.835938%202%2018%20C%202%2021.300781%204.699219%2024%208%2024%20L%2013%2024%20L%2013%2022%20L%208%2022%20C%205.78125%2022%204%2020.21875%204%2018%20C%204%2016.339844%205.007813%2014.921875%206.4375%2014.3125%20L%207.125%2014.03125%20L%207.03125%2013.28125%20C%207.011719%2013.117188%207%2013.023438%207%2013%20C%207%2011.882813%207.882813%2011%209%2011%20C%209.140625%2011%209.296875%2011.019531%209.46875%2011.0625%20L%2010.09375%2011.21875%20L%2010.46875%2010.71875%20C%2011.75%209.074219%2013.75%208%2016%208%20C%2019.277344%208%2022.011719%2010.253906%2022.78125%2013.28125%20L%2022.96875%2014.0625%20L%2023.8125%2014.03125%20C%2024.023438%2014.019531%2024.070313%2014%2024%2014%20C%2026.21875%2014%2028%2015.78125%2028%2018%20C%2028%2020.21875%2026.21875%2022%2024%2022%20L%2019%2022%20L%2019%2024%20L%2024%2024%20C%2027.300781%2024%2030%2021.300781%2030%2018%20C%2030%2014.84375%2027.511719%2012.316406%2024.40625%2012.09375%20C%2023.183594%208.574219%2019.925781%206%2016%206%20Z%20M%2015%2018%20L%2015%2026%20L%2012%2026%20L%2016%2030%20L%2020%2026%20L%2017%2026%20L%2017%2018%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-cloud-download:before {
+    top: 3px;
+  }
+}
+
+.la-cloud-upload:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%207%20C%2013.351563%207%2011.050781%208.238281%209.40625%2010.0625%20C%209.269531%2010.046875%209.148438%2010%209%2010%20C%206.800781%2010%205%2011.800781%205%2014%20C%203.269531%2015.054688%202%2016.835938%202%2019%20C%202%2022.300781%204.699219%2025%208%2025%20L%2013%2025%20L%2013%2023%20L%208%2023%20C%205.78125%2023%204%2021.21875%204%2019%20C%204%2017.339844%205.007813%2015.921875%206.4375%2015.3125%20L%207.125%2015.03125%20L%207.03125%2014.28125%20C%207.011719%2014.117188%207%2014.023438%207%2014%20C%207%2012.882813%207.882813%2012%209%2012%20C%209.140625%2012%209.296875%2012.019531%209.46875%2012.0625%20L%2010.09375%2012.21875%20L%2010.46875%2011.71875%20C%2011.75%2010.074219%2013.75%209%2016%209%20C%2019.277344%209%2022.011719%2011.253906%2022.78125%2014.28125%20L%2022.96875%2015.0625%20L%2023.8125%2015.03125%20C%2024.023438%2015.019531%2024.070313%2015%2024%2015%20C%2026.21875%2015%2028%2016.78125%2028%2019%20C%2028%2021.21875%2026.21875%2023%2024%2023%20L%2019%2023%20L%2019%2025%20L%2024%2025%20C%2027.300781%2025%2030%2022.300781%2030%2019%20C%2030%2015.84375%2027.511719%2013.316406%2024.40625%2013.09375%20C%2023.183594%209.574219%2019.925781%207%2016%207%20Z%20M%2016%2015%20L%2012%2019%20L%2015%2019%20L%2015%2027%20L%2017%2027%20L%2017%2019%20L%2020%2019%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-cloud-upload:before {
+    top: 3px;
+  }
+}
+
+.la-bars:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%204%207%20L%204%209%20L%2028%209%20L%2028%207%20Z%20M%204%2015%20L%204%2017%20L%2028%2017%20L%2028%2015%20Z%20M%204%2023%20L%204%2025%20L%2028%2025%20L%2028%2023%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-bars:before {
+    top: 3px;
+  }
+}
+
+.la-times:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%207.21875%205.78125%20L%205.78125%207.21875%20L%2014.5625%2016%20L%205.78125%2024.78125%20L%207.21875%2026.21875%20L%2016%2017.4375%20L%2024.78125%2026.21875%20L%2026.21875%2024.78125%20L%2017.4375%2016%20L%2026.21875%207.21875%20L%2024.78125%205.78125%20L%2016%2014.5625%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-times:before {
+    top: 3px;
+  }
+}
+
+.la-tags:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2014.59375%204%20L%2014.28125%204.28125%20L%203.28125%2015.28125%20L%202.59375%2016%20L%203.28125%2016.71875%20L%2012.28125%2025.71875%20L%2013%2026.40625%20L%2013.71875%2025.71875%20L%2024.71875%2014.71875%20L%2025%2014.40625%20L%2025%204%20Z%20M%2015.4375%206%20L%2023%206%20L%2023%2013.5625%20L%2013%2023.5625%20L%205.4375%2016%20Z%20M%2026%207%20L%2026%209%20L%2027%209%20L%2027%2017.15625%20L%2017.5%2026.59375%20L%2016.25%2025.34375%20L%2014.84375%2026.75%20L%2016.78125%2028.71875%20L%2017.5%2029.40625%20L%2018.1875%2028.71875%20L%2028.71875%2018.3125%20L%2029%2018%20L%2029%207%20Z%20M%2020%208%20C%2019.449219%208%2019%208.449219%2019%209%20C%2019%209.550781%2019.449219%2010%2020%2010%20C%2020.550781%2010%2021%209.550781%2021%209%20C%2021%208.449219%2020.550781%208%2020%208%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-tags:before {
+    top: 3px;
+  }
+}
+
+.la-tag:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%205%20L%2015.6875%205.28125%20L%204.28125%2016.8125%20L%203.59375%2017.5%20L%204.28125%2018.21875%20L%2013.78125%2027.71875%20L%2014.5%2028.40625%20L%2015.1875%2027.71875%20L%2026.71875%2016.3125%20L%2027%2016%20L%2027%205%20Z%20M%2016.84375%207%20L%2025%207%20L%2025%2015.15625%20L%2014.5%2025.59375%20L%206.40625%2017.5%20Z%20M%2022%209%20C%2021.449219%209%2021%209.449219%2021%2010%20C%2021%2010.550781%2021.449219%2011%2022%2011%20C%2022.550781%2011%2023%2010.550781%2023%2010%20C%2023%209.449219%2022.550781%209%2022%209%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-tag:before {
+    top: 3px;
+  }
+}
+
+.la-scroll:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2010%204%20C%208.355%204%207%205.355%207%207%20L%207%2021%20L%204%2021%20L%204%2025%20C%204%2026.645%205.355%2028%207%2028%20L%2021%2028%20L%2021.03125%2028%20C%2022.66025%2027.984%2024%2026.633%2024%2025%20L%2024%2011%20L%2028%2011%20L%2028%207%20C%2028%205.355%2026.645%204%2025%204%20L%2010%204%20z%20M%2010%206%20L%2022.1875%206%20C%2022.0745%206.316%2022%206.648%2022%207%20L%2022%2025%20C%2022%2025.566%2021.566%2026%2021%2026%20C%2020.437%2026.008%2020.008%2025.562%2020%2025%20L%2019.96875%2021%20L%209%2021%20L%209%207%20C%209%206.434%209.434%206%2010%206%20z%20M%2025%206%20C%2025.566%206%2026%206.434%2026%207%20L%2026%209%20L%2024%209%20L%2024%207%20C%2024%206.434%2024.434%206%2025%206%20z%20M%206%2023%20L%2014%2023%20L%2017.96875%2023%20L%2018%2023%20L%2018%2025%20L%2018%2025.03125%20C%2018.004%2025.37525%2018.0745%2025.691%2018.1875%2026%20L%207%2026%20C%206.434%2026%206%2025.566%206%2025%20L%206%2023%20z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-scroll:before {
+    top: 2px;
+  }
+}
+
+.la-chart-bar:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2021%204%20L%2021%2028%20L%2029%2028%20L%2029%204%20Z%20M%2023%206%20L%2027%206%20L%2027%2026%20L%2023%2026%20Z%20M%203%2010%20L%203%2028%20L%2011%2028%20L%2011%2010%20Z%20M%205%2012%20L%209%2012%20L%209%2026%20L%205%2026%20Z%20M%2012%2016%20L%2012%2028%20L%2020%2028%20L%2020%2016%20Z%20M%2014%2018%20L%2018%2018%20L%2018%2026%20L%2014%2026%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-chart-bar:before {
+    top: 2px;
+  }
+}
+
+.la-home:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%202.59375%20L%2015.28125%203.28125%20L%202.28125%2016.28125%20L%203.71875%2017.71875%20L%205%2016.4375%20L%205%2028%20L%2014%2028%20L%2014%2018%20L%2018%2018%20L%2018%2028%20L%2027%2028%20L%2027%2016.4375%20L%2028.28125%2017.71875%20L%2029.71875%2016.28125%20L%2016.71875%203.28125%20Z%20M%2016%205.4375%20L%2025%2014.4375%20L%2025%2026%20L%2020%2026%20L%2020%2016%20L%2012%2016%20L%2012%2026%20L%207%2026%20L%207%2014.4375%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-home:before {
+    top: 2px;
+  }
+}
+
+.la-road:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%205.46875%206%20L%205.28125%206.75%20L%200.625%2024.75%20L%200.28125%2026%20L%2031.71875%2026%20L%2031.375%2024.75%20L%2026.71875%206.75%20L%2026.53125%206%20Z%20M%207.03125%208%20L%2015.125%208%20L%2015.0625%2011%20L%2016.9375%2011%20L%2016.875%208%20L%2024.96875%208%20L%2029.125%2024%20L%2017.28125%2024%20L%2017.1875%2020%20L%2014.8125%2020%20L%2014.71875%2024%20L%202.875%2024%20Z%20M%2015%2013%20L%2014.875%2018%20L%2017.125%2018%20L%2017%2013%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-road:before {
+    top: 3px;
+  }
+}
+
+.la-diff:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 2px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20296%20296%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M295.934%2C69.249c0.051-2.252-0.868-4.413-2.523-5.934l-25.699-23.56c-1.442-1.32-3.316-2.054-5.271-2.054H155.5V17.319%20c0-4.311-3.491-7.8-7.8-7.8c-4.312%2C0-7.8%2C3.489-7.8%2C7.8v76.028H33.499c-1.95%2C0-3.832%2C0.731-5.271%2C2.049l-25.7%2C23.559%20c-1.658%2C1.518-2.577%2C3.682-2.526%2C5.934c0.054%2C2.252%2C1.077%2C4.367%2C2.803%2C5.807l25.702%2C21.419c1.404%2C1.173%2C3.166%2C1.812%2C4.992%2C1.812%20H139.9v124.689c0%2C4.312%2C3.488%2C7.8%2C7.8%2C7.8c4.309%2C0%2C7.8-3.488%2C7.8-7.8V146.127v-44.98v-2.867h106.935%20c1.823%2C0%2C3.59-0.64%2C4.991-1.808l25.695-21.419C294.857%2C73.618%2C295.878%2C71.501%2C295.934%2C69.249z%20M36.322%2C138.33l-16.681-13.898%20l16.889-15.48H139.9v29.378H36.322z%20M259.616%2C82.685H156.041V53.307h103.361l16.89%2C15.48L259.616%2C82.685z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-diff:before {
+    top: 2px;
+  }
+}
+
+.la-blame:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 3px;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2010.292969%205.292969%20L%207%208.585938%20L%205.707031%207.292969%20L%204.292969%208.707031%20L%207%2011.414063%20L%2011.707031%206.707031%20Z%20M%2014%207%20L%2014%209%20L%2028%209%20L%2028%207%20Z%20M%2014%2015%20L%2014%2017%20L%2028%2017%20L%2028%2015%20Z%20M%2014%2023%20L%2014%2025%20L%2028%2025%20L%2028%2023%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-blame:before {
+    top: 3px;
+  }
+}
+
+.la-credit-card:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0.1875em; /* 3px */
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%205%206%20C%203.355469%206%202%207.355469%202%209%20L%202%2023%20C%202%2024.644531%203.355469%2026%205%2026%20L%2027%2026%20C%2028.644531%2026%2030%2024.644531%2030%2023%20L%2030%209%20C%2030%207.355469%2028.644531%206%2027%206%20Z%20M%205%208%20L%2027%208%20C%2027.566406%208%2028%208.433594%2028%209%20L%2028%2011%20L%205%2011%20L%205%2013%20L%2028%2013%20L%2028%2023%20C%2028%2023.566406%2027.566406%2024%2027%2024%20L%205%2024%20C%204.433594%2024%204%2023.566406%204%2023%20L%204%209%20C%204%208.433594%204.433594%208%205%208%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-credit-card:before {
+    top: 0.1875em; /* 3px */
+  }
+}
+
+.la-ruble:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0.125em;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2011%206%20L%2011%2016%20L%209%2016%20L%209%2018%20L%2011%2018%20L%2011%2020%20L%209%2020%20L%209%2022%20L%2011%2022%20L%2011%2026%20L%2013%2026%20L%2013%2022%20L%2018%2022%20L%2018%2020%20L%2013%2020%20L%2013%2018%20L%2019%2018%20C%2022.300781%2018%2025%2015.300781%2025%2012%20C%2025%208.699219%2022.300781%206%2019%206%20Z%20M%2013%208%20L%2019%208%20C%2021.21875%208%2023%209.78125%2023%2012%20C%2023%2014.21875%2021.21875%2016%2019%2016%20L%2013%2016%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-ruble:before {
+    top: 0.125em; /* 2px */
+  }
+}
+
+.la-euro:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0.125em;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2018%204%20C%2013.261719%204%209.414063%207.886719%208.3125%2013%20L%206%2013%20L%206%2015%20L%208.0625%2015%20C%208.039063%2015.328125%208%2015.664063%208%2016%20C%208%2016.335938%208.039063%2016.671875%208.0625%2017%20L%206%2017%20L%206%2019%20L%208.3125%2019%20C%209.414063%2024.113281%2013.261719%2028%2018%2028%20C%2020.707031%2028%2023.167969%2026.695313%2024.9375%2024.65625%20L%2023.40625%2023.34375%20C%2021.953125%2025.019531%2020.070313%2026%2018%2026%20C%2014.496094%2026%2011.410156%2023.101563%2010.375%2019%20L%2019%2019%20L%2019%2017%20L%2010.03125%2017%20C%2010.003906%2016.667969%2010%2016.339844%2010%2016%20C%2010%2015.660156%2010.003906%2015.332031%2010.03125%2015%20L%2019%2015%20L%2019%2013%20L%2010.375%2013%20C%2011.410156%208.898438%2014.496094%206%2018%206%20C%2020.070313%206%2021.953125%206.980469%2023.40625%208.65625%20L%2024.9375%207.34375%20C%2023.167969%205.304688%2020.707031%204%2018%204%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-euro:before {
+    top: 0.125em; /* 2px */
+  }
+}
+
+.la-dollar:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0.125em;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2015%203%20L%2015%205.09375%20C%2012.164063%205.570313%2010%208.050781%2010%2011%20C%2010%2012.777344%2010.832031%2014.148438%2011.9375%2015.03125%20C%2013.042969%2015.914063%2014.375%2016.40625%2015.625%2016.90625%20C%2016.875%2017.40625%2018.042969%2017.914063%2018.8125%2018.53125%20C%2019.582031%2019.148438%2020%2019.773438%2020%2021%20C%2020%2023.15625%2018.207031%2025%2016%2025%20C%2013.78125%2025%2012%2023.21875%2012%2021%20L%2012%2020%20L%2010%2020%20L%2010%2021%20C%2010%2023.964844%2012.164063%2026.429688%2015%2026.90625%20L%2015%2029%20L%2017%2029%20L%2017%2026.90625%20C%2019.84375%2026.425781%2022%2023.925781%2022%2021%20C%2022%2019.21875%2021.167969%2017.855469%2020.0625%2016.96875%20C%2018.957031%2016.082031%2017.625%2015.5625%2016.375%2015.0625%20C%2015.125%2014.5625%2013.957031%2014.082031%2013.1875%2013.46875%20C%2012.417969%2012.855469%2012%2012.21875%2012%2011%20C%2012%208.808594%2013.785156%207%2016%207%20C%2018.21875%207%2020%208.78125%2020%2011%20L%2020%2012%20L%2022%2012%20L%2022%2011%20C%2022%208.035156%2019.835938%205.570313%2017%205.09375%20L%2017%203%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-dollar:before {
+    top: 0.125em; /* 2px */
+  }
+}
+
+.la-question-circle:before {
+  width: 1em;
+  height: 1em;
+  display: inline-flex;
+  position: relative;
+  left: 0;
+  top: 0.125em;
+  content: '';
+  background-color: currentColor;
+  -webkit-mask: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2032%2032%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M%2016%204%20C%209.382813%204%204%209.382813%204%2016%20C%204%2022.617188%209.382813%2028%2016%2028%20C%2022.617188%2028%2028%2022.617188%2028%2016%20C%2028%209.382813%2022.617188%204%2016%204%20Z%20M%2016%206%20C%2021.535156%206%2026%2010.464844%2026%2016%20C%2026%2021.535156%2021.535156%2026%2016%2026%20C%2010.464844%2026%206%2021.535156%206%2016%20C%206%2010.464844%2010.464844%206%2016%206%20Z%20M%2016%2010%20C%2013.800781%2010%2012%2011.800781%2012%2014%20L%2014%2014%20C%2014%2012.882813%2014.882813%2012%2016%2012%20C%2017.117188%2012%2018%2012.882813%2018%2014%20C%2018%2014.765625%2017.507813%2015.445313%2016.78125%2015.6875%20L%2016.375%2015.8125%20C%2015.558594%2016.082031%2015%2016.863281%2015%2017.71875%20L%2015%2019%20L%2017%2019%20L%2017%2017.71875%20L%2017.40625%2017.59375%20C%2018.945313%2017.082031%2020%2015.621094%2020%2014%20C%2020%2011.800781%2018.199219%2010%2016%2010%20Z%20M%2015%2020%20L%2015%2022%20L%2017%2022%20L%2017%2020%20Z%22%2F%3E%3C%2Fsvg%3E');
+  -webkit-mask-size: cover;
+}
+@media screen and (min-width: 1920px) {
+  .la-question-circle:before {
+    top: 0.125em; /* 2px */
+  }
+}
Index: csvn-ui-0.1.5/csvncgi/.csvn/html/footer.html
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/html/footer.html	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/html/footer.html	(revision 12)
@@ -0,0 +1,36 @@
+
+      </div> <!-- End of front_wrapper -->
+
+      <div class="footer segment">
+          <div class="container">
+            <div class="csvn-footer">
+
+              <!-- cSvn-ui 0.0.9 | Subversion 1.14.0 | Nginx 1.12.2 -->
+              <div class="versions">
+                  <div class="prog">cSvn-ui<span class="tm">&#8482;</span> <span class="version">${csvn-version}</span></div>
+                  <div class="prog svn">Subversion<span class="tm">&#8482;</span> <span class="version">${svn-version}</span></div>
+                  <div class="prog">Nginx<span class="tm">&#8482;</span> <span class="version">${nginx-version}</span></div>
+              </div>
+
+              <div class="copying container">
+                <p class="copyright-notice">
+                  <!-- При использовании материалов указание источника обязательнo. -->
+                  ${copyright-notice}
+                </p>
+                <p class="copyright">
+                  <!-- &#169; Андрей В. Костельцев, 2009 &#8211; 2020. -->
+                  ${copyright}
+                </p>
+              </div>
+            </div>
+          </div>
+      </div>  <!-- End of footer -->
+
+    </div> <!-- End of pusher -->
+
+${donate-css}
+${donate-html}
+${donate-js}
+
+  </body>
+</html>
Index: csvn-ui-0.1.5/csvncgi/.csvn/html/header.html
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/html/header.html	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/html/header.html	(revision 12)
@@ -0,0 +1,193 @@
+<!DOCTYPE html>
+<html lang="en-US">
+  <head>
+    <meta charset="utf-8">
+    <!--[if IE]><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><![endif]-->
+    <meta name="viewport" content="width=device-width, initial-scale=1.0">
+
+    <meta name="owner" content="${owner}">
+    <meta name="author" content="${author}">
+    <meta name="description" content="${description}">
+    <meta name="keywords" content="${keywords}">
+
+${analytic-links}
+    <title>${title}</title>
+
+    <link rel="apple-touch-icon" sizes="180x180" href="${favicon-path}/apple-touch-icon.png">
+    <link rel="icon" type="image/png" sizes="32x32" href="${favicon-path}/favicon-32x32.png">
+    <link rel="icon" type="image/png" sizes="16x16" href="${favicon-path}/favicon-16x16.png">
+    <link rel="manifest" href="${favicon-path}/site.webmanifest">
+    <link rel="mask-icon" href="${favicon-path}/safari-pinned-tab.svg" color="#5bbad5">
+    <link rel="shortcut icon" href="${favicon-path}/favicon.ico">
+    <meta name="msapplication-TileColor" content="#da532c">
+    <meta name="msapplication-config" content="${favicon-path}/browserconfig.xml">
+    <meta name="theme-color" content="#ffffff">
+
+
+    <!-- Font Fira-Sans -->
+    <link rel="stylesheet" href="/.csvn/.fonts/Fira-Sans.css">
+    <!-- Font Fira-Sans-Condensed -->
+    <!-- <link rel="stylesheet" href="/.csvn/.fonts/Fira-Sans-Condensed.css"> -->
+    <!-- Font Fira-Sans-Extra-Condensed -->
+    <!-- <link rel="stylesheet" href="/.csvn/.fonts/Fira-Sans-Extra-Condensed.css"> -->
+    <!-- Font Fira-Mono -->
+    <!-- <link rel="stylesheet" href="/.csvn/.fonts/Fira-Mono.css"> -->
+    <!-- Font Roboto -->
+    <link rel="stylesheet" href="/.csvn/.fonts/Roboto.css">
+    <!-- Font Roboto-Condensed -->
+    <!-- <link rel="stylesheet" href="/.csvn/.fonts/Roboto-Condensed.css"> -->
+    <!-- Font Roboto-Mono -->
+    <link rel="stylesheet" href="/.csvn/.fonts/Roboto-Mono.css">
+
+    <!-- Syntax Highlight Themes -->
+    <link rel="stylesheet" href="/.csvn/.engines/highlight/10.4.0/css/${syntax-highlight-css}">
+
+    <!-- Highlight line numbers Theme -->
+    <link rel="stylesheet" href="/.csvn/.engines/highlight-ln/2.8.0/css/highlightjs-line-numbers.css">
+
+    <!-- Highlight js -->
+    <script src="/.csvn/.engines/highlight/10.4.0/js/highlight.pack.js"></script>
+    <!-- Highlight line numbers js -->
+    <script src="/.csvn/.engines/highlight-ln/2.8.0/js/highlightjs-line-numbers.min.js"></script>
+
+
+    <!-- cSvn main static CSS -->
+    <link rel="stylesheet" href="${css}">
+
+    <style>
+      /*
+        template CSS: site/repository main menu logo: background-image: url("${main-menu-logo}");
+       */
+      .logo-32:before {
+        content: " ";
+        background-image: url("${main-menu-logo}");
+        width: 2em; /* base body font size 16px */
+        height: 2em;
+        position: absolute;
+        top: 0.625em;
+      }
+      @media screen and (min-width: 992px) {
+        .logo-32:before {
+          top: 0.5625em;
+        }
+      }
+      .logo-32-text {
+        margin-left: 2.375em;
+      }
+    </style>
+
+    <script>
+      /*******************
+        common variables:
+       */
+      var page_type    = '${page-type}';
+      var page_size    =  ${page-size};
+      var num_of_repos =  ${num-of-repos};
+      var snapshots    = '${snapshots}';
+    </script>
+
+    <!-- cSvn main static JavaScript -->
+    <script src="/.csvn/js/csvn.js"></script>
+
+${analytic-scripts}
+  </head>
+  <body class="pushable">
+
+    <div class="description segment">
+      <div class="container">
+        <div class="csvn-main-description">
+
+          <div class="row">
+            <div class="col-site-desc">
+              <!-- Site/Repo Title and Description -->
+              <h1>${title}</h1>
+              <p>
+                ${description}
+              </p>
+            </div>
+            <div class="col-site-icon">
+              <div class="banner">
+                <div class="banner-image">
+                  <!-- Site/Repo Logo, alt and Link (see also left menu HOME item) -->
+                  <a target="_blank" href="${logo-link}">
+                    <img alt="${logo-alt}" src="${logo}"/>
+                  </a>
+                </div>
+              </div>
+            </div>
+            <div class="col-site-stat">
+              <div class="site-stat" dir="rtl">
+                &lrm;${status-line}
+              </div>
+            </div>
+
+          </div> <!-- End of row -->
+
+        </div> <!-- End of csvn-main-description -->
+      </div>
+    </div>
+
+    <div class="header segment">
+      <div class="container">
+        <div class="csvn-main-menu">
+          <div class="left menu">
+            <div class="logo-32 item">
+              <div class="logo-32-text">
+                <!-- <a href="">index</a>  -->
+                ${main-menu-item}
+              </div>
+            </div>
+            <!-- <div class="item"><a href="">tags</a></div>
+                 <div class="item"><a href="">branches</a></div>
+                 <div class="item"><a href="">log</a></div>
+                 <div class="item"><a href="">tree</a></div>
+                 <div class="item"><a href="">commit</a></div>
+                 <div class="item"><a href="">stats</a></div> -->
+            ${left-menu-items}
+          </div>
+          <div class="right menu">
+            <div class="csvn-main-menu-bars"><span class="las la-bars"></span></div>
+            <div class="csvn-popup-menu-bars">
+              <!-- <div class="item"><span class="icon las la-tags"></span><a href="">tags</a></div>
+                   <div class="item"><span class="icon las la-code-branch"></span><a href="">branches</a></div>
+                   <div class="item"><span class="icon las la-scroll"></span><a href="">log</a></div>
+                   <div class="item"><span class="icon las la-folder-tree"></span><a href="">tree</a></div>
+                   <div class="item"><span class="icon las la-code-commit"></span><a href="">commit</a></div>
+                   <div class="item"><span class="icon las la-chart-bar"></span><a href="">stats</a></div>
+                   <div class="divider"></div>
+                   <div class="item"><span class="icon las la-home"></span>
+                     <a href="https://example.org/" target="_blank">home</a>
+                   </div> -->
+              ${popup-menu-items}
+            </div>
+            <!-- <div class="item"><a href="https://example.org/" target="_blank">Home page</a></div> -->
+            ${right-menu-items}
+          </div>
+        </div> <!-- End of 'csvn-main-menu' -->
+
+        <div class="csvn-sub-menu">
+          <div class="left sub-menu">
+            <div class="item">
+              <div class="relative-path">
+                <!-- <a class="base">trunk</a>/<a class="relative">Makefile</a> -->
+                ${relative-html}
+              </div>
+            </div>
+          </div>
+          <div class="right sub-menu">
+            <div class="item">
+              <div class="search-form">
+                <!-- Search Placeholder -->
+                <input class="search" type="text" placeholder="${search-placeholder}">
+                <div class="search-button" onclick="search()"><span class="icon las la-search-left"></span></div>
+              </div>
+            </div>
+          </div>
+        </div> <!-- End of 'csvn-sub-menu' -->
+
+      </div>
+    </div>
+
+
+    <div class="pusher">
+      <div id="front_wrapper" class="full-height">
Index: csvn-ui-0.1.5/csvncgi/.csvn/js/csvn.js
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/js/csvn.js	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/js/csvn.js	(revision 12)
@@ -0,0 +1,329 @@
+
+function get_query_parameter( name, url = window.location.href )
+{
+  name = name.replace( /[\[\]]/g, '\\$&' );
+  var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)'), results = regex.exec(url);
+  if( !results ) return null;
+  if( !results[2] ) return '';
+  return decodeURIComponent( results[2].replace(/\+/g, ' ') );
+}
+
+function removeParam( query_string, param ) {
+  if( query_string !== "" )
+  {
+    var query = "";
+    var params = decodeURIComponent(query_string).split('&');
+    var i, name;
+    for( i = 0; i < params.length; ++i ) {
+      name = params[i].split('=');
+      if( name[0] !== param ) {
+        query = query + name[0] + '=' + name[1] + '&';
+      }
+    }
+    if( query !== "" ) {
+      query = query.substring( 0, query.length - 1 );
+    }
+  }
+  return query;
+}
+
+function search() {
+
+  var text = document.querySelector( '.search-form input' ).value;
+
+  if( page_type === "repo" && text )
+  {
+    var path         = window.location.pathname;
+    var query_string = window.location.search;
+    var revision     = encodeURIComponent( text );
+
+    if( query_string ) {
+      query_string = query_string.substring( 1, query_string.length );
+      query_string = removeParam( query_string, "rev" );
+      query_string = removeParam( query_string, "op" );
+    }
+
+    revision = revision.toLowerCase();
+    if( revision === "head" ) {
+      revision = "0";
+    }
+
+    document.querySelector( '.search-form input' ).value = "";
+
+    window.location.pathname = path;
+    if( query_string ) {
+      window.location.search = "?rev=" + revision + "&" + query_string;
+    } else {
+      window.location.search = "?rev=" + revision;
+    }
+  }
+  if( page_type === "repolist" && text )
+  {
+    var path         = window.location.pathname;
+    var query_string = window.location.search;
+    var repo_path    = encodeURIComponent( text );
+
+    if( query_string ) {
+      query_string = query_string.substring( 1, query_string.length );
+      query_string = removeParam( query_string, "search" );
+    }
+
+    document.querySelector( '.search-form input' ).value = "";
+
+    window.location.pathname = path;
+    if( query_string ) {
+      window.location.search = "?search=" + repo_path + "&" + query_string;
+    } else {
+      window.location.search = "?search=" + repo_path;
+    }
+  }
+}
+
+function show_hide_direction() {
+  var direction = document.querySelector( '.direction' );
+  var prev = document.querySelector( '.prev-direction' );
+  var next = document.querySelector( '.next-direction' );
+  var ofs = get_query_parameter( 'ofs' );
+
+  if( direction )
+  {
+    if( num_of_repos < page_size ) {
+      direction.style.display = 'none';
+    }
+    else {
+      direction.style.display = 'block';
+
+      if( (num_of_repos - ofs) < page_size ) { next.style.display = 'none';  }
+      else                                   { next.style.display = 'block'; }
+
+      if( ofs > 0 ) { prev.style.display = 'block'; }
+      else          { prev.style.display = 'none';  }
+    }
+  }
+}
+
+/***************************************************************
+  We dont want to use tooltips from any foreign engine.
+  NOTE:
+    All tooltips we attached to the '.pusher' element.
+ */
+function fade_out( element ) {
+  /* постепенно исчезать */
+  var op = 1;  /* initial opacity */
+  var timer = setInterval( function() {
+    if( op <= 0.1 ) {
+      clearInterval( timer );
+      element.style.display = 'none';
+    }
+    element.style.opacity = op;
+    element.style.filter = 'alpha(opacity=' + op * 100 + ")";
+    op -= op * 0.1;
+  }, 10);
+}
+
+function fade_in( element ) {
+  /* постепенно появляться */
+  var op = 0.1;  /* initial opacity */
+  element.style.display = 'block';
+  var timer = setInterval( function() {
+    if( op >= 1 ) {
+      clearInterval( timer );
+    }
+    element.style.opacity = op;
+    element.style.filter = 'alpha(opacity=' + op * 100 + ")";
+    op += op * 0.1;
+  }, 10);
+}
+
+function simple_tooltip( target_items, name ) {
+  var pusher = document.querySelector( '.pusher' );
+  var items = document.querySelectorAll( target_items );
+
+  items.forEach( function( item, i, array ) {
+    var html = "<div class='" + name +
+               "' id='" + name + "-" + i +
+               "'><p>" + item.getAttribute('title') +
+               "</p></div>";
+    pusher.insertAdjacentHTML( 'beforeend', html );
+
+    var tooltip = document.querySelector( "#" + name + "-" + i );
+
+    item.removeAttribute( 'title' );
+    item.addEventListener( "mouseover", function( event ) {
+      fade_in( tooltip );
+    });
+    item.addEventListener( "mousemove", function( kmouse ) {
+      /***********************************************
+         c - client is a browser window;
+         o - offset from page (document) coordinate.
+         t - tooltip;
+       ***********************************************/
+      var cW  = window.innerWidth;
+      var cH  = window.innerHeight;
+      var cX  = kmouse.clientX;
+      var cY  = kmouse.clientY;
+      var tW  = tooltip.offsetWidth;
+      var tH  = tooltip.offsetHeight;
+      var oX;
+      var oY;
+      if( ( cW - cX ) < ( tW + 15) ) { oX = - 15 - tW; } else { oX = 15; }
+      if( ( cH - cY ) < ( tH + 15) ) { oY = - 15 - tH; } else { oY = 15; }
+      tooltip.style.left = kmouse.pageX + oX + 'px';
+      tooltip.style.top  = kmouse.pageY + oY - pusher.offsetTop + 'px';
+    });
+    item.addEventListener( "mouseout", function( event ) {
+      fade_out( tooltip );
+    });
+  });
+}
+
+/*******************************************
+  Truncate descriptions or commit messages:
+ */
+function trunc(el) {
+  if( el.classList.contains('trunc') )
+  {
+    el.classList.remove('trunc');
+  }
+  else
+  {
+    el.classList.add('trunc');
+  }
+}
+
+/*****************************
+  Show/Hide right popup menu:
+ */
+function show_sidebar(event) {
+  var sidebar = document.querySelector('.csvn-popup-menu-bars');
+  sidebar.classList.add("visible");
+
+  /* change icon bars->times */
+  var icon = document.querySelector('.csvn-main-menu-bars .las');
+  icon.classList.remove("la-bars");
+  icon.classList.add("la-times");
+
+  var sb = document.querySelector('.csvn-main-menu-bars');
+  sb.onclick = hide_sidebar;
+
+  if( !event )
+    event = window.event;
+  event.stopPropagation();
+}
+
+function hide_sidebar(event) {
+  var sidebar = document.querySelector('.csvn-popup-menu-bars');
+  sidebar.classList.remove("visible");
+
+  /* change icon times->bars */
+  var icon = document.querySelector('.csvn-main-menu-bars .las');
+  icon.classList.remove("la-times");
+  icon.classList.add("la-bars");
+
+  var sb = document.querySelector('.csvn-main-menu-bars');
+  sb.onclick = show_sidebar;
+
+  if( !event )
+    event = window.event;
+  event.stopPropagation();
+}
+
+/********************
+  on Document Ready:
+ */
+document.addEventListener('DOMContentLoaded', function() {
+
+  /* initialy show main popup menu on click */
+  var sb = document.querySelector('.csvn-main-menu-bars');
+  sb.onclick = show_sidebar;
+
+  var items = document.querySelectorAll('.csvn-popup-menu-bars > .item');
+  items.forEach( function(item) {
+    /* each item should hide main popup menu */
+    item.onclick = hide_sidebar;
+  });
+
+  window.addEventListener('resize', function(event) {
+    var width = window.innerWidth;
+    if( width > 768 ) {
+      /* change icon times->bars */
+      var icon = document.querySelector('.csvn-main-menu-bars .las');
+      icon.classList.remove("la-times");
+      icon.classList.add("la-bars");
+
+      /* hide main popup menu */
+      var sidebar = document.querySelector('.csvn-popup-menu-bars');
+      sidebar.classList.remove("visible");
+    }
+    else {
+      /* show main popup menu on click after resize */
+      var sb = document.querySelector('.csvn-main-menu-bars');
+      sb.onclick = show_sidebar;
+    }
+  });
+
+
+  /*************************************************
+    Skip line numbering in the Markdown content:
+   */
+  var mdcode = document.querySelectorAll('.markdown-content code');
+  mdcode.forEach( function( block ) {
+    block.classList.add('nohljsln');
+  });
+
+  /*************************************************
+    Skip line numbering in the Blame content:
+   */
+  var blame = document.querySelectorAll('.blame code');
+  blame.forEach( function( block ) {
+    block.classList.add('nohljsln');
+  });
+
+  /*************************************************
+    Initialize highlight.js with hljs line numbers:
+   */
+  hljs.configure({
+    useBR: false,
+    /* languages: 'Makefile Bash C Perl',*/
+    tabReplace: '<span class="tab">&lt;------&gt;</span>'
+  });
+
+  var preformated = document.querySelectorAll('pre code');
+  preformated.forEach( function( block ) {
+    hljs.highlightBlock( block ); /* init hljs */
+    if( false === block.classList.contains('nohljsln') )
+    {
+      hljs.lineNumbersBlock( block, { /* init hljs line numbers with options: */
+        startFrom: 0,
+        singleLine: false
+      });
+    }
+  });
+
+
+  /***************************************************************
+    Pseudo paragraphs inserted before headers to skip the stiky
+    Main Menu Bar height when we going to anchor in a Markdown
+    document.
+   */
+  var mdheaders = document.querySelectorAll('.markdown-content h1,h2,h3,h4,h5,h6');
+  mdheaders.forEach( function( header ) {
+    var content = header.textContent;
+    var id = content.toLowerCase().replaceAll( ' ', '-' ).replaceAll( ':', '' );
+
+    var ph = document.createElement( 'p' );
+    ph.setAttribute( 'class', 'headers-anchor' )
+    ph.setAttribute( 'id', id );
+    header.parentNode.insertBefore( ph, header );
+  });
+
+  var input = document.querySelector( '.search-form input' );
+  input.addEventListener( "keyup", function( event ) {
+    if( event.key === "Enter" ) {
+      search();
+    }
+  });
+
+  simple_tooltip( "[title]", "tooltip" );
+  show_hide_direction();
+});
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/csvn-banner-280x280.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/csvn-banner-280x280.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/android-chrome-192x192.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/android-chrome-192x192.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/android-chrome-512x512.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/android-chrome-512x512.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/apple-touch-icon.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/apple-touch-icon.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/browserconfig.xml
===================================================================
--- csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/browserconfig.xml	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/browserconfig.xml	(revision 12)
@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="utf-8"?>
+<browserconfig>
+    <msapplication>
+        <tile>
+            <square150x150logo src="/.csvn/pixmaps/favicon/mstile-150x150.png"/>
+            <TileColor>#da532c</TileColor>
+        </tile>
+    </msapplication>
+</browserconfig>
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon-16x16.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon-16x16.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon-32x32.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon-32x32.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon.ico
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/vnd.microsoft.icon

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/favicon.ico
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/vnd.microsoft.icon
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-144x144.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-144x144.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-150x150.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-150x150.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-310x150.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-310x150.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-310x310.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-310x310.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-70x70.png
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/png

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/mstile-70x70.png
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/png
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/safari-pinned-tab.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/safari-pinned-tab.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/site.webmanifest
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/json

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/favicon/site.webmanifest
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/json
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-744x744.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-744x744.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-black-744x744.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-black-744x744.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = image/svg+xml

Property changes on: csvn-ui-0.1.5/csvncgi/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+image/svg+xml
\ No newline at end of property
Index: csvn-ui-0.1.5/csvncgi/Makefile.am
===================================================================
--- csvn-ui-0.1.5/csvncgi/Makefile.am	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/Makefile.am	(revision 12)
@@ -0,0 +1,36 @@
+
+AM_CPPFLAGS       = -I@top_srcdir@ -DLOCALEDIR='"$(localedir)"'
+
+script_PROGRAMS   = csvn-ui.cgi
+script_DATA       = robots.txt .csvn/pixmaps/favicon/favicon.ico
+
+csvn_ui_cgi_SOURCES  = csvn-cgi.c ctx.c date.c dlist.c fatal.c
+csvn_ui_cgi_SOURCES += html.c http.c repolist.c strbuf.c system.c wrapper.c
+csvn_ui_cgi_SOURCES += ui-shared.c ui-repolist.c ui-file.c ui-tree.c ui-diff.c
+csvn_ui_cgi_SOURCES += ui-blame.c ui-log.c cmpvers.c
+
+noinst_HEADERS    = ctx.h date.h dlist.h fatal.h
+noinst_HEADERS   += html.h http.h repolist.h strbuf.h system.h wrapper.h
+noinst_HEADERS   += ui-shared.h ui-repolist.h ui-file.h ui-tree.h ui-diff.h
+noinst_HEADERS   += ui-blame.h ui-log.h cmpvers.h
+
+man5_MANS = csvn-ui.rc.5
+notrans_dist_man5_MANS = csvn-ui.rc.5
+
+#
+# Add: libxml2, ...
+#
+CPPFLAGS   += $(XML_CFLAGS)
+LIBS       += $(XML_LIBS)
+
+dirs = .csvn
+install-data-local:
+	@for d in $(dirs); do \
+	   $(mkinstalldirs) "$(DESTDIR)$(scriptdir)" ; \
+	   cp -a $$d "$(DESTDIR)$(scriptdir)" ; \
+	 done
+
+uninstall-local:
+	@for d in $(dirs); do \
+	   cd "$(DESTDIR)$(scriptdir)" && rm -rf $$d ; \
+	 done
Index: csvn-ui-0.1.5/csvncgi/cmpvers.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/cmpvers.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/cmpvers.c	(revision 12)
@@ -0,0 +1,95 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdint.h>
+#include <string.h>
+#include <ctype.h>
+
+/* states: S_N: normal, S_I: comparing integral part, S_F: comparing
+           fractionnal parts, S_Z: idem but with leading Zeroes only */
+#define  S_N    0x0
+#define  S_I    0x3
+#define  S_F    0x6
+#define  S_Z    0x9
+
+/* result_type: CMP: return diff; LEN: compare using len_diff/diff */
+#define  CMP    2
+#define  LEN    3
+
+
+/* Compare S1 and S2 as strings holding indices/version numbers,
+   returning less than, equal to or greater than zero if S1 is less than,
+   equal to or greater than S2 (for more info, see the texinfo doc).
+*/
+
+int cmp_version( const char *s1, const char *s2 )
+{
+  const unsigned char *p1 = (const unsigned char *)s1;
+  const unsigned char *p2 = (const unsigned char *)s2;
+
+  /* Symbol(s)    0       [1-9]   others
+     Transition   (10) 0  (01) d  (00) x   */
+  static const uint8_t next_state[] =
+  {
+      /* state    x    d    0  */
+      /* S_N */  S_N, S_I, S_Z,
+      /* S_I */  S_N, S_I, S_I,
+      /* S_F */  S_N, S_F, S_F,
+      /* S_Z */  S_N, S_F, S_Z
+  };
+
+  static const int8_t result_type[] =
+  {
+      /* state   x/x  x/d  x/0  d/x  d/d  d/0  0/x  0/d  0/0  */
+
+      /* S_N */  CMP, CMP, CMP, CMP, LEN, CMP, CMP, CMP, CMP,
+      /* S_I */  CMP, -1,  -1,  +1,  LEN, LEN, +1,  LEN, LEN,
+      /* S_F */  CMP, CMP, CMP, CMP, CMP, CMP, CMP, CMP, CMP,
+      /* S_Z */  CMP, +1,  +1,  -1,  CMP, CMP, -1,  CMP, CMP
+  };
+
+  if( p1 == p2 ) return 0;
+
+  unsigned char c1 = *p1++;
+  unsigned char c2 = *p2++;
+  /* Hint: '0' is a digit too.  */
+  int state = S_N + ((c1 == '0') + (isdigit (c1) != 0));
+
+  int diff;
+  while( (diff = c1 - c2) == 0 )
+    {
+      if( c1 == '\0' ) return diff;
+
+      state  = next_state[state];
+      c1     = *p1++;
+      c2     = *p2++;
+      state += (c1 == '0') + (isdigit (c1) != 0);
+    }
+
+  state = result_type[state * 3 + (((c2 == '0') + (isdigit (c2) != 0)))];
+
+  switch (state)
+  {
+    case CMP:
+      return diff;
+
+    case LEN:
+      while( isdigit (*p1++) )
+        if( !isdigit (*p2++) )
+          return 1;
+
+      return isdigit (*p2) ? -1 : diff;
+
+    default:
+      return state;
+  }
+}
+
+
+const char *max_version( const char *s1, const char *s2 )
+{
+  if( cmp_version( s1, s2 ) < 0 ) return s2;
+  else                            return s1;
+}
Index: csvn-ui-0.1.5/csvncgi/cmpvers.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/cmpvers.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/cmpvers.h	(revision 12)
@@ -0,0 +1,18 @@
+
+#ifndef _CMP_VERSION_H_
+#define _CMP_VERSION_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern int cmp_version( const char *s1, const char *s2 );
+extern const char *max_version( const char *s1, const char *s2 );
+
+
+#ifdef __cplusplus
+}  /* ... extern "C" */
+#endif
+
+#endif /* _CMP_VERSION_H_ */
Index: csvn-ui-0.1.5/csvncgi/csvn-cgi.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/csvn-cgi.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/csvn-cgi.c	(revision 12)
@@ -0,0 +1,267 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#define _GNU_SOURCE
+#include <getopt.h>
+
+#include <nls.h>
+
+#include <defs.h>
+#include <cscm/bcf.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+#include <ui-repolist.h>
+#include <ui-file.h>
+#include <ui-tree.h>
+#include <ui-diff.h>
+#include <ui-blame.h>
+#include <ui-log.h>
+
+
+static void free_resources( void )
+{
+  if( config ) free_config();
+}
+
+int main( int argc, char *argv[] )
+{
+
+  __mctx_init();
+
+  setlocale( LC_ALL, "" );
+#if ENABLE_NLS == 1
+  bindtextdomain( PACKAGE, LOCALEDIR );
+  textdomain( PACKAGE );
+#endif
+
+  csvn_prepare_context();
+
+  /************************
+    define error handlers:
+   */
+   system_fatal = fatal_html;
+  wrapper_fatal = fatal_html;
+    dlist_fatal = fatal_html;
+    rlist_fatal = fatal_html;
+     http_fatal = fatal_html;
+     html_fatal = fatal_html;
+
+  if( !(config = read_config()) )
+  {
+    fatal_html( "cannot read config file: /dev/shm%s", CSVN_SHM_BCF );
+    free_resources();
+    exit( 1 );
+  }
+
+  csvn_parse_query();
+
+  csvn_prepare_template_variables();
+
+  if( ctx.page.status == 404 )
+  {
+    csvn_print_404_page();
+    csvn_release_template_variables();
+    free_resources();
+    return 0;
+  }
+
+  if( !strcmp( ctx.vars.page_type, ptype_repolist ) )
+  {
+    if( ctx.query.search && *ctx.query.search )
+    {
+      csvn_search_repo( ctx.query.search );
+    }
+    csvn_print_repolist_page();
+  }
+  else if( !strcmp( ctx.vars.page_type, ptype_repo ) )
+  {
+    if( ctx.query.operation && *ctx.query.operation && !strcmp( ctx.query.operation, "diff" ) )
+    {
+      csvn_print_diff_page();
+    }
+    else if( ctx.query.operation && *ctx.query.operation && !strcmp( ctx.query.operation, "log" ) )
+    {
+      csvn_print_log_page();
+    }
+    else if( ctx.repo.relative_info.kind == KIND_FILE )
+    {
+      if( ctx.query.operation && *ctx.query.operation && !strcmp( ctx.query.operation, "blame" ) )
+      {
+        csvn_print_blame_page();
+      }
+      else
+      {
+        csvn_print_file_page();
+      }
+    }
+    else if( ctx.repo.relative_info.kind == KIND_DIR )
+    {
+      csvn_print_tree_page();
+    }
+    else
+    {
+      csvn_print_repolist_page();
+    }
+  }
+
+#if 0
+  {
+    struct strbuf buf  = STRBUF_INIT;
+
+    strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+    strbuf_addf( &buf, "          <div class=\"container\">\n" );
+    strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+    strbuf_addf( &buf, "<pre><code class='language-text'>HTTP_HOST = %s\n", ctx.env.http_host );
+    strbuf_addf( &buf, "HTTPS = %s\n", ctx.env.https );
+    strbuf_addf( &buf, "NO_HTTP = %s\n", ctx.env.no_http );
+    strbuf_addf( &buf, "PATH_INFO = %s\n", ctx.env.path_info );
+    strbuf_addf( &buf, "QUERY_STRING = %s\n", ctx.env.query_string );
+    strbuf_addf( &buf, "REQUEST_URI = %s\n", ctx.env.request_uri );
+    strbuf_addf( &buf, "REQUEST_SCHEME = %s\n", ctx.env.request_scheme );
+    strbuf_addf( &buf, "REQUEST_METHOD = %s\n", ctx.env.request_method );
+    strbuf_addf( &buf, "SCRIPT_NAME = %s\n", ctx.env.script_name );
+    strbuf_addf( &buf, "SERVER_NAME = %s\n", ctx.env.server_name );
+    strbuf_addf( &buf, "SERVER_PORT = %s\n", ctx.env.server_port );
+    strbuf_addf( &buf, "HTTP_COOKIE = %s\n", ctx.env.http_cookie );
+    strbuf_addf( &buf, "CONTENT_LENGTH = %d\n", ctx.env.content_lenght );
+    strbuf_addf( &buf, "HTTP_ROOT = %s\n", ctx.env.http_root );
+
+    strbuf_addf( &buf, "\naddition:\n" );
+    strbuf_addf( &buf, "DOCUMENT_ROOT = %s\n", getenv("DOCUMENT_ROOT") );
+    strbuf_addf( &buf, "DOCUMENT_URI = %s\n", getenv("DOCUMENT_URI") );
+    strbuf_addf( &buf, "PATH_TRANSLATED = %s\n", getenv("PATH_TRANSLATED") );
+    strbuf_addf( &buf, "SERVER_SOFTWARE = %s\n", getenv("SERVER_SOFTWARE") );
+    strbuf_addf( &buf, "SERVER_PROTOCOL = %s\n", getenv("SERVER_PROTOCOL") );
+    strbuf_addf( &buf, "SERVER_ADDR = %s\n", getenv("SERVER_ADDR") );
+    strbuf_addf( &buf, "REMOTE_ADDR = %s\n", getenv("REMOTE_ADDR") );
+    strbuf_addf( &buf, "GATEWAY_INTERFACE = %s\n", getenv("GATEWAY_INTERFACE") );
+    strbuf_addf( &buf, "SERVER_PROTOCOL = %s\n", getenv("SERVER_PROTOCOL") );
+
+    strbuf_addf( &buf, "\nctx:\n" );
+    strbuf_addf( &buf, "ctx.query.ofs = %d;\n", ctx.query.ofs );
+    strbuf_addf( &buf, "ctx.query.rev = %d;\n", ctx.query.rev );
+    strbuf_addf( &buf, "ctx.query.revision = '%s';\n", ctx.query.revision );
+    strbuf_addf( &buf, "ctx.query.operation = '%s';\n", ctx.query.operation );
+    strbuf_addf( &buf, "ctx.query.search = '%s';\n", ctx.query.search );
+    strbuf_addf( &buf, "\n" );
+    strbuf_addf( &buf, "ctx.repo.name = %s\n", ctx.repo.name );
+    strbuf_addf( &buf, "ctx.repo.repo_root = %s\n", ctx.repo.repo_root );
+    strbuf_addf( &buf, "ctx.repo.info = {\n" );
+    switch( ctx.repo.info.kind )
+    {
+      case KIND_DIR:
+        strbuf_addf( &buf, "  kind = '%s';\n", "dir" );
+        break;
+      case KIND_FILE:
+        strbuf_addf( &buf, "  kind = '%s';\n", "file" );
+        break;
+      default:
+        strbuf_addf( &buf, "  kind = '%s';\n", "unknown" );
+        break;
+    }
+    strbuf_addf( &buf, "  revision = %d;\n", ctx.repo.info.revision );
+    strbuf_addf( &buf, "  author = '%s';\n", ctx.repo.info.author );
+    strbuf_addf( &buf, "  date = %"PRIdMAX";\n", ctx.repo.info.date );
+    strbuf_addf( &buf, "  mime = '%s';\n", ctx.repo.info.mime );
+    strbuf_addf( &buf, "  lang = '%s';\n", ctx.repo.info.lang );
+    strbuf_addf( &buf, "}\n" );
+
+    strbuf_addf( &buf, "ctx.repo.relative_path = %s\n", ctx.repo.relative_path );
+    strbuf_addf( &buf, "ctx.repo.relative_info = {\n" );
+    switch( ctx.repo.relative_info.kind )
+    {
+      case KIND_DIR:
+        strbuf_addf( &buf, "  kind = '%s';\n", "dir" );
+        break;
+      case KIND_FILE:
+        strbuf_addf( &buf, "  kind = '%s';\n", "file" );
+        break;
+      default:
+        strbuf_addf( &buf, "  kind = '%s';\n", "unknown" );
+        break;
+    }
+    strbuf_addf( &buf, "  revision = %d;\n", ctx.repo.relative_info.revision );
+    strbuf_addf( &buf, "  author = '%s';\n", ctx.repo.relative_info.author );
+    strbuf_addf( &buf, "  date = %"PRIdMAX";\n", ctx.repo.relative_info.date );
+    strbuf_addf( &buf, "  mime = '%s';\n", ctx.repo.relative_info.mime );
+    strbuf_addf( &buf, "  lang = '%s';\n", ctx.repo.relative_info.lang );
+    strbuf_addf( &buf, "}\n" );
+
+    strbuf_addf( &buf, "ctx.repo.relative_href = %s\n", ctx.repo.relative_href );
+    strbuf_addf( &buf, "ctx.repo.relative_html = %s\n", ctx.repo.relative_html );
+
+    strbuf_addf( &buf, "ctx.repo.trunk = %s\n", ctx.repo.trunk );
+    strbuf_addf( &buf, "ctx.repo.branches = %s\n", ctx.repo.branches );
+    strbuf_addf( &buf, "ctx.repo.tags = %s\n", ctx.repo.tags );
+    strbuf_addf( &buf, "ctx.repo.checkout_ro_prefix = %s\n", ctx.repo.checkout_ro_prefix );
+    strbuf_addf( &buf, "ctx.repo.checkout_prefix = %s\n", ctx.repo.checkout_prefix );
+    strbuf_addf( &buf, "ctx.repo.nbranches = %d\n", ctx.repo.nbranches );
+    strbuf_addf( &buf, "ctx.repo.ntags = %d\n", ctx.repo.ntags );
+
+    strbuf_addf( &buf, "ctx.vers.subversion = %s\n", ctx.vers.subversion );
+    strbuf_addf( &buf, "ctx.vers.nginx = %s\n", ctx.vers.nginx );
+    strbuf_addf( &buf, "ctx.vers.csvn = %s\n", ctx.vers.csvn );
+
+    strbuf_addf( &buf, "</code></pre>\n" );
+
+    print_config( &buf, config );
+
+    strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+    strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+    strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+    ctx.page.size = buf.len;
+
+    strbuf_write( &buf, STDOUT_FILENO );
+    strbuf_release( &buf );
+  }
+#endif
+
+  csvn_release_template_variables();
+  free_resources();
+
+  return 0;
+}
Index: csvn-ui-0.1.5/csvncgi/csvn-ui.rc.5
===================================================================
--- csvn-ui-0.1.5/csvncgi/csvn-ui.rc.5	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/csvn-ui.rc.5	(revision 12)
@@ -0,0 +1,637 @@
+.\"
+.TH "CSVN-UI.RC" 5 "2020-11-07" "cSvn-ui CGI script" "csvn-ui.rc"
+
+.SH "NAME"
+\fB/etc/csvn-ui.rc\fR \- cSvn CGI script config file
+
+.SH "DESCRIPTION"
+\fB/etc/csvn-ui.rc\fR file describes Subversion repositories which should be shown by \fBcSvn-ui\fR CGI script.
+
+.SH "FILE FORMAT"
+\fB/etc/csvn-ui.rc\fR is regular text file created by user to present Subversion repositories. This file reads by \fBcscmd\fR daemon
+and converts to binary form for \fBcSvn-ui\fR CGI script. Binary format allows to minimize the time needed for complete HTTP responses.
+.PP
+The configuration file consists of a set of variable or repository declarations also configuration file can contains section
+of repository descriptions. The C/C++ comments are available:
+.PP
+.in +4n
+.EX
+\fI
+/****************************
+  Apache's SVN repositories:
+ */
+home-page = "https://svn.apache.org/";
+
+repo 'subversion' {
+  owner = "Apache";
+  description = "Source repository of the Subversion.";
+  checkout-prefix-readonly = 'https://svn.apache.org/repos/asf';
+}
+
+section "Other Repositories" {
+  repo 'other-repository' {
+    . . .
+  }
+  . . .
+}
+\fR
+.EE
+.in
+
+.SH "DATA TYPES"
+Configuration file assumes three types of variables.
+
+.PP
+\fBint\fR \- integer constants. Example declaration:
+.PP
+.in +4n
+.EX
+\fItrue = 1;\fR
+.EE
+.in
+
+.PP
+\fBstring\fR \- string constants. Example declaration:
+.PP
+.in +4n
+.EX
+\fIname = "Apache Subversion";\fR
+.EE
+.in
+
+.PP
+\fBpath\fR \- path constants. Example declaration:
+.PP
+.in +4n
+.EX
+\fIpath = '/etc/csvn-ui.rc';\fR
+.EE
+.in
+
+.SH "RESERVED VARIABLES"
+There is a set of variable names used by \fBcSvn-ui\fR CGI Script.
+
+.TP 4
+\fBsvn-utc-offset\fR
+The integer or string value of UTC offset on the SVN server where repositories are published. For example:
+.PP
+.in +6n
+.EX
+\fIsvn-utc-offset = +0300; /* Europe/Moscow time zone */\fR
+.EE
+.in
+
+.TP 4
+\fBrepo-root\fR
+The name of directory where some repository is placed related to \fBsvn repositories root\fR directory. For example:
+.PP
+.in +6n
+.EX
+\fIrepo-root = 'tools';\fR
+.EE
+.in
+
+.TP 4
+\fBcheckout-prefix-readonly\fR
+The checkout prefix for readonly access to the repository. The value of this variable should has \fBpath\fR type
+without leadinfg dir-separator. Example  declaration:
+.PP
+.in +6n
+.EX
+\fIcheckout-prefix-readonly = 'svn://example.com';\fR
+\fIcheckout-prefix-readonly = 'https://svn.example.com/svn';\fR
+.EE
+.in
+
+.RS 4
+Please note that \fBsvn\fR protocol works match quickly.
+.RE
+
+.TP 4
+\fBcheckout-prefix\fR
+The checkout prefix for readwrite access to the repository. The value of this variable should has \fBpath\fR type
+without leadinfg dir-separator. Example declaration:
+.PP
+.in +6n
+.EX
+\fIcheckout-prefix = 'svn+ssh://svn@example.com';\fR
+.EE
+.in
+
+.RS 4
+This means the access on behalf \fIsvn\fR system user.
+.RE
+
+.TP 4
+\fBbranches\fR
+The name of directory where branches is places. Default value is \fIbranches\fR.
+.TP 4
+\fBtrunk\fR
+The name of the \fItrunk\fR directory. Default value is \fItrunks\fR.
+.TP 4
+\fBtags\fR
+The name of directory where tags are saved. Default value is \fItags\fR.
+.RS 4
+Example declarations of directory names:
+.RE
+.PP
+.in +6n
+.EX
+\fIbranches = 'branches';\fR
+\fItrunk    = 'trunk';\fR
+\fItags     = 'tags';\fR
+.EE
+.in
+
+.TP 4
+\fBsnapshots\fR
+The extension of snapshot tarballs. Default value: \fI'tar.xz'\fR. Example declaration:
+.PP
+.in +6n
+.EX
+\fIsnapshots = 'tar.xz';\fR
+.EE
+.in
+
+.RS 4
+Currently snapshot variable is not used by \fBcSvn-ui\fR CGI Script.
+.RE
+
+.TP 4
+\fBcss\fR
+.RS 4
+The full name of the CSS style sheet relative to the directory where \fBcSvn-ui\fR CGI Sctipt is installed.
+Example declaration:
+.RE
+.PP
+.in +6n
+.EX
+\fIcss = '/.csvn/css/csvn.css';\fR
+.EE
+.in
+
+.TP 4
+\fBlogo\fR
+Url which specifies the source of an image which will be used as a logo (i.e right banner) on \fBcSvn-ui\fR pages.
+Default value: \fI'/.csvn/pixmaps/csvn-banner-280x280.png'\fR. The path to the \fBlogo\fR also should be set
+relative to the directory where \fBcSvn-ui\fR CGI Script is installed. Example declaration:
+.PP
+.in +6n
+.EX
+\fIlogo = '/.csvn/pixmaps/csvn-banner-280x280.png';\fR
+.EE
+.in
+
+.TP 4
+\fBlogo-alt\fR
+The string used in HTML as a 'alt' property of the right banner <img> tag. Default value: \fI"Example.org"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIlogo-alt = "Example.org";\fR
+.EE
+.in
+
+.TP 4
+\fBlogo-link\fR
+The string used in HTML as a 'href' property of the right banner image link <a> tag. Default value: \fI"https://example.org"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIlogo-link = "https://example.org";\fR
+.EE
+.in
+
+.TP 4
+\fBmain-menu-logo\fR
+Url which specifies the source of an image which will be used as a logo of the main menu item on \fBcSvn-ui\fR pages.
+Default value: \fI'/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg'\fR. The path to the \fBmain-menu-logo\fR also should be set
+relative to the directory where \fBcSvn-ui\fR CGI Script is installed. Example declaration:
+.PP
+.in +6n
+.EX
+\fImain-menu-logo = '/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg';\fR
+.EE
+.in
+
+.TP 4
+\fBfavicon-path\fR
+The directory name of the 'favicon.ico' file without leadind dir-separator.
+Default value: \fI'/.csvn/pixmaps/favicon'\fR. Example declaration:
+.PP
+.in +6n
+.EX
+\fIfavicon-path = '/.csvn/pixmaps/favicon';\fR
+.EE
+.in
+
+.RS 4
+This directory name used for finding additional images declared in the HTML \fBheader\fR of all \fBcSvn-ui\fR pages.
+.RE
+
+.TP 4
+\fBsyntax-highlight-css\fR
+The base name of the CSS style sheet file used for syntax highlighting.
+Default value: \fI'_csvn.css'\fR. Example declaration:
+.PP
+.in +6n
+.EX
+\fIsyntax-highlight-css = '_csvn.css';\fR
+.EE
+.in
+
+.RS 4
+\fBcSvn-ui\fR CGI Script uses highlight.js
+.UR https://\:highlightjs.org\:/
+.UE
+installed into \fI'/.csvn/.engines/highlight/${hljs-version}/{css,js}'\fR directories
+where the default \fI'_csvn.css'\fR file is palced too.
+.RE
+
+.TP 4
+\fBheader\fR
+The content of the file specified with this option will be included verbatim at the top of all pages.
+Default value: \fI'/.csvn/html/header.html'\fR.
+.TP 4
+\fBfooter\fR
+The content of the file specified with this option will be included verbatim at the bottom of all pages.
+Default value: \fI'/.csvn/html/footer.html'\fR. Examle of the \fBheader\fR and the \fBfooter\fR declarations:
+.PP
+.in +6n
+.EX
+\fIheader = '/.csvn/html/header.html';\fR
+\fIfooter = '/.csvn/html/footer.html';\fR
+.EE
+.in
+
+.RS 4
+The \fBheader\fR and the \fBfooter\fR files used as template where \fBcSvn-ui\fR CGI Script substitute placeholders
+such as \fI${variable-name}\fR by their values. For example the ${css} placeholder will be replaced by the value
+of \fIcss\fR variable declared in the \fB/etc/csvn-ui.rc\fR config file.
+.RE
+
+.TP 4
+\fBpage-size\fR
+The \fBstring\fR or \fBint\fR variable which set the length of the repositories list or logs shown in one page by the \fBcSvn-ui\fR CGI Script.
+Default value: 200. Example declaration:
+.PP
+.in +6n
+.EX
+\fIpage-size = 50; /* 10 ... 200 may be string or integer. Default value is page-size = 200 */\fR
+.EE
+.in
+
+.TP 4
+\fBowner\fR
+The \fBstring\fR variable used in the HTML header of all \fBcSvn-ui\fR pages and also in the \fIOwner\fR colon of the repository list.
+Default value: \fI"Andrey V.Kosteltsev"\fR.
+.TP 4
+\fBauthor\fR
+The \fBstring\fR variable used in the HTML header of all \fBcSvn-ui\fR pages. Default value: \fI"Andrey V.Kosteltsev"\fR.
+Example declarations of the \fBowner\fR and the \fBauthor\fR variables:
+.PP
+.in +6n
+.EX
+\fIowner  = "John Smith";\fR
+\fIauthor = "John Smith";\fR
+.EE
+.in
+
+.TP 4
+\fBtitle\fR
+The \fBstring\fR variable used in the HTML header of all \fBcSvn-ui\fR pages as a page title. Default value: \fI"SVN Repositories"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fItitle  = "Example.org SVN Repositories";\fR
+.EE
+.in
+
+.TP 4
+\fBdescription\fR
+The \fBstring\fR variable used in the HTML header of all \fBcSvn-ui\fR pages as a page description.
+Default value: \fI"Subversion repositories hosted at Solar System, Earth"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdescription  = "Subversion repositories hosted at example.org (St.-Petersburg)";\fR
+.EE
+.in
+
+.RS 4
+For a long description the value of this \fBstring\fR variable can be splitted in the C-style by following way:
+.RE
+.PP
+.in +6n
+.EX
+\fIdescription  = "Subversion repositories"\fR
+\fI               " hosted at example.org "\fR
+\fI               "(St.-Petersburg)";\fR
+.EE
+.in
+
+.TP 4
+\fBkeywords\fR
+The \fBstring\fR variable contains space separated keywords used in the HTML header of all \fBcSvn-ui\fR pages as a page keywords.
+Default value: \fI"cSvn repositories"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIkeywords = "cSvn UI CGI Subversion Repositories scm SVN";\fR
+.EE
+.in
+
+.TP 4
+\fBcopyright-notice\fR
+The \fBstring\fR variable used in the HTML footer of all \fBcSvn-ui\fR pages as a Copyright Notice.
+Default value: \fI"By using any website materials you agree to indicate source."\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIcopyright-notice = "By using any materials you agree with ...";\fR
+.EE
+.in
+
+.TP 4
+\fBcopyright\fR
+The \fBstring\fR variable used in the HTML footer of all \fBcSvn-ui\fR pages as a Copyright.
+Default value: \fI"&#169; 2020 Andrey V.Kosteltsev. All Rights Reserved."\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIcopyright = "&#169; John Smith (explorer), 1580 - 1631.";\fR
+.EE
+.in
+
+.TP 4
+\fBhome-page\fR
+The URL of the home page of the project.
+Default value: \fI"https://example.org"\fR.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIhome-page = "https://main-site-of-the-project.org";\fR
+.EE
+.in
+
+Analytics variables:
+
+.TP 4
+\fBanalytic-links\fR
+The path to the file which contains meta tags with site ownership verificaton codes for engines such as \fIGoogle Search Console\fR or
+\fIYandex Webmaster\fR. \fBcSvn-ui\fR CGI Script reads the file \fBanalytic-links\fR in RAW format and includes it into <HEAD> tag of each HTML page.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIanalytic-links = '/analytics/links';\fR
+.EE
+.in
+
+.RS 4
+Where the file \fI/analytics/links\fR may contains HTML tags like follow:
+.RE
+
+.PP
+.in +6n
+.EX
+\fI<meta name="google-site-verification" content="..." />\fR
+.EE
+.in
+
+.RS 4
+The file name should be defined relative of the path where \fBcSvn-ui\fR CGI Script is installed. For example, if \fBcSvn-ui\fR CGI Script installed
+into \fI/srv/www/htdocs/csvn\fR directory and file name declared as \fI/analytics/links\fR then \fBcSvn-ui\fR CGI Script will try to read the
+file \fI/srv/www/htdocs/csvn/analytics/links\fR.
+.RE
+
+.TP 4
+\fBanalytic-scripts\fR
+The path to the file which contains JavaScripts for engines such as \fIGoogle Search Console\fR or
+\fIYandex Webmaster\fR. \fBcSvn-ui\fR CGI Script reads the file \fBanalytic-scripts\fR in RAW format and includes it at the end of <HEAD> tag before </HEAD>
+entry of each HTML page.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIanalytic-scripts = '/analytics/scripts';\fR
+.EE
+.in
+
+.RS 4
+Where the file \fI/analytics/scripts\fR may contains code like follow:
+.RE
+
+.PP
+.in +6n
+.EX
+\fI
+<!-- Global site tag (gtag.js) - Google Analytics -->
+<script async src="https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX"></script>
+<script>
+  window.dataLayer = window.dataLayer || [];
+  function gtag(){dataLayer.push(arguments);}
+  gtag('js', new Date());
+
+  gtag('config', 'G-XXXXXXXXXX');
+</script>
+\fR
+.EE
+.in
+
+.RS 4
+Please note that the \fI<script>\fR tags should be present in the \fI/analytics/scripts\fR because \fBcSvn-ui\fR CGI Script reads this file
+in RAW format and includes it as is.
+.RE
+
+.RS 4
+The variables \fBanalytic-links\fR and \fBanalytic-scripts\fR should be declared on the global level of the \fB/etc/csvn-ui.rc\fR
+configuration file and cannot be overriden in a repository declaration.
+.RE
+
+Donation variables:
+
+.RS 4
+The \fBcSvn-ui\fR CGI Script provides the ability to create a custom donation dialogue. To do this, you need to create a set of three files:
+CSS, HTML, and JavaScript file for automation. You can add a donation dialogue for each repository separately, as well as for the
+entire list of repositories. To enable donation dialogue you have to set the value of \fBdonate\fR variable to \fBdonate = 1\fR:
+.RE
+
+.TP 4
+\fBdonate\fR
+The integer variable used to enable or disable donation dialogue.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate = 1;\fR
+.EE
+.in
+
+.TP 4
+\fBdonate-css\fR
+The name of file contains the stylesheet for donation modal dialogue.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate-css = '/donations/donate.css';\fR
+.EE
+.in
+
+.TP 4
+\fBdonate-html\fR
+The name of file contains the HTML code of donation modal dialogue.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate-html = '/donations/donate.html';\fR
+.EE
+.in
+
+.TP 4
+\fBdonate-js\fR
+The name of file contains the javascript code for donation modal dialogue automation.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate-js = '/donations/donate.js';\fR
+.EE
+.in
+
+.RS 4
+\fBcSvn-ui\fR CGI Script includes these files at end of <BODY> tag just before the closing </BODY> tag. Unlike the others,
+the \fBdonate-html\fR file should be no more than 8192 bytes in size due to the fact that this file is a template
+and the values of the following two variables are substituted into its body using placeholders \fI${donate-header}\fR
+and \fI${donate-purpose}\fR:
+.RE
+
+.TP 4
+\fBdonate-header\fR
+The title of the donation modal dialogue defined in the \fBdonate-html\fR file.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate-header = "Donations";\fR
+.EE
+.in
+
+.TP 4
+\fBdonate-purpose\fR
+The donation purpose used as value of <input value="..."> tag property in payment form of systems such as \fIPayPal\fR or \fIYandex.Money\fR.
+Also this value can be used as a header of modal dialogue content.
+Example declaration:
+.PP
+.in +6n
+.EX
+\fIdonate-purpose = "Support for our projects";\fR
+.EE
+.in
+
+.RS 4
+Donation dialogue can be defined for each repository separately or defined on global level. In the last case
+the dialogue header and payment purpose may be overriden in the body of a repository declaration like follow:
+.RE
+
+.PP
+.in +6n
+.EX
+\fI
+true  = 1;
+false = 0;
+
+donate         = true;
+donate-css     = '/donations/donate.css';
+donate-html    = '/donations/donate.html';
+donate-js      = '/donations/donate.js';
+donate-header  = "Donation";
+donate-purpose = "Support our activities";
+
+section "Tools" {
+  repo 'repo-path' {
+    . . .
+    donate-header  = "Project Donation";
+    donate-purpose = "Support our Project";
+    . . .
+  }
+}
+\fR
+.EE
+.in
+
+.RS 4
+To show the modal dialogue in javascript code \fBdonate-js\fR the selector 'a.donate' should be used. For examle, like this:
+.RE
+
+.PP
+.in +6n
+.EX
+\fI
+var show = document.querySelector( "a.donate" );
+
+/**************
+  Open Dialog:
+ */
+show.onclick = function() {
+  dialog.style.display = "block";
+}
+\fR
+.EE
+.in
+
+.RS 4
+Where the variable \fIdialog\fR points to modal dialogue defined in the \fBdonate-html\fR file.
+.RE
+
+
+.SH "REPOSITORY DECLARATIONS"
+The \fB/etc/csvn-ui.rc\fR config file should contains at least one repository declaration to be shown by the \fBcSvn-ui\fR CGI Script.
+When all expected variables declared in the global section the config file the repository declaration can be very simple:
+.PP
+.in +4n
+.EX
+\fI
+repo 'tools' {
+  owner = "John Smith";
+  description = "John Smith's tools source code repository.";
+}
+\fR
+.EE
+.in
+
+The list of repositories can be splitted in several sections. The section has a name and can contains repository declarations only.
+.PP
+.in +4n
+.EX
+\fI
+section "John Smith sources" {
+  repo 'tools' {
+    owner = "John Smith";
+    description = "John Smith's tools source code repository.";
+  }
+  repo 'examples' {
+    owner = "John Smith";
+    description = "John Smith's examples source code.";
+  }
+}
+\fR
+.EE
+.in
+
+Global variables are propagate into repo sections but their values overrides by correspond repo variables.
+
+
+.SH "SEE ALSO"
+.BR cscmd (8)
+
Index: csvn-ui-0.1.5/csvncgi/ctx.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ctx.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ctx.c	(revision 12)
@@ -0,0 +1,1656 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3)   */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)      */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)     */
+#include <strings.h>  /* strcasecmp(3) */
+#include <libgen.h>   /* basename(3)   */
+#include <ctype.h>    /* tolower(3)    */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+
+#include <ui-shared.h>
+
+
+/* Allocate memory in .bss segment: */
+static struct __context mctx;
+
+/* Share address of __context: */
+struct __context *pmctx = &mctx;
+
+void __mctx_init( void )
+{
+  pmctx->_cur_brk = (void *)&((pmctx->_mem)[0]);
+}
+
+static int
+__brk( void *end_d )
+{
+  void *ptr = __mem;
+
+  if( (unsigned char *)end_d < (unsigned char *)ptr ||
+      (unsigned char *)end_d > (unsigned char *)ptr + CONTEXT_MEM_SIZE )
+  {
+    errno = ENOMEM;
+    return( -1 );
+  }
+
+ /*
+   __cur_brk = (unsigned char *)end_d;
+
+   Функция  __brk()  лишь проверяет границы
+   области памяти, значение __cur_brk выставляется
+   в __sbrk() .
+  *************************************************/
+
+  return( 0 );
+
+} /* End of __brk() */
+
+void *
+__sbrk( int incr )
+{
+  void         *ptr = __cur_brk;
+  register int  rc;
+
+  if( incr == 0 ) return( ptr );
+
+  rc = __brk( ptr + incr );
+  if( rc == -1 )
+  {
+    /* errno is set into __brk() */
+    return( (void *)0 );
+  }
+
+  __cur_brk = ((unsigned char *)ptr) + (int)incr;
+
+  return( ptr );
+
+} /* End of __sbrk() */
+
+
+struct csvn_context ctx;
+
+const char *ptype_repolist   = "repolist";
+const char *ptype_repo       = "repo";
+
+void csvn_prepare_context( void )
+{
+  memset( &ctx, 0, sizeof(ctx) );
+
+  ctx.env.http_host = getenv("HTTP_HOST");
+  ctx.env.https = getenv("HTTPS");
+  ctx.env.no_http = getenv("NO_HTTP");
+  ctx.env.path_info = getenv("PATH_INFO");
+  ctx.env.query_string = getenv("QUERY_STRING");
+  ctx.env.request_uri = getenv("REQUEST_URI");
+
+  if( ctx.env.request_uri == NULL )
+    ctx.env.request_uri = "/";
+
+  ctx.env.request_scheme = getenv("REQUEST_SCHEME");
+  ctx.env.request_method = getenv("REQUEST_METHOD");
+  ctx.env.script_name = getenv("SCRIPT_NAME");
+  ctx.env.server_name = getenv("SERVER_NAME");
+  ctx.env.server_port = getenv("SERVER_PORT");
+  ctx.env.http_cookie = getenv("HTTP_COOKIE");
+  ctx.env.content_lenght = getenv("CONTENT_LENGTH") ? strtoul(getenv("CONTENT_LENGTH"), NULL, 10) : 0;
+  ctx.env.http_root = NULL;
+  ctx.env.authenticated = 0;
+
+  ctx.query.ofs = 0;
+  ctx.query.rev = 0;
+  ctx.query.revision = NULL;
+  ctx.query.operation = NULL;
+  ctx.query.search = NULL;
+
+  ctx.page.mimetype = "text/html";
+  ctx.page.charset = "UTF-8";
+  ctx.page.size = 0;
+  ctx.page.modified = time(NULL);
+  ctx.page.expires = ctx.page.modified + 5 * 60;
+  ctx.page.status = 200;
+  ctx.page.status_message = "OK";
+  ctx.page.header = "/.csvn/html/header.html";
+  ctx.page.footer = "/.csvn/html/footer.html";
+
+  ctx.vars.css = "/.csvn/css/csvn.css";
+  ctx.vars.owner = "Andrey V.Kosteltsev";
+  ctx.vars.author = "Andrey V.Kosteltsev";
+  ctx.vars.description = "Subversion repositories hosted at Solar System, Earth";
+  ctx.vars.keywords = "cSvn repositories";
+  ctx.vars.title = "SVN Repositories";
+  ctx.vars.favicon_path = "/.csvn/pixmaps/favicon";
+  ctx.vars.syntax_highlight_css = "_csvn.css";
+  ctx.vars.logo = "/.csvn/pixmaps/csvn-banner-280x280.png";
+  ctx.vars.logo_alt = "Example.org";
+  ctx.vars.logo_link = "https://example.org";
+  ctx.vars.home_page = "https://example.org";
+  ctx.vars.snapshots = "tar.xz";
+  ctx.vars.status_line = "Subversion Repositories";
+  ctx.vars.main_menu_logo = "/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg";
+  ctx.vars.main_menu_item = "<a href='/'>Index</a>";
+  ctx.vars.left_menu_items = "";
+  ctx.vars.popup_menu_items = "<div class='item'><span class='icon las la-home'></span><a href='https://example.org/' target='_blank'>Home page</a></div>";
+  ctx.vars.right_menu_items = "<div class='item'><a href='https://example.org/' target='_blank'>Home page</a></div>";
+  ctx.vars.copyright_notice = "By using any website materials you agree to indicate source.";
+  ctx.vars.copyright = "&#169; 2020 Andrey V.Kosteltsev. All Rights Reserved.";
+  ctx.vars.page_type = ptype_repolist;
+  ctx.vars.page_size = "200";
+  ctx.vars.num_of_repos = "0";
+
+  ctx.repo.name = NULL;
+  ctx.repo.info = CSVN_INFO_INIT;
+  ctx.repo.repo_root = NULL;
+  ctx.repo.relative_path = NULL;
+  ctx.repo.relative_info = CSVN_INFO_INIT;
+  ctx.repo.relative_html = NULL;
+  ctx.repo.relative_href = "/";
+  ctx.repo.search_placeholder = "repository...";
+  ctx.repo.trunk = "trunk";
+  ctx.repo.branches = "branches";
+  ctx.repo.tags = "tags";
+  ctx.repo.checkout_prefix = NULL;
+  ctx.repo.checkout_ro_prefix = NULL;
+  ctx.repo.nbranches = 0;
+  ctx.repo.ntags = 0;
+
+  ctx.promo.analytic_links   = NULL;
+  ctx.promo.analytic_scripts = NULL;
+  ctx.promo.donate           = 0;
+  ctx.promo.donate_css       = NULL;
+  ctx.promo.donate_html      = NULL;
+  ctx.promo.donate_js        = NULL;
+  ctx.promo.donate_header    = NULL;
+  ctx.promo.donate_purpose   = NULL;
+
+  ctx.vers.subversion = NULL;
+  ctx.vers.nginx = NULL;
+  ctx.vers.csvn = PROGRAM_VERSION;
+}
+
+void csvn_prepare_template_variables( void )
+{
+  envtab_install( &strbuf_envtab, "css", ctx.vars.css, fatal_html );
+  envtab_install( &strbuf_envtab, "owner", ctx.vars.owner, fatal_html );
+  envtab_install( &strbuf_envtab, "author", ctx.vars.author, fatal_html );
+  envtab_install( &strbuf_envtab, "description", ctx.vars.description, fatal_html );
+  envtab_install( &strbuf_envtab, "keywords", ctx.vars.keywords, fatal_html );
+  envtab_install( &strbuf_envtab, "title", ctx.vars.title, fatal_html );
+  envtab_install( &strbuf_envtab, "favicon-path", ctx.vars.favicon_path, fatal_html );
+  envtab_install( &strbuf_envtab, "syntax-highlight-css", ctx.vars.syntax_highlight_css, fatal_html );
+  envtab_install( &strbuf_envtab, "logo", ctx.vars.logo, fatal_html );
+  envtab_install( &strbuf_envtab, "logo-alt", ctx.vars.logo_alt, fatal_html );
+  envtab_install( &strbuf_envtab, "logo-link", ctx.vars.logo_link, fatal_html );
+  envtab_install( &strbuf_envtab, "home-page", ctx.vars.home_page, fatal_html );
+  envtab_install( &strbuf_envtab, "snapshots", ctx.vars.snapshots, fatal_html );
+  envtab_install( &strbuf_envtab, "status-line", ctx.vars.status_line, fatal_html );
+  envtab_install( &strbuf_envtab, "main-menu-logo", ctx.vars.main_menu_logo, fatal_html );
+  envtab_install( &strbuf_envtab, "main-menu-item", ctx.vars.main_menu_item, fatal_html );
+  envtab_install( &strbuf_envtab, "left-menu-items", ctx.vars.left_menu_items, fatal_html );
+  envtab_install( &strbuf_envtab, "popup-menu-items", ctx.vars.popup_menu_items, fatal_html );
+  envtab_install( &strbuf_envtab, "right-menu-items", ctx.vars.right_menu_items, fatal_html );
+
+  envtab_install( &strbuf_envtab, "relative-html", ctx.repo.relative_html, fatal_html );
+  envtab_install( &strbuf_envtab, "search-placeholder", ctx.repo.search_placeholder, fatal_html );
+
+  envtab_install( &strbuf_envtab, "analytic-links", ctx.promo.analytic_links, fatal_html );
+  envtab_install( &strbuf_envtab, "analytic-scripts", ctx.promo.analytic_scripts, fatal_html );
+  envtab_install( &strbuf_envtab, "donate-css", ctx.promo.donate_css, fatal_html );
+  envtab_install( &strbuf_envtab, "donate-html", ctx.promo.donate_html, fatal_html );
+  envtab_install( &strbuf_envtab, "donate-js", ctx.promo.donate_js, fatal_html );
+  envtab_install( &strbuf_envtab, "donate-header", ctx.promo.donate_header, fatal_html );
+  envtab_install( &strbuf_envtab, "donate-purpose", ctx.promo.donate_purpose, fatal_html );
+
+  envtab_install( &strbuf_envtab, "svn-version", ctx.vers.subversion, fatal_html );
+  envtab_install( &strbuf_envtab, "nginx-version", ctx.vers.nginx, fatal_html );
+  envtab_install( &strbuf_envtab, "csvn-version", ctx.vers.csvn, fatal_html );
+
+  envtab_install( &strbuf_envtab, "copyright-notice", ctx.vars.copyright_notice, fatal_html );
+  envtab_install( &strbuf_envtab, "copyright", ctx.vars.copyright, fatal_html );
+
+  envtab_install( &strbuf_envtab, "page-type", ctx.vars.page_type, fatal_html );
+  envtab_install( &strbuf_envtab, "page-size", ctx.vars.page_size, fatal_html );
+  envtab_install( &strbuf_envtab, "num-of-repos", ctx.vars.num_of_repos, fatal_html );
+}
+
+void csvn_release_template_variables( void )
+{
+  envtab_release( &strbuf_envtab );
+}
+
+static void get_selfdir( void )
+{
+  char    path[PATH_MAX];
+  ssize_t len;
+
+  bzero( (void *)path, PATH_MAX );
+
+  len = readlink( "/proc/self/exe", &path[0], (size_t)PATH_MAX );
+  if( len > 0 && len < PATH_MAX )
+  {
+    char *selfdir = NULL;
+
+    selfdir = (char *)__sbrk( (int)len + 1 );
+    strcpy( selfdir, (const char *)dirname( (char *)&path[0] ) );
+    ctx.env.http_root = selfdir;
+  }
+  else
+    fatal_html( "cannot get selfdir" );
+}
+
+static size_t read_http_root_raw_file( struct strbuf *sb, const char *fname )
+{
+  char    path[PATH_MAX];
+  int     fd = -1;
+  size_t  len = 0;
+
+  if( !sb || !fname || !*fname ) return len;
+
+  bzero( (void *)path, PATH_MAX );
+  strcpy( (char *)&path[0], ctx.env.http_root );
+  if( *fname != '/' )
+    strcat( (char *)&path[0], "/" );
+
+  strcat( (char *)&path[0], fname );
+
+  if( (fd = open( (const char *)&path[0], O_RDONLY )) == -1 )
+   fatal_html( "Cannot open %s file: %s", fname, strerror( errno ) );
+
+  len = strbuf_read( sb, fd, 0 );
+  close( fd );
+
+  return len;
+}
+
+static size_t read_http_root_env_file( struct strbuf *sb, const char *fname )
+{
+  char    path[PATH_MAX];
+  FILE   *fp = NULL;
+  size_t  len = 0;
+
+  if( !sb || !fname || !*fname ) return len;
+
+  bzero( (void *)path, PATH_MAX );
+  strcpy( (char *)&path[0], ctx.env.http_root );
+  if( *fname != '/' )
+    strcat( (char *)&path[0], "/" );
+
+  strcat( (char *)&path[0], fname );
+
+  if( (fp = fopen( (const char *)&path[0], "r" )) == NULL )
+   fatal_html( "Cannot open %s file: %s", fname, strerror( errno ) );
+
+  len = strbuf_env_fread( sb, fp );
+  fclose( fp );
+
+  if( len > STRBUF_MAXLINE )
+    fatal_html( "The '%s' file is too large. No more than 8192 bytes is allowed for includes", fname );
+
+  return len;
+}
+
+static void read_donate_html( void )
+{
+  struct strbuf buf = STRBUF_INIT;
+  char  *html = NULL;
+
+  if( !ctx.promo.donate ) return;
+  if( !ctx.promo.donate_html || !*ctx.promo.donate_html ) return;
+
+  (void)read_http_root_env_file( &buf, ctx.promo.donate_html );
+
+  html = (char *)__sbrk( (int)buf.len + 1 );
+  memcpy( (void *)html, (const void *)buf.buf, buf.len + 1 );
+  ctx.promo.donate_html = (const char *)html;
+  strbuf_release( &buf );
+}
+
+
+static char psize[4] = { 0, 0, 0, 0 };
+
+static void ctx_page_size_from_global( void )
+{
+  struct variable f = { (unsigned char *)"page-size", { 0 }, DT_NUMERICAL }, *var = NULL;
+  var = lookup_global( lookup_global_section( config ), &f );
+  if( var )
+  {
+    if( var->type == DT_NUMERICAL )
+    {
+      if( var->_v.val > 9 && var->_v.val < 201 )
+        snprintf( &psize[0], 4, "%d", var->_v.val );
+      else
+        snprintf( &psize[0], 4, "%d", 200 );
+      ctx.vars.page_size = &psize[0];
+    }
+    else
+    {
+      int size = 0;
+      sscanf( (const char *)var->_v.vptr, "%d", &size );
+      if( size > 9 && size < 201 )
+        ctx.vars.page_size = (const char *)var->_v.vptr;
+      else
+      {
+        snprintf( &psize[0], 4, "%d", 200 );
+        ctx.vars.page_size = &psize[0];
+      }
+    }
+  }
+}
+
+static void ctx_page_size_from_repo( struct repo *repo )
+{
+  struct variable f = { (unsigned char *)"page-size", { 0 }, DT_NUMERICAL }, *var = NULL;
+  var = lookup( repo, &f );
+  if( var )
+  {
+    if( var->type == DT_NUMERICAL )
+    {
+      if( var->_v.val > 9 && var->_v.val < 201 )
+        snprintf( &psize[0], 4, "%d", var->_v.val );
+      else
+        snprintf( &psize[0], 4, "%d", 200 );
+      ctx.vars.page_size = &psize[0];
+    }
+    else
+    {
+      int size = 0;
+      sscanf( (const char *)var->_v.vptr, "%d", &size );
+      if( size > 9 && size < 201 )
+        ctx.vars.page_size = (const char *)var->_v.vptr;
+      else
+      {
+        snprintf( &psize[0], 4, "%d", 200 );
+        ctx.vars.page_size = &psize[0];
+      }
+    }
+  }
+}
+
+static void ctx_repo_dirs_from_global( void )
+{
+  struct variable  repo_root = { (unsigned char *)"repo-root", { 0 }, DT_PATH };
+  struct variable  trunk     = { (unsigned char *)"trunk",     { 0 }, DT_PATH };
+  struct variable  branches  = { (unsigned char *)"branches",  { 0 }, DT_PATH };
+  struct variable  tags      = { (unsigned char *)"tags",      { 0 }, DT_PATH };
+  struct variable  ro_prefix = { (unsigned char *)"checkout-prefix-readonly", { 0 }, DT_PATH };
+  struct variable  rw_prefix = { (unsigned char *)"checkout-prefix",          { 0 }, DT_PATH };
+  struct variable *var = NULL;
+
+  var = lookup_global( lookup_global_section( config ), &repo_root );
+  if( var )
+  {
+    ctx.repo.repo_root = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &trunk );
+  if( var )
+  {
+    ctx.repo.trunk = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &branches );
+  if( var )
+  {
+    ctx.repo.branches = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &tags );
+  if( var )
+  {
+    ctx.repo.tags = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &rw_prefix );
+  if( var )
+  {
+    ctx.repo.checkout_prefix = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &ro_prefix );
+  if( var )
+  {
+    ctx.repo.checkout_ro_prefix = (const char *)var->_v.vptr;
+  }
+}
+
+static void ctx_site_vars_from_global( void )
+{
+  struct variable                   css = { (unsigned char *)"css",                  { 0 }, DT_PATH };
+  struct variable                 owner = { (unsigned char *)"owner",                { 0 }, DT_STRING };
+  struct variable                author = { (unsigned char *)"author",               { 0 }, DT_STRING };
+  struct variable                 title = { (unsigned char *)"title",                { 0 }, DT_STRING };
+  struct variable           description = { (unsigned char *)"description",          { 0 }, DT_STRING };
+  struct variable              keywords = { (unsigned char *)"keywords",             { 0 }, DT_STRING };
+  struct variable      copyright_notice = { (unsigned char *)"copyright-notice",     { 0 }, DT_STRING };
+  struct variable             copyright = { (unsigned char *)"copyright",            { 0 }, DT_STRING };
+  struct variable          favicon_path = { (unsigned char *)"favicon-path",         { 0 }, DT_PATH   };
+  struct variable                  logo = { (unsigned char *)"logo",                 { 0 }, DT_PATH   };
+  struct variable              logo_alt = { (unsigned char *)"logo-alt",             { 0 }, DT_STRING };
+  struct variable             logo_link = { (unsigned char *)"logo-link",            { 0 }, DT_STRING };
+  struct variable             home_page = { (unsigned char *)"home-page",            { 0 }, DT_STRING };
+  struct variable             snapshots = { (unsigned char *)"snapshots",            { 0 }, DT_PATH   };
+  struct variable        main_menu_logo = { (unsigned char *)"main-menu-logo",       { 0 }, DT_PATH   };
+  struct variable  syntax_highlight_css = { (unsigned char *)"syntax-highlight-css", { 0 }, DT_PATH   };
+  struct variable *var = NULL;
+
+  var = lookup_global( lookup_global_section( config ), &css );
+  if( var )
+  {
+    ctx.vars.css = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &owner );
+  if( var )
+  {
+    ctx.vars.owner = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &author );
+  if( var )
+  {
+    ctx.vars.author = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &title );
+  if( var )
+  {
+    ctx.vars.title = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &description );
+  if( var )
+  {
+    ctx.vars.description = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &keywords );
+  if( var )
+  {
+    ctx.vars.keywords = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &copyright_notice );
+  if( var )
+  {
+    ctx.vars.copyright_notice = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &copyright );
+  if( var )
+  {
+    ctx.vars.copyright = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &favicon_path );
+  if( var )
+  {
+    ctx.vars.favicon_path = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &logo );
+  if( var )
+  {
+    ctx.vars.logo = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &logo_alt );
+  if( var )
+  {
+    ctx.vars.logo_alt = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &logo_link );
+  if( var )
+  {
+    ctx.vars.logo_link = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &home_page );
+  if( var )
+  {
+    ctx.vars.home_page = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &snapshots );
+  if( var )
+  {
+    ctx.vars.snapshots = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &main_menu_logo );
+  if( var )
+  {
+    ctx.vars.main_menu_logo = (const char *)var->_v.vptr;
+  }
+  var = lookup_global( lookup_global_section( config ), &syntax_highlight_css );
+  if( var )
+  {
+    ctx.vars.syntax_highlight_css = (const char *)var->_v.vptr;
+  }
+}
+
+static void ctx_promo_vars_from_global( void )
+{
+  struct variable  analytic_links   = { (unsigned char *)"analytic-links",   { 0 }, DT_PATH      };
+  struct variable  analytic_scripts = { (unsigned char *)"analytic-scripts", { 0 }, DT_PATH      };
+  struct variable  donate           = { (unsigned char *)"donate",           { 0 }, DT_NUMERICAL };
+  struct variable  donate_css       = { (unsigned char *)"donate-css",       { 0 }, DT_PATH      };
+  struct variable  donate_html      = { (unsigned char *)"donate-html",      { 0 }, DT_PATH      };
+  struct variable  donate_js        = { (unsigned char *)"donate-js",        { 0 }, DT_PATH      };
+  struct variable  donate_header    = { (unsigned char *)"donate-header",    { 0 }, DT_STRING    };
+  struct variable  donate_purpose   = { (unsigned char *)"donate-purpose",   { 0 }, DT_STRING    };
+  struct variable *var = NULL;
+
+  var = lookup_global( lookup_global_section( config ), &analytic_links );
+  if( var )
+  {
+    ctx.promo.analytic_links = (const char *)var->_v.vptr;
+
+    if( ctx.promo.analytic_links && *ctx.promo.analytic_links )
+    {
+      struct strbuf buf = STRBUF_INIT;
+      char  *links = NULL;
+
+      (void)read_http_root_raw_file( &buf, ctx.promo.analytic_links );
+
+      links = (char *)__sbrk( (int)buf.len + 1 );
+      memcpy( (void *)links, (const void *)buf.buf, buf.len + 1 );
+      ctx.promo.analytic_links = (const char *)links;
+      strbuf_release( &buf );
+    }
+  }
+  var = lookup_global( lookup_global_section( config ), &analytic_scripts );
+  if( var )
+  {
+    ctx.promo.analytic_scripts = (const char *)var->_v.vptr;
+
+    if( ctx.promo.analytic_scripts && *ctx.promo.analytic_scripts )
+    {
+      struct strbuf buf = STRBUF_INIT;
+      char  *scripts = NULL;
+
+      (void)read_http_root_raw_file( &buf, ctx.promo.analytic_scripts );
+
+      scripts = (char *)__sbrk( (int)buf.len + 1 );
+      memcpy( (void *)scripts, (const void *)buf.buf, buf.len + 1 );
+      ctx.promo.analytic_scripts = (const char *)scripts;
+      strbuf_release( &buf );
+    }
+  }
+
+  var = lookup_global( lookup_global_section( config ), &donate );
+  if( var )
+  {
+    if( var->type == DT_NUMERICAL )
+    {
+      ctx.promo.donate = var->_v.val;
+      if( ctx.promo.donate )
+        ctx.promo.donate = 1;
+    }
+  }
+
+  if( ctx.promo.donate )
+  {
+    var = lookup_global( lookup_global_section( config ), &donate_css );
+    if( var )
+    {
+      ctx.promo.donate_css = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_css && *ctx.promo.donate_css )
+      {
+        struct strbuf buf = STRBUF_INIT;
+        char  *css = NULL;
+
+        strbuf_addf( &buf, "<link rel=\"stylesheet\" href=\"%s\">", ctx.promo.donate_css );
+        strbuf_trim( &buf );
+        css = (char *)__sbrk( (int)buf.len + 1 );
+        memcpy( (void *)css, (const void *)buf.buf, buf.len + 1 );
+        ctx.promo.donate_css = (const char *)css;
+        strbuf_release( &buf );
+      }
+    }
+    var = lookup_global( lookup_global_section( config ), &donate_js );
+    if( var )
+    {
+      ctx.promo.donate_js = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_js && *ctx.promo.donate_js )
+      {
+        struct strbuf buf = STRBUF_INIT;
+        char  *js = NULL;
+
+        strbuf_addf( &buf, "<script src=\"%s\"></script>", ctx.promo.donate_js );
+        strbuf_trim( &buf );
+        js = (char *)__sbrk( (int)buf.len + 1 );
+        memcpy( (void *)js, (const void *)buf.buf, buf.len + 1 );
+        ctx.promo.donate_js = (const char *)js;
+        strbuf_release( &buf );
+      }
+    }
+    var = lookup_global( lookup_global_section( config ), &donate_header );
+    if( var )
+    {
+      ctx.promo.donate_header = (const char *)var->_v.vptr;
+    }
+    var = lookup_global( lookup_global_section( config ), &donate_purpose );
+    if( var )
+    {
+      ctx.promo.donate_purpose = (const char *)var->_v.vptr;
+    }
+
+    var = lookup_global( lookup_global_section( config ), &donate_html );
+    if( var )
+    {
+      ctx.promo.donate_html = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_html && *ctx.promo.donate_html )
+      {
+        envtab_install( &strbuf_envtab, "donate-header", ctx.promo.donate_header, fatal_html );
+        envtab_install( &strbuf_envtab, "donate-purpose", ctx.promo.donate_purpose, fatal_html );
+        read_donate_html();
+        envtab_release( &strbuf_envtab );
+      }
+    }
+  }
+}
+
+static void ctx_repo_dirs_from_repo( struct repo *repo )
+{
+  struct variable  repo_root = { (unsigned char *)"repo-root", { 0 }, DT_PATH };
+  struct variable  trunk     = { (unsigned char *)"trunk",     { 0 }, DT_PATH };
+  struct variable  branches  = { (unsigned char *)"branches",  { 0 }, DT_PATH };
+  struct variable  tags      = { (unsigned char *)"tags",      { 0 }, DT_PATH };
+  struct variable  ro_prefix = { (unsigned char *)"checkout-prefix-readonly", { 0 }, DT_PATH };
+  struct variable  rw_prefix = { (unsigned char *)"checkout-prefix",          { 0 }, DT_PATH };
+  struct variable *var = NULL;
+
+  if( !repo ) return;
+
+  var = lookup( repo, &repo_root );
+  if( var )
+  {
+    ctx.repo.repo_root = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &trunk );
+  if( var )
+  {
+    ctx.repo.trunk = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &branches );
+  if( var )
+  {
+    ctx.repo.branches = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &tags );
+  if( var )
+  {
+    ctx.repo.tags = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &rw_prefix );
+  if( var )
+  {
+    ctx.repo.checkout_prefix = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &ro_prefix );
+  if( var )
+  {
+    ctx.repo.checkout_ro_prefix = (const char *)var->_v.vptr;
+  }
+}
+
+static void ctx_site_vars_from_repo( struct repo *repo )
+{
+  struct variable                   css = { (unsigned char *)"css",                  { 0 }, DT_PATH   };
+  struct variable                 owner = { (unsigned char *)"owner",                { 0 }, DT_STRING };
+  struct variable                author = { (unsigned char *)"author",               { 0 }, DT_STRING };
+  struct variable                 title = { (unsigned char *)"title",                { 0 }, DT_STRING };
+  struct variable           description = { (unsigned char *)"description",          { 0 }, DT_STRING };
+  struct variable              keywords = { (unsigned char *)"keywords",             { 0 }, DT_STRING };
+  struct variable      copyright_notice = { (unsigned char *)"copyright-notice",     { 0 }, DT_STRING };
+  struct variable             copyright = { (unsigned char *)"copyright",            { 0 }, DT_STRING };
+  struct variable          favicon_path = { (unsigned char *)"favicon-path",         { 0 }, DT_PATH   };
+  struct variable                  logo = { (unsigned char *)"logo",                 { 0 }, DT_PATH   };
+  struct variable              logo_alt = { (unsigned char *)"logo-alt",             { 0 }, DT_STRING };
+  struct variable             logo_link = { (unsigned char *)"logo-link",            { 0 }, DT_STRING };
+  struct variable             home_page = { (unsigned char *)"home-page",            { 0 }, DT_STRING };
+  struct variable             snapshots = { (unsigned char *)"snapshots",            { 0 }, DT_PATH   };
+  struct variable        main_menu_logo = { (unsigned char *)"main-menu-logo",       { 0 }, DT_PATH   };
+  struct variable  syntax_highlight_css = { (unsigned char *)"syntax-highlight-css", { 0 }, DT_PATH   };
+  struct variable *var = NULL;
+
+  if( !repo ) return;
+
+  var = lookup( repo, &css );
+  if( var )
+  {
+    ctx.vars.css = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &owner );
+  if( var )
+  {
+    ctx.vars.owner = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &author );
+  if( var )
+  {
+    ctx.vars.author = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &title );
+  if( var )
+  {
+    ctx.vars.title = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &description );
+  if( var )
+  {
+    ctx.vars.description = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &keywords );
+  if( var )
+  {
+    ctx.vars.keywords = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &copyright_notice );
+  if( var )
+  {
+    ctx.vars.copyright_notice = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &copyright );
+  if( var )
+  {
+    ctx.vars.copyright = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &favicon_path );
+  if( var )
+  {
+    ctx.vars.favicon_path = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &logo );
+  if( var )
+  {
+    ctx.vars.logo = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &logo_alt );
+  if( var )
+  {
+    ctx.vars.logo_alt = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &logo_link );
+  if( var )
+  {
+    ctx.vars.logo_link = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &home_page );
+  if( var )
+  {
+    ctx.vars.home_page = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &snapshots );
+  if( var )
+  {
+    ctx.vars.snapshots = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &main_menu_logo );
+  if( var )
+  {
+    ctx.vars.main_menu_logo = (const char *)var->_v.vptr;
+  }
+  var = lookup( repo, &syntax_highlight_css );
+  if( var )
+  {
+    ctx.vars.syntax_highlight_css = (const char *)var->_v.vptr;
+  }
+}
+
+static void ctx_promo_vars_from_repo( struct repo *repo )
+{
+  struct variable  analytic_links   = { (unsigned char *)"analytic-links",   { 0 }, DT_PATH      };
+  struct variable  analytic_scripts = { (unsigned char *)"analytic-scripts", { 0 }, DT_PATH      };
+  struct variable  donate           = { (unsigned char *)"donate",           { 0 }, DT_NUMERICAL };
+  struct variable  donate_css       = { (unsigned char *)"donate-css",       { 0 }, DT_PATH      };
+  struct variable  donate_html      = { (unsigned char *)"donate-html",      { 0 }, DT_PATH      };
+  struct variable  donate_js        = { (unsigned char *)"donate-js",        { 0 }, DT_PATH      };
+  struct variable  donate_header    = { (unsigned char *)"donate-header",    { 0 }, DT_STRING    };
+  struct variable  donate_purpose   = { (unsigned char *)"donate-purpose",   { 0 }, DT_STRING    };
+  struct variable *var = NULL;
+
+  /*
+    Analytics reads from global section only:
+   */
+  var = lookup_global( lookup_global_section( config ), &analytic_links );
+  if( var )
+  {
+    ctx.promo.analytic_links = (const char *)var->_v.vptr;
+
+    if( ctx.promo.analytic_links && *ctx.promo.analytic_links )
+    {
+      struct strbuf buf = STRBUF_INIT;
+      char  *links = NULL;
+
+      (void)read_http_root_raw_file( &buf, ctx.promo.analytic_links );
+
+      links = (char *)__sbrk( (int)buf.len + 1 );
+      memcpy( (void *)links, (const void *)buf.buf, buf.len + 1 );
+      ctx.promo.analytic_links = (const char *)links;
+      strbuf_release( &buf );
+    }
+  }
+  var = lookup_global( lookup_global_section( config ), &analytic_scripts );
+  if( var )
+  {
+    ctx.promo.analytic_scripts = (const char *)var->_v.vptr;
+
+    if( ctx.promo.analytic_scripts && *ctx.promo.analytic_scripts )
+    {
+      struct strbuf buf = STRBUF_INIT;
+      char  *scripts = NULL;
+
+      (void)read_http_root_raw_file( &buf, ctx.promo.analytic_scripts );
+
+      scripts = (char *)__sbrk( (int)buf.len + 1 );
+      memcpy( (void *)scripts, (const void *)buf.buf, buf.len + 1 );
+      ctx.promo.analytic_scripts = (const char *)scripts;
+      strbuf_release( &buf );
+    }
+  }
+
+  var = lookup( repo, &donate );
+  if( var )
+  {
+    if( var->type == DT_NUMERICAL )
+    {
+      ctx.promo.donate = var->_v.val;
+      if( ctx.promo.donate )
+        ctx.promo.donate = 1;
+    }
+  }
+
+  if( ctx.promo.donate )
+  {
+    var = lookup( repo, &donate_css );
+    if( var )
+    {
+      ctx.promo.donate_css = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_css && *ctx.promo.donate_css )
+      {
+        struct strbuf buf = STRBUF_INIT;
+        char  *css = NULL;
+
+        strbuf_addf( &buf, "<link rel=\"stylesheet\" href=\"%s\">", ctx.promo.donate_css );
+        strbuf_trim( &buf );
+        css = (char *)__sbrk( (int)buf.len + 1 );
+        memcpy( (void *)css, (const void *)buf.buf, buf.len + 1 );
+        ctx.promo.donate_css = (const char *)css;
+        strbuf_release( &buf );
+      }
+    }
+    var = lookup( repo, &donate_js );
+    if( var )
+    {
+      ctx.promo.donate_js = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_js && *ctx.promo.donate_js )
+      {
+        struct strbuf buf = STRBUF_INIT;
+        char  *js = NULL;
+
+        strbuf_addf( &buf, "<script src=\"%s\"></script>", ctx.promo.donate_js );
+        strbuf_trim( &buf );
+        js = (char *)__sbrk( (int)buf.len + 1 );
+        memcpy( (void *)js, (const void *)buf.buf, buf.len + 1 );
+        ctx.promo.donate_js = (const char *)js;
+        strbuf_release( &buf );
+      }
+    }
+    var = lookup( repo, &donate_header );
+    if( var )
+    {
+      ctx.promo.donate_header = (const char *)var->_v.vptr;
+    }
+    var = lookup( repo, &donate_purpose );
+    if( var )
+    {
+      ctx.promo.donate_purpose = (const char *)var->_v.vptr;
+    }
+    var = lookup( repo, &donate_html );
+    if( var )
+    {
+      ctx.promo.donate_html = (const char *)var->_v.vptr;
+
+      if( ctx.promo.donate_html && *ctx.promo.donate_html )
+      {
+        envtab_install( &strbuf_envtab, "donate-header", ctx.promo.donate_header, fatal_html );
+        envtab_install( &strbuf_envtab, "donate-purpose", ctx.promo.donate_purpose, fatal_html );
+        read_donate_html();
+        envtab_release( &strbuf_envtab );
+      }
+    }
+  }
+}
+
+
+
+static char nrepos[11] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
+
+static void ctx_num_of_repos( void )
+{
+  int32_t  num = repolist_length( config );
+  num &= 0x7fffffff;
+  if( num > 0 )
+  {
+    snprintf( &nrepos[0], 11, "%d", num );
+    ctx.vars.num_of_repos = &nrepos[0];
+  }
+}
+
+static void ctx_repolist_status_line( void )
+{
+  struct strbuf buf = STRBUF_INIT;
+  char    *nrepos_string = NULL;
+  char    *status_line   = NULL;
+  int32_t  num = 0;
+
+  sscanf( ctx.vars.num_of_repos, "%d", &num );
+
+  strbuf_addf( &buf, Q_("%d Subversion Repository", "%d Subversion Repositories", num), num );
+  nrepos_string = (char *)__sbrk( (int)buf.len + 1 );
+  memcpy( (void *)nrepos_string, (const void *)buf.buf, buf.len + 1 );
+  strbuf_release( &buf );
+
+  buf.alloc = 0, buf.len = 0, buf.fatal = strbuf_fatal, buf.buf = strbuf_slopbuf;
+
+  strbuf_addf( &buf, "<span class=\"las la-cloud-upload\"></span> %s\n", nrepos_string );
+  if( ctx.promo.donate )
+    strbuf_addf( &buf, "&nbsp; | <a class=\"donate\"><span class=\"icon las la-credit-card\"></span> Donate</a>\n" );
+
+  status_line = (char *)__sbrk( (int)buf.len + 1 );
+  memcpy( (void *)status_line, (const void *)buf.buf, buf.len + 1 );
+  strbuf_release( &buf );
+
+  ctx.vars.status_line = (const char *)status_line;
+}
+
+static void ctx_repo_status_line( struct csvn_repository *rctx )
+{
+  struct strbuf buf      = STRBUF_INIT;
+  struct strbuf commits  = STRBUF_INIT;
+  struct strbuf branches = STRBUF_INIT;
+  struct strbuf tags     = STRBUF_INIT;
+  char  *status_line = NULL;
+
+  if( !rctx ) return;
+
+  strbuf_addf( &commits, Q_("%d Commit", "%d Commits", rctx->info.revision), rctx->info.revision );
+  strbuf_addf( &branches, Q_("%d Branch", "%d Branches", rctx->nbranches), rctx->nbranches );
+  strbuf_addf( &tags, Q_("%d Tag", "%d Tags", rctx->ntags), rctx->ntags );
+
+  strbuf_addf( &buf, "<span class=\"las la-code-commit\"></span> %s &nbsp;\n", commits.buf );
+  strbuf_addf( &buf, "<span class=\"las la-code-branch\"></span> %s &nbsp;\n", branches.buf );
+  strbuf_addf( &buf, "<span class=\"las la-tags\"></span> %s\n", tags.buf );
+  if( ctx.promo.donate )
+    strbuf_addf( &buf, "&nbsp; | <a class=\"donate\"><span class=\"icon las la-credit-card\"></span> Donate</a>\n" );
+
+  strbuf_release( &commits );
+  strbuf_release( &branches );
+  strbuf_release( &tags );
+
+  status_line = (char *)__sbrk( (int)buf.len + 1 );
+  memcpy( (void *)status_line, (const void *)buf.buf, buf.len + 1 );
+  strbuf_release( &buf );
+
+  ctx.vars.status_line = (const char *)status_line;
+}
+
+static void ctx_repolist_menu( void )
+{
+  struct strbuf mmenu = STRBUF_INIT;
+  struct strbuf popup = STRBUF_INIT;
+  struct strbuf right = STRBUF_INIT;
+
+  char *main_menu  = NULL;
+  char *popup_menu = NULL;
+  char *right_menu = NULL;
+
+  strbuf_addf( &mmenu, "<a href=\"/\">Index</a>\n" );
+  strbuf_addf( &popup, "<div class=\"item\"><span class=\"icon las la-home\"></span><a href=\"%s\" target=\"_blank\">Home page</a></div>\n", ctx.vars.home_page );
+  strbuf_addf( &right, "<div class=\"item\"><a href=\"%s\" target=\"_blank\">Home page</a></div>\n", ctx.vars.home_page );
+
+  main_menu = (char *)__sbrk( (int)mmenu.len + 1 );
+  memcpy( (void *)main_menu, (const void *)mmenu.buf, mmenu.len + 1 );
+  strbuf_release( &mmenu );
+  ctx.vars.main_menu_item = (const char *)main_menu;
+
+  popup_menu = (char *)__sbrk( (int)popup.len + 1 );
+  memcpy( (void *)popup_menu, (const void *)popup.buf, popup.len + 1 );
+  strbuf_release( &popup );
+  ctx.vars.popup_menu_items = (const char *)popup_menu;
+
+  right_menu = (char *)__sbrk( (int)right.len + 1 );
+  memcpy( (void *)right_menu, (const void *)right.buf, right.len + 1 );
+  strbuf_release( &right );
+  ctx.vars.right_menu_items = (const char *)right_menu;
+}
+
+static void ctx_repo_menu( struct csvn_repository *rctx )
+{
+  struct strbuf mmenu = STRBUF_INIT;
+  struct strbuf left  = STRBUF_INIT;
+  struct strbuf popup = STRBUF_INIT;
+  struct strbuf right = STRBUF_INIT;
+
+  char *main_menu  = NULL;
+  char *left_menu  = NULL;
+  char *popup_menu = NULL;
+  char *right_menu = NULL;
+
+  if( !rctx ) return;
+
+  strbuf_addf( &mmenu, "<a href=\"/\">Index</a>\n" );
+
+  strbuf_addf( &left, "<div class=\"item\"><a href=\"/%s/%s/\">Trunk</a></div>\n", rctx->name, rctx->trunk );
+  strbuf_addf( &left, "<div class=\"item\"><a href=\"/%s/%s/\">Branches</a></div>\n", rctx->name, rctx->branches );
+  strbuf_addf( &left, "<div class=\"item\"><a href=\"/%s/%s/\">Tags</a></div>\n", rctx->name, rctx->tags );
+
+  strbuf_addf( &popup, "<div class=\"item\"><span class=\"icon las la-road\"></span><a href=\"/%s/%s/\">Trunk</a></div>\n", rctx->name, rctx->trunk );
+  strbuf_addf( &popup, "<div class=\"item\"><span class=\"icon las la-code-branch\"></span><a href=\"/%s/%s/\">Branches</a></div>\n", rctx->name, rctx->branches );
+  strbuf_addf( &popup, "<div class=\"item\"><span class=\"icon las la-tags\"></span><a href=\"/%s/%s/\">Tags</a></div>\n", rctx->name, rctx->tags );
+  strbuf_addf( &popup, "<div class=\"divider\"></div>\n" );
+  strbuf_addf( &popup, "<div class=\"item\"><span class=\"icon las la-home\"></span><a href=\"%s\" target=\"_blank\">Home page</a></div>\n", ctx.vars.home_page );
+
+  strbuf_addf( &right, "<div class=\"item\"><a href=\"%s\" target=\"_blank\">Home page</a></div>\n", ctx.vars.home_page );
+
+  main_menu = (char *)__sbrk( (int)mmenu.len + 1 );
+  memcpy( (void *)main_menu, (const void *)mmenu.buf, mmenu.len + 1 );
+  strbuf_release( &mmenu );
+  ctx.vars.main_menu_item = (const char *)main_menu;
+
+  left_menu = (char *)__sbrk( (int)left.len + 1 );
+  memcpy( (void *)left_menu, (const void *)left.buf, left.len + 1 );
+  strbuf_release( &left );
+  ctx.vars.left_menu_items = (const char *)left_menu;
+
+  popup_menu = (char *)__sbrk( (int)popup.len + 1 );
+  memcpy( (void *)popup_menu, (const void *)popup.buf, popup.len + 1 );
+  strbuf_release( &popup );
+  ctx.vars.popup_menu_items = (const char *)popup_menu;
+
+  right_menu = (char *)__sbrk( (int)right.len + 1 );
+  memcpy( (void *)right_menu, (const void *)right.buf, right.len + 1 );
+  strbuf_release( &right );
+  ctx.vars.right_menu_items = (const char *)right_menu;
+}
+
+
+static void ctx_header_from_global( void )
+{
+  struct strbuf   buf  = STRBUF_INIT;
+  struct variable head = { (unsigned char *)"header", { 0 }, DT_PATH }, *var = NULL;
+  char  *pheader = NULL;
+
+  var = lookup_global( lookup_global_section( config ), &head );
+  strbuf_selfdir( &buf );
+
+  if( var ) { strbuf_addf( &buf, "%s", (const char *)var->_v.vptr ); }
+  else      { strbuf_addf( &buf, "%s", ctx.page.header );            }
+
+  pheader = (char *)__sbrk( (int)buf.len + 1 );
+  sprintf( pheader, "%s", buf.buf );
+  strbuf_release( &buf );
+  ctx.page.header = (const char *)pheader;
+}
+
+static void ctx_header_from_repo( struct repo *repo )
+{
+  struct strbuf   buf  = STRBUF_INIT;
+  struct variable head = { (unsigned char *)"header", { 0 }, DT_PATH }, *var = NULL;
+  char  *pheader = NULL;
+
+  var = lookup( repo, &head );
+  strbuf_selfdir( &buf );
+
+  if( var ) { strbuf_addf( &buf, "%s", (const char *)var->_v.vptr ); }
+  else      { strbuf_addf( &buf, "%s", ctx.page.header );            }
+
+  pheader = (char *)__sbrk( (int)buf.len + 1 );
+  sprintf( pheader, "%s", buf.buf );
+  strbuf_release( &buf );
+  ctx.page.header = (const char *)pheader;
+}
+
+
+static void ctx_footer_from_global( void )
+{
+  struct strbuf   buf  = STRBUF_INIT;
+  struct variable foot = { (unsigned char *)"footer", { 0 }, DT_PATH }, *var = NULL;
+  char  *pfooter = NULL;
+
+  var = lookup_global( lookup_global_section( config ), &foot );
+  strbuf_selfdir( &buf );
+
+  if( var ) { strbuf_addf( &buf, "%s", (const char *)var->_v.vptr ); }
+  else      { strbuf_addf( &buf, "%s", ctx.page.footer );            }
+
+  pfooter = (char *)__sbrk( (int)buf.len + 1 );
+  sprintf( pfooter, "%s", buf.buf );
+  strbuf_release( &buf );
+  ctx.page.footer = (const char *)pfooter;
+}
+
+static void ctx_footer_from_repo( struct repo *repo )
+{
+  struct strbuf   buf  = STRBUF_INIT;
+  struct variable foot = { (unsigned char *)"footer", { 0 }, DT_PATH }, *var = NULL;
+  char  *pfooter = NULL;
+
+  var = lookup( repo, &foot );
+  strbuf_selfdir( &buf );
+
+  if( var ) { strbuf_addf( &buf, "%s", (const char *)var->_v.vptr ); }
+  else      { strbuf_addf( &buf, "%s", ctx.page.footer );            }
+
+  pfooter = (char *)__sbrk( (int)buf.len + 1 );
+  sprintf( pfooter, "%s", buf.buf );
+  strbuf_release( &buf );
+  ctx.page.footer = (const char *)pfooter;
+}
+
+
+static char name[PATH_MAX] = { 0 };
+static char repo_root[PATH_MAX] = { 0 };
+static char relative_path[PATH_MAX] = { 0 };
+
+static char try[PATH_MAX] = { 0 };
+
+static struct repo *ctx_repo_name( void )
+{
+  struct repo *repo = NULL;
+  char *s, *p = NULL, *n, *path, *path_info;
+  int   len = 0;
+
+  if( strcmp( "/", ctx.env.path_info ) )
+  {
+    path_info = xstrdup( ctx.env.path_info );
+    s = path_info;
+
+    while( *s )
+    {
+      while( *s && is_dir_sep( *s ) )
+        ++s;
+      n = p = s;
+
+      while( *p && !is_dir_sep( *p ) )
+        ++p;
+      if( *p )
+      {
+        *p = '\0'; s = ++p;
+
+        /****************************************************************
+          The repo name can be given as a relative path in the git-root:
+         */
+        if( repo_root[0] )
+        {
+          sprintf( try, "%s", repo_root );
+          strcat( try, "/" );
+          strcat( try, n );
+        }
+        else
+        {
+          sprintf( try, "%s", n );
+        }
+
+        if( (repo = lookup_repo( config, try )) )
+        {
+          sprintf( name, "%s", try );
+          {
+            char *rr = strstr( repo_root, try );
+            if( rr )
+              *rr = '\0';
+            else
+              repo_root[0] = '\0';
+          }
+          break;
+        }
+        else
+        {
+          if( repo_root[0] )
+            strcat( repo_root, "/" );
+          strcat( repo_root, n );
+        }
+      }
+      else
+        s = p;
+    }
+
+    ctx.repo.name = (const char *)&name[0];
+    ctx.repo.repo_root = (const char *)&repo_root[0];
+
+    path = p;
+
+    if( *path )
+    {
+      len = (int)strlen( path );
+
+      if( path[len-1] =='/' ) { path[len-1] = '\0'; --len; }
+      len += 1;
+
+      sprintf( relative_path, "%s", path );
+      ctx.repo.relative_path = (const char *)&relative_path[0];
+    }
+
+    free( path_info );
+  }
+
+  return repo;
+}
+
+
+/*************************************************************
+  Get integer value of query parameter 'name' and remove this
+  parameter 'name=..' from ctx.env.query_string.
+ */
+int ctx_grab_int_query_param( const char *name )
+{
+  char *pofs = NULL, *query_string, *s = (char *)ctx.env.query_string;
+  int   ret = 0, len = 0;
+
+  if( !name || !*name ) return ret;
+
+  if( s && *s && (pofs = strstr( s, name )) )
+  {
+    char *rem, *p, *val = NULL;
+    struct strbuf buf = STRBUF_INIT;
+
+    p = pofs;
+
+    /* move to end of 'ofs=val' declaration: */
+    while( *p && *p != '&' && *p != '=' ) ++p;
+    if( *p == '=' ) { val = ++p; while( *p && *p != '&' ) ++p; }
+    if( *p ) { *p = '\0'; rem = ++p; }
+    else
+    {
+      rem = p;
+      if( s < pofs && (pofs[-1] == '&' || pofs[-1] == '=') ) --pofs;
+    }
+
+    /* fill buffer: */
+    while( s < pofs ) { strbuf_addch( &buf, *s ); ++s; }
+    s = rem;
+    while( *s ) { strbuf_addch( &buf, *s ); ++s; }
+    strbuf_addch( &buf, '\0' );
+
+    /* get value: */
+    if( val && *val ) { ret = atoi( val ); }
+    else              { ret = 0;           }
+
+    len = (int)buf.len;
+    query_string = (char *)__sbrk( len );
+    memcpy( (void *)query_string, (const void *)buf.buf, (size_t)len );
+    strbuf_release( &buf );
+    ctx.env.query_string = (const char *)query_string;
+  }
+
+  return ret;
+}
+
+/***************************************************************
+  Rmove parametr with specified 'name=...' fom query string and
+  return modified query string allocated in context _mem[].
+ */
+const char *ctx_remove_query_param( const char *query_string, const char *name )
+{
+  char *pofs = NULL, *query = NULL, *s = (char *)query_string;
+  int len = 0;
+
+  if( !name || !*name ) return (const char *)query;
+
+  if( s && *s && (pofs = strstr( s, name )) )
+  {
+    char *rem, *p;
+    struct strbuf buf = STRBUF_INIT;
+
+    p = pofs;
+
+    /* move to end of 'ofs=val' declaration: */
+    while( *p && *p != '&' && *p != '=' ) ++p;
+    if( *p == '=' ) { while( *p && *p != '&' ) ++p; }
+    if( *p ) { *p = '\0'; rem = ++p; }
+    else
+    {
+      rem = p;
+      if( s < pofs && (pofs[-1] == '&' || pofs[-1] == '=') ) --pofs;
+    }
+
+    /* fill buffer: */
+    while( s < pofs ) { strbuf_addch( &buf, *s ); ++s; }
+    s = rem;
+    while( *s ) { strbuf_addch( &buf, *s ); ++s; }
+    strbuf_addch( &buf, '\0' );
+
+    len = (int)buf.len;
+    query = (char *)__sbrk( len );
+    memcpy( (void *)query, (const void *)buf.buf, (size_t)len );
+    strbuf_release( &buf );
+    return (const char *)query;
+  }
+
+  return (const char *)query;
+}
+
+
+static void ctx_search_placeholder( void )
+{
+  struct strbuf buf = STRBUF_INIT;
+  char  *revision;
+  int    len;
+
+  if( !strcmp( ctx.vars.page_type, ptype_repo ) )
+  {
+    if( ctx.query.rev )
+      strbuf_addf( &buf, "%d", ctx.query.rev );
+    else
+      strbuf_addf( &buf, "%d", ctx.repo.info.revision );
+
+    len = (int)strlen( buf.buf ) + 1;
+    revision = (char *)__sbrk( len );
+    memcpy( (void *)revision, (const void *)buf.buf, (size_t)len );
+    strbuf_release( &buf );
+
+    ctx.repo.search_placeholder = (const char *)revision;
+    /* ctx.repo.search_placeholder = "HEAD"; */
+  }
+}
+
+static void ctx_relative_html( void )
+{
+  struct strbuf buf  = STRBUF_INIT;
+  char  *relative_html;
+  int    len;
+
+  if( !strcmp( ctx.vars.page_type, ptype_repolist ) )
+  {
+    if( ctx.env.http_host && *ctx.env.http_host )
+    {
+      strbuf_addf( &buf, "<a class='base' href='/'>%s</a>/", ctx.env.http_host );
+    }
+    else if( ctx.env.server_name && *ctx.env.server_name )
+    {
+      strbuf_addf( &buf, "<a class='base' href='/'>%s</a>/", ctx.env.server_name );
+    }
+  }
+  else if( !strcmp( ctx.vars.page_type, ptype_repo ) )
+  {
+    if( ctx.repo.name && *ctx.repo.name && ctx.repo.info.kind != KIND_UNKNOWN  )
+    {
+      if( ctx.repo.repo_root && *ctx.repo.repo_root )
+        strbuf_addf( &buf, "<a class='base' href='/%s/%s/'>%s/%s</a>/", ctx.repo.repo_root, ctx.repo.name, ctx.repo.repo_root, ctx.repo.name );
+      else
+        strbuf_addf( &buf, "<a class='base' href='/%s/'>%s</a>/", ctx.repo.name, ctx.repo.name );
+    }
+    if( ctx.repo.relative_path && *ctx.repo.relative_path && ctx.repo.relative_info.kind != KIND_UNKNOWN )
+    {
+      char   *p, *s, *rem;
+      int     msize;
+      char   *path, *href;
+      size_t  length;
+
+      length = strlen( ctx.repo.relative_path ) + 1;
+      msize = (int)strlen(ctx.repo.name) + (int)strlen(ctx.repo.relative_path) + 4; /* '/' repo.name '/' relative_path '/' + '\0' */
+
+      href = (char *)__sbrk( msize );
+      sprintf( href, "/%s/", ctx.repo.name );
+
+      path = (char *)__sbrk( msize );
+      memcpy( (void *)path, (const void *)ctx.repo.relative_path, length );
+
+      p = s = path;
+      while( *p && !is_dir_sep( *p ) ) ++p;
+      if( *p ) { *p = '\0'; rem = ++p; }
+      else     { rem = p; }
+      strcat( href, s ); strcat( href, "/" );
+
+      if( !strcmp( s, ctx.repo.trunk )    ||
+          !strcmp( s, ctx.repo.branches ) ||
+          !strcmp( s, ctx.repo.tags )       )
+      {
+        strbuf_addf( &buf, "<a class='base' href='%s'>%s</a>/", href, s );
+      }
+      else
+      {
+        strbuf_addf( &buf, "<a class='relative' href='%s'>%s</a>/", href, s );
+      }
+
+      s = rem;
+      while( *s )
+      {
+        p = s;
+        while( *p && !is_dir_sep( *p ) ) ++p;
+        if( *p ) { *p = '\0'; rem = ++p; }
+        else     { rem = p; }
+        strcat( href, s ); strcat( href, "/" );
+        strbuf_addf( &buf, "<a class='relative' href='%s'>%s</a>/", href, s );
+        s = rem;
+      }
+
+      if( ctx.repo.relative_info.kind == KIND_FILE )
+        strbuf_trim_trailing_dir_sep( &buf );
+
+      ctx.repo.relative_href = (const char *)href;
+
+      (void)__sbrk( - msize ); /* free ctx memory alocated for path only */
+    }
+  }
+
+  len = (int)strlen( buf.buf ) + 1;
+  relative_html = (char *)__sbrk( len );
+  memcpy( (void *)relative_html, (const void *)buf.buf, (size_t)len );
+  strbuf_release( &buf );
+  ctx.repo.relative_html = (const char *)relative_html;
+}
+
+static void ctx_check_query_uri( int replace_query_string )
+{
+  /*
+    Nginx passed QUERY_STRING for all cgi engines by: {fastcgi, scgi, uwsgi}_params.
+    But PATH_INFO passed onlyfor UWSGI by uwsgi_params.
+   */
+  if( !ctx.env.path_info && ctx.env.request_uri && *ctx.env.request_uri )
+  {
+    char *path_info = NULL, *query_string = NULL;
+    char *p, *path, *query = NULL;
+    int   len;
+
+    p = path = (char *)ctx.env.request_uri;
+
+    while( *p && *p != '?' ) ++p;
+    if( *p == '?' ) { *p = '\0'; query = ++p; }
+
+    len = strlen( path ) + 1;
+    path_info = (char *)__sbrk( len );
+    memcpy( (void *)path_info, (const void *)path, (size_t)len );
+    ctx.env.path_info = (const char *)path_info;
+
+    if( query && *query && replace_query_string )
+    {
+      len = strlen( query ) + 1;
+      query_string = (char *)__sbrk( len );
+      memcpy( (void *)query_string, (const void *)query, (size_t)len );
+      ctx.env.query_string = (const char *)query_string;
+    }
+  }
+}
+
+
+static void querystring_cb( const char *name, const char *value )
+{
+  char *val;
+  int   len;
+
+  if( !value )
+    value = "";
+
+  if( !strcmp( name, "rev" ) )
+  {
+    len = (int)strlen( value ) + 1;
+    val = (char *)__sbrk( len );
+    memcpy( (void *)val, (const void *)value, (size_t)len );
+    ctx.query.revision = (const char *)val;
+    if( !strcasecmp( val, "HEAD" ) )
+      ctx.query.rev = 0;
+    else
+      ctx.query.rev = atoi( val );
+    /*****************************************************************************
+      NOTE:
+      ====
+        If we will parse another string values of SVN revision such as
+        'BASE', 'COMMITED', 'PREV' then we have to call http_parse_querystring()
+        strongly after calling csvn_rpath_info() or ctx_relative_html() because
+        the structs ctx.repo.info and ctx.repo.relative_info should be completed
+        before parsing special SVN revision names.
+
+        Revision at start of the date '{' DATE '}' we will not support.
+     *****************************************************************************/
+  }
+  else if( !strcmp( name, "op" ) )
+  {
+    len = (int)strlen( value ) + 1;
+    val = (char *)__sbrk( len );
+    memcpy( (void *)val, (const void *)value, (size_t)len );
+    ctx.query.operation = (const char *)val;
+  }
+  else if( !strcmp( name, "search" ) )
+  {
+    len = (int)strlen( value ) + 1;
+    val = (char *)__sbrk( len );
+    memcpy( (void *)val, (const void *)value, (size_t)len );
+    ctx.query.search = (const char *)val;
+  }
+/*
+  else if( another parameter )
+  {
+  }
+  ...
+ */
+  /* NOTE: Do not parse 'ofs=' parameter! */
+}
+
+
+void csvn_parse_query( void )
+{
+  char *path_info = NULL;
+
+  get_selfdir();
+
+  ctx_check_query_uri( 1 );
+
+  path_info = xstrdup( ctx.env.path_info );
+
+  ctx.query.ofs = ctx_grab_int_query_param( "ofs" );
+
+  if( path_info )
+  {
+    if( !strcmp( "/", path_info ) )
+    {
+      ctx_page_size_from_global();
+      ctx_repo_dirs_from_global();
+      ctx_site_vars_from_global();
+      ctx_promo_vars_from_global();
+      ctx_header_from_global();
+      ctx_footer_from_global();
+      ctx_num_of_repos();
+      ctx_repolist_status_line();
+      ctx_repolist_menu();
+    }
+    else
+    {
+      struct repo *repo = NULL;
+
+      repo = ctx_repo_name();
+      if( repo )
+      {
+        ctx_page_size_from_repo( repo );
+        ctx_repo_dirs_from_repo( repo );
+        ctx_site_vars_from_repo( repo );
+        ctx_promo_vars_from_repo( repo );
+        ctx_header_from_repo( repo );
+        ctx_footer_from_repo( repo );
+        ctx.vars.page_type = ptype_repo;
+
+        csvn_repo_info( &ctx.repo.info, 0 );
+        if( ctx.repo.relative_path )
+          csvn_rpath_info( &ctx.repo.relative_info, ctx.repo.relative_path, 0 );
+        else
+          memcpy( (void *)&ctx.repo.relative_info, (const void *)&ctx.repo.info, sizeof( struct csvn_info ) );
+
+        csvn_repo_branches_number( &ctx.repo );
+        csvn_repo_tags_number( &ctx.repo );
+        ctx_repo_status_line( &ctx.repo );
+        ctx_repo_menu( &ctx.repo );
+      }
+      else
+      {
+        ctx_page_size_from_global();
+        ctx_repo_dirs_from_global();
+        ctx_header_from_global();
+        ctx_footer_from_global();
+
+        ctx.page.status = 404;
+        ctx.page.status_message = "Page not found";
+
+        ctx.vars.title = "404";
+        {
+          struct strbuf  buf = STRBUF_INIT;
+          char  *stmsg = NULL;
+
+          /**************************************************************************
+            We slipped to the end of PATH_INFO when we were looking for a repository
+            and now we printout the repo-root:
+           */
+          strbuf_addf( &buf, "Subversion Repository '%s' not found.", ctx.repo.repo_root );
+          stmsg = (char *)__sbrk( (int)buf.len + 1 );
+          memcpy( (void *)stmsg, (const void *)buf.buf, buf.len + 1 );
+          strbuf_release( &buf );
+          ctx.vars.description = (const char *)stmsg;
+        }
+      }
+
+      ctx_num_of_repos();
+    }
+
+    ctx_relative_html();
+    http_parse_querystring( ctx.env.query_string, querystring_cb );
+    if( ctx.query.rev < 1 )
+    {
+      (void)ctx_grab_int_query_param( "rev" );
+      ctx.query.rev = 0;
+    }
+    ctx_search_placeholder();
+
+    csvn_svn_version( &ctx.vers );
+    csvn_nginx_version( &ctx.vers );
+
+    free( path_info );
+  }
+}
Index: csvn-ui-0.1.5/csvncgi/ctx.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ctx.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ctx.h	(revision 12)
@@ -0,0 +1,215 @@
+
+#ifndef    __CONTEXT_H
+#define    __CONTEXT_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+#define CONTEXT_MEM_SIZE  524288
+
+struct __context
+{
+  void *_cur_brk;
+  unsigned char _mem[CONTEXT_MEM_SIZE];
+};
+
+extern struct __context *pmctx;
+
+#define __cur_brk  (*((void **)&(pmctx->_cur_brk)))
+#define __mem      ((unsigned char *)&((pmctx->_mem)[0]))
+
+extern void __mctx_init( void );
+extern void *__sbrk( int incr );
+
+
+struct csvn_tmplt_vars {
+  const char *css;
+  const char *owner;
+  const char *author;
+  const char *description;
+  const char *keywords;
+  const char *title;
+  const char *favicon_path;
+  const char *syntax_highlight_css;
+  const char *logo;
+  const char *logo_alt;
+  const char *logo_link;
+  const char *home_page;
+  const char *snapshots;
+  const char *status_line;
+  const char *main_menu_logo;
+  const char *main_menu_item;
+  const char *left_menu_items;
+  const char *popup_menu_items;
+  const char *right_menu_items;
+  const char *copyright_notice;
+  const char *copyright;
+  const char *page_type;
+  const char *page_size;
+  const char *num_of_repos;
+};
+
+#define KIND_DIR     0
+#define KIND_FILE    1
+#define KIND_UNKNOWN 2
+#define CSVN_INFO_INIT  (struct csvn_info) { .kind = KIND_UNKNOWN, .revision = 0, .author = NULL, .date = 0, .mime = NULL, .lang = NULL }
+
+struct csvn_info {
+  int kind;
+  int revision;
+  const char *author;
+  time_t date;
+  const char *mime;
+  const char *lang;
+};
+
+struct csvn_repository {
+  const char       *name;
+  struct csvn_info  info;
+  const char       *repo_root;
+  const char       *relative_path;
+  struct csvn_info  relative_info;
+  const char       *relative_html;
+  const char       *relative_href;
+  const char       *search_placeholder;
+  const char       *trunk;    /* trunk    directory name */
+  const char       *branches; /* branches directory name */
+  const char       *tags;     /* tags     directory name */
+  const char       *checkout_prefix;
+  const char       *checkout_ro_prefix;
+  int               nbranches; /* number of branches */
+  int               ntags;     /* number of tags     */
+};
+
+struct csvn_page {
+  time_t modified;
+  time_t expires;
+  size_t size;
+  const char *mimetype;
+  const char *charset;
+  int status;
+  const char *status_message;
+  const char *header;
+  const char *footer;
+};
+
+struct csvn_environment {
+  const char *http_host;
+  const char *https;
+  const char *no_http;
+  const char *path_info;
+  const char *query_string;
+  const char *request_uri;
+  const char *request_scheme;
+  const char *request_method;
+  const char *script_name;
+  const char *server_name;
+  const char *server_port;
+  const char *http_cookie;
+  unsigned int content_lenght;
+  const char *http_root;
+  int authenticated;
+};
+
+struct csvn_query {
+  int ofs;
+  int rev;
+  const char *revision;
+  const char *operation;
+  const char *search;
+};
+
+struct csvn_versions {
+  const char *subversion;
+  const char *nginx;
+  const char *csvn;
+};
+
+struct csvn_promotion {
+  const char *analytic_links;
+  const char *analytic_scripts;
+  int donate;
+  const char *donate_css;
+  const char *donate_html;
+  const char *donate_js;
+  const char *donate_header;
+  const char *donate_purpose;
+};
+
+struct csvn_context {
+  struct csvn_environment  env;
+  struct csvn_promotion    promo;
+  struct csvn_query        query;
+  struct csvn_page         page;
+  struct csvn_tmplt_vars   vars;
+  struct csvn_repository   repo;
+  struct csvn_versions     vers;
+};
+
+
+extern const char *ptype_repolist;
+extern const char *ptype_repo;
+
+extern struct csvn_context ctx;
+
+/*
+  header/footer template variables:
+  ================================
+  ${css}
+  ${owner}
+  ${author}
+  ${description}
+  ${keywords}
+  ${title}
+  ${favicon-path}
+  ${syntax-highlight-css}
+  ${logo}
+  ${logo-alt}
+  ${logo-link}
+  ${home-page}
+  ${snapshots}
+  ${status-line}
+  ${main-menu-logo}
+  ${main-menu-item}
+  ${left-menu-items}
+  ${popup-menu-items}
+  ${right-menu-items}
+  ${relative-html}
+  ${search-placeholder}
+
+  ${analytic-links}
+  ${analytic-scripts}
+  ${donate-css}
+  ${donate-html}
+  ${donate-js}
+  ${donate-header}
+  ${donate-purpose}
+
+  ${svn-version}
+  ${nginx-version}
+  ${csvn-version}
+  ${copyright-notice}
+  ${copyright}
+
+  ${page-type}
+  ${page-size}
+  ${num-of-repos}
+ */
+
+extern void csvn_prepare_context( void );
+extern void csvn_prepare_template_variables( void );
+extern void csvn_release_template_variables( void );
+
+extern void csvn_parse_query( void );
+
+extern int ctx_grab_int_query_param( const char *name );
+extern const char *ctx_remove_query_param( const char *query_string, const char *name );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __CONTEXT_H */
Index: csvn-ui-0.1.5/csvncgi/date.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/date.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/date.c	(revision 12)
@@ -0,0 +1,596 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <strbuf.h>
+#include <date.h>
+
+
+/* Valid rule actions */
+enum rule_action
+{
+  ACCUM,    /* Accumulate a decimal value */
+  MICRO,    /* Accumulate microseconds */
+  TZIND,    /* Handle +, -, Z */
+  NOOP,     /* Do nothing */
+  SKIPFROM, /* If at end-of-value, accept the match.  Otherwise,
+               if the next template character matches the current
+               value character, continue processing as normal.
+               Otherwise, attempt to complete matching starting
+               immediately after the first subsequent occurrance of
+               ']' in the template. */
+  SKIP,     /* Ignore this template character */
+  ACCEPT    /* Accept the value */
+};
+
+/* How to handle a particular character in a template */
+struct rule
+{
+  char              key;    /* The template char that this rule matches */
+  const char       *valid;  /* String of valid chars for this rule */
+  enum rule_action  action; /* What action to take when the rule is matched */
+  int               offset; /* Where to store the any results of the action,
+                               expressed in terms of bytes relative to the
+                               base of a match_state object. */
+};
+
+struct match_state
+{
+  struct tm       base;
+  struct timeval  tv;
+  int             gmtoff;
+  int             gmtoff_hours;
+  int             gmtoff_minutes;
+};
+
+
+#define DIGITS "0123456789"
+
+/*
+  A declarative specification of how each template character
+  should be processed, using a rule for each valid symbol.
+ */
+static const struct rule rules[] =
+{
+  { 'Y', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_year)   },
+  { 'M', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_mon)    },
+  { 'D', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_mday)   },
+  { 'h', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_hour)   },
+  { 'm', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_min)    },
+  { 's', DIGITS,    ACCUM, offsetof(struct match_state, base.tm_sec)    },
+  { 'u', DIGITS,    MICRO, offsetof(struct match_state, tv.tv_usec)     },
+  { 'O', DIGITS,    ACCUM, offsetof(struct match_state, gmtoff_hours)   },
+  { 'o', DIGITS,    ACCUM, offsetof(struct match_state, gmtoff_minutes) },
+  { '+',   "-+",    TZIND, 0 },
+  { 'Z',    "Z",    TZIND, 0 },
+  { ':',    ":",     NOOP, 0 },
+  { '-',    "-",     NOOP, 0 },
+  { 'T',    "T",     NOOP, 0 },
+  { ' ',    " ",     NOOP, 0 },
+  { '.',   ".,",     NOOP, 0 },
+  { '[',   NULL, SKIPFROM, 0 },
+  { ']',   NULL,     SKIP, 0 },
+  { '\0',  NULL,   ACCEPT, 0 },
+};
+
+/* Return the rule associated with TCHAR, or NULL if there is no such rule. */
+static const struct rule *find_rule( char tchar )
+{
+  int i = sizeof(rules)/sizeof(rules[0]);
+  while( i-- )
+    if( rules[i].key == tchar )
+      return &rules[i];
+  return NULL;
+}
+
+/*
+  Attempt to match the date-string in VALUE to the provided TEMPLATE,
+  using the rules defined above.  Return TRUE on successful match,
+  FALSE otherwise.  On successful match, fill in *TM with the
+  matched values and set *LOCALTZ to GMT-offset if the local time zone
+  should be used to interpret the match.
+ */
+static int template_match( struct tm *tm, int *localtz, const char *template, const char *value )
+{
+  int    multiplier = 100000;
+  int    tzind = 0;
+  struct match_state  ms;
+  char  *base = (char *)&ms;
+
+  memset( &ms, 0, sizeof(ms) );
+
+  for( ;; )
+  {
+    const struct rule *match = find_rule(*template++);
+    char vchar = *value++;
+    int *place;
+
+    if( !match || (match->valid && (!vchar || !strchr(match->valid, vchar))) )
+      return FALSE;
+
+    /* Compute the address of memory location affected by this
+       rule by adding match->offset bytes to the address of ms.
+       Because this is a byte-quantity, it is necessary to cast
+       &ms to char *. */
+    place = (int *)(base + match->offset);
+    switch( match->action )
+    {
+      case ACCUM:
+        *place = *place * 10 + vchar - '0';
+        continue;
+      case MICRO:
+        *place += (vchar - '0') * multiplier;
+        multiplier /= 10;
+        continue;
+      case TZIND:
+        tzind = vchar;
+        continue;
+      case SKIP:
+        value--;
+        continue;
+      case NOOP:
+        continue;
+      case SKIPFROM:
+        if( !vchar )
+          break;
+        match = find_rule(*template);
+        if (!strchr(match->valid, vchar))
+          template = strchr(template, ']') + 1;
+        value--;
+        continue;
+      case ACCEPT:
+        if( vchar )
+          return FALSE;
+        break;
+    }
+
+    break;
+  }
+
+  /* Validate gmt offset here, since we can't reliably do it later. */
+  if( ms.gmtoff_hours > 23 || ms.gmtoff_minutes > 59 )
+    return FALSE;
+
+  /*
+    tzind will be '+' or '-' for an explicit time zone,
+    'Z' to indicate UTC, or 0 to indicate local time.
+   */
+  switch( tzind )
+  {
+    case '+':
+      ms.gmtoff =   ms.gmtoff_hours * 3600 + ms.gmtoff_minutes * 60;
+      break;
+    case '-':
+      ms.gmtoff = -(ms.gmtoff_hours * 3600 + ms.gmtoff_minutes * 60);
+      break;
+  }
+
+  *tm = ms.base;
+  *localtz = ms.gmtoff;
+  return TRUE;
+}
+
+static int valid_days_by_month[] =
+{
+  31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31
+};
+
+/*
+  Returns -1 on error,
+  time_t as the number of seconds since Epoch, 1970-01-01 00:00:00 +0000 (UTC)
+  on success.
+ */
+time_t parse_date( struct tm *tm, const char *text )
+{
+  time_t     n, ret = (time_t)-1;
+  struct tm  pt, *now;
+  int        localtz;
+
+  n = time( NULL ); /* current UTC time */
+  now = gmtime( &n );
+
+
+  if( /* ISO-8601 extended, date only: */
+      template_match( &pt, &localtz, "YYYY-M[M]-D[D]", text ) ||
+      /* ISO-8601 extended, UTC: */
+      template_match( &pt, &localtz, "YYYY-M[M]-D[D]Th[h]:mm[:ss[.u[u[u[u[u[u][Z]", text ) ||
+      /* ISO-8601 extended, with offset: */
+      template_match( &pt, &localtz, "YYYY-M[M]-D[D]Th[h]:mm[:ss[.u[u[u[u[u[u]+OO[:oo]", text ) ||
+      /* ISO-8601 basic, date only */
+      template_match( &pt, &localtz, "YYYYMMDD", text ) ||
+      /* ISO-8601 basic, UTC: */
+      template_match( &pt, &localtz, "YYYYMMDDThhmm[ss[.u[u[u[u[u[u][Z]", text ) ||
+      /* ISO-8601 basic, with offset: */
+      template_match( &pt, &localtz, "YYYYMMDDThhmm[ss[.u[u[u[u[u[u]+OO[oo]", text ) ||
+      /* "svn log" format: */
+      template_match( &pt, &localtz, "YYYY-M[M]-D[D] h[h]:mm[:ss[.u[u[u[u[u[u][ +OO[oo]", text ) ||
+      /* GNU date's iso-8601: */
+      template_match( &pt, &localtz, "YYYY-M[M]-D[D]Th[h]:mm[:ss[.u[u[u[u[u[u]+OO[oo]", text ) )
+  {
+    pt.tm_year -= 1900;
+    pt.tm_mon -= 1;
+  }
+  else if( template_match( &pt, &localtz, "h[h]:mm[:ss[.u[u[u[u[u[u]", text) ) /* Just a time */
+  {
+    pt.tm_year = now->tm_year;
+    pt.tm_mon  = now->tm_mon;
+    pt.tm_mday = now->tm_mday;
+  }
+
+  /* Range validation, allowing for leap seconds */
+  if( pt.tm_mon  <  0 ||
+      pt.tm_mon  > 11 ||
+      pt.tm_mday > valid_days_by_month[pt.tm_mon] ||
+      pt.tm_mday <  1 ||
+      pt.tm_hour > 23 ||
+      pt.tm_min  > 59 ||
+      pt.tm_sec  > 60   )
+    return ret;
+
+  /*
+    february/leap-year day checking. tm_year is bias-1900, so
+    centuries that equal 100 (mod 400) are multiples of 400.
+   */
+  if( pt.tm_mon  ==  1 &&
+      pt.tm_mday == 29 &&
+     (pt.tm_year % 4 != 0 || (pt.tm_year % 100 == 0 && pt.tm_year % 400 != 100)) )
+    return ret;
+
+  if( localtz )
+  {
+    struct tm *gmt = NULL;
+    time_t     time;
+
+    time = mktime( &pt ); /* brocken-down tm asumed as localtime */
+    if( time == -1 )
+      return ret;
+
+    time -= (time_t)localtz;
+
+    gmt = localtime( &time );
+    if( !gmt )
+      return ret;
+
+    memcpy( (void *)&pt, (const void *)gmt, sizeof(struct tm) );
+  }
+
+  memcpy( (void *)tm, (const void *)&pt, sizeof(struct tm) );
+
+  return mktime( &pt );
+}
+
+
+void show_date_relative( struct strbuf *sb, time_t t )
+{
+  time_t now, diff;
+
+  if( !sb || !t ) return;
+
+  now = time( NULL );
+  if( now < t )
+  {
+    strbuf_addstr( sb, _("in the future") );
+    return;
+  }
+  diff = now - t;
+  if( diff < 90 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" second ago", "%"PRIdMAX" seconds ago", diff), diff );
+    return;
+  }
+  /* Turn it into minutes */
+  diff = (diff + 30) / 60;
+  if( diff < 90 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" minute ago", "%"PRIdMAX" minutes ago", diff), diff );
+    return;
+  }
+  /* Turn it into hours */
+  diff = (diff + 30) / 60;
+  if( diff < 36 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" hour ago", "%"PRIdMAX" hours ago", diff), diff );
+    return;
+  }
+  /* We deal with number of days from here on */
+  diff = (diff + 12) / 24;
+  if( diff < 14 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" day ago", "%"PRIdMAX" days ago", diff), diff );
+    return;
+  }
+  /* Say weeks for the past 10 weeks or so */
+  if( diff < 70 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" week ago", "%"PRIdMAX" weeks ago", (diff+3)/7), (diff+3)/7 );
+    return;
+  }
+  /* Say months for the past 12 months or so */
+  if( diff < 365 )
+  {
+    strbuf_addf( sb, Q_("%"PRIdMAX" month ago", "%"PRIdMAX" months ago", (diff+15)/30), (diff+15)/30 );
+    return;
+  }
+  /* Give years and months for 5 years or so */
+  if( diff < 1825 )
+  {
+    time_t totalmonths = (diff * 12 * 2 + 365) / (365 * 2);
+    time_t years = totalmonths / 12;
+    time_t months = totalmonths % 12;
+    if( months )
+    {
+      struct strbuf buf = STRBUF_INIT;
+      strbuf_addf( &buf, Q_("%"PRIdMAX" year", "%"PRIdMAX" years", years), years );
+      strbuf_addf( sb,
+         /* TRANSLATORS: "%s" is "<n> months" */
+         Q_("%s, %"PRIdMAX" month ago", "%s, %"PRIdMAX" months ago", months), buf.buf, months );
+      strbuf_release( &buf );
+    }
+    else
+      strbuf_addf( sb, Q_("%"PRIdMAX" year ago", "%"PRIdMAX" years ago", years), years );
+    return;
+  }
+  /* Otherwise, just years. Centuries is probably overkill. */
+  strbuf_addf( sb, Q_("%"PRIdMAX" year ago", "%"PRIdMAX" years ago", (diff+183)/365), (diff+183)/365 );
+}
+
+struct date_mode *date_mode_from_type( enum date_mode_type type )
+{
+  static struct date_mode mode;
+  mode.type = type;
+  mode.local = 0;
+  return &mode;
+}
+
+static const char *month_names[] = {
+  "January", "February", "March", "April", "May", "June",
+  "July", "August", "September", "October", "November", "December"
+};
+
+static const char *weekday_names[] = {
+  "Sundays", "Mondays", "Tuesdays", "Wednesdays", "Thursdays", "Fridays", "Saturdays"
+};
+
+static time_t gm_time_t( time_t time, int tz )
+{
+  int minutes;
+
+  minutes = tz < 0 ? -tz : tz;
+  minutes = (minutes / 100)*60 + (minutes % 100);
+  minutes = tz < 0 ? -minutes : minutes;
+
+  time += minutes * 60;
+
+  return time;
+}
+
+static struct tm *time_to_tm( time_t time, int tz, struct tm *tm )
+{
+  time_t t = gm_time_t( time, tz );
+  return gmtime_r( &t, tm );
+}
+
+static struct tm *time_to_tm_local( time_t time, struct tm *tm )
+{
+  time_t t = time;
+  return localtime_r( &t, tm );
+}
+
+/**********************************************************
+  Fill in the localtime 'struct tm' for the supplied time,
+  and return the local tz.
+ */
+static int local_time_tzoffset( time_t t, struct tm *tm )
+{
+  time_t t_local;
+  int offset, eastwest;
+
+  localtime_r( &t, tm );
+  t_local = mktime( tm );
+  if( t_local == -1 )
+    return 0; /* error; just use +0000 */
+  if( t_local < t )
+  {
+    eastwest = -1;
+    offset = t - t_local;
+  }
+  else
+  {
+    eastwest = 1;
+    offset = t_local - t;
+  }
+  offset /= 60; /* in minutes */
+  offset = (offset % 60) + ((offset / 60) * 100);
+  return offset * eastwest;
+}
+
+static int local_tzoffset( time_t time )
+{
+  struct tm tm;
+  return local_time_tzoffset( time, &tm );
+}
+
+
+static void show_date_normal( struct strbuf *sb,
+                              time_t time, struct tm *tm, int tz,
+                              struct tm *human_tm, int human_tz, int local )
+{
+  struct
+  {
+    unsigned int year:1,
+                 date:1,
+                 wday:1,
+                 time:1,
+                 seconds:1,
+                 tz:1;
+  } hide = { 0 };
+
+  hide.tz = local || tz == human_tz;
+  hide.year = tm->tm_year == human_tm->tm_year;
+  if( hide.year )
+  {
+    if( tm->tm_mon == human_tm->tm_mon )
+    {
+      if( tm->tm_mday > human_tm->tm_mday )
+      {
+        /* Future date: think timezones */
+      }
+      else if( tm->tm_mday == human_tm->tm_mday )
+      {
+        hide.date = hide.wday = 1;
+      }
+      else if( tm->tm_mday + 5 > human_tm->tm_mday )
+      {
+        /* Leave just weekday if it was a few days ago */
+        hide.date = 1;
+      }
+    }
+  }
+
+  /* Show "today" times as just relative times */
+  if( hide.wday )
+  {
+    show_date_relative( sb, time );
+    return;
+  }
+
+  /******************************************************
+    Always hide seconds for human-readable.
+    Hide timezone if showing date.
+    Hide weekday and time if showing year.
+
+    The logic here is two-fold:
+     (a) only show details when recent enough to matter
+     (b) keep the maximum length "similar", and in check
+   ******************************************************/
+  if( human_tm->tm_year )
+  {
+    hide.seconds = 1;
+    hide.tz |= !hide.date;
+    hide.wday = hide.time = !hide.year;
+  }
+
+  if( !hide.wday )
+    strbuf_addf( sb, "%.3s ", weekday_names[tm->tm_wday] );
+  if( !hide.date )
+    strbuf_addf( sb, "%.3s %d ", month_names[tm->tm_mon], tm->tm_mday );
+
+  /* Do we want AM/PM depending on locale? */
+  if( !hide.time )
+  {
+    strbuf_addf( sb, "%02d:%02d", tm->tm_hour, tm->tm_min );
+    if( !hide.seconds )
+      strbuf_addf( sb, ":%02d", tm->tm_sec );
+  }
+  else
+    strbuf_rtrim( sb );
+
+  if( !hide.year )
+    strbuf_addf( sb, " %d", tm->tm_year + 1900 );
+
+  if( !hide.tz )
+    strbuf_addf( sb, " %+05d", tz );
+}
+
+void show_date( struct strbuf *sb, time_t t, int tz, const struct date_mode *mode )
+{
+  struct tm *tm;
+  struct tm  tmbuf = { 0 };
+  struct tm  human_tm = { 0 };
+  int        human_tz = -1;
+
+  if( mode->type == DATE_UNIX )
+  {
+    strbuf_addf( sb, "%"PRIdMAX, t );
+  }
+
+  if( mode->type == DATE_HUMAN )
+  {
+    time_t now = time( NULL );
+
+    /* Fill in the data for "current time" in human_tz and human_tm */
+    human_tz = local_time_tzoffset( now, &human_tm );
+  }
+
+  if( mode->local )
+    tz = local_tzoffset( t );
+
+  if( mode->type == DATE_RAW )
+  {
+    strbuf_addf( sb, "%"PRIdMAX" %+05d", t, tz );
+  }
+
+  if( mode->type == DATE_RELATIVE )
+  {
+    show_date_relative( sb, t );
+  }
+
+  if( mode->local )
+    tm = time_to_tm_local( t, &tmbuf );
+  else
+    tm = time_to_tm( t, tz, &tmbuf );
+  if (!tm) {
+    tm = time_to_tm( 0, 0, &tmbuf );
+    tz = 0;
+  }
+
+  if( mode->type == DATE_SHORT )
+    strbuf_addf( sb, "%04d-%02d-%02d", tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday );
+  else if( mode->type == DATE_ISO8601 )
+    strbuf_addf( sb, "%04d-%02d-%02d %02d:%02d:%02d %+05d",
+                      tm->tm_year + 1900,
+                      tm->tm_mon + 1,
+                      tm->tm_mday,
+                      tm->tm_hour, tm->tm_min, tm->tm_sec,
+                      tz );
+  else if( mode->type == DATE_ISO8601_STRICT )
+  {
+    char sign = (tz >= 0) ? '+' : '-';
+    tz = abs( tz );
+    strbuf_addf( sb, "%04d-%02d-%02dT%02d:%02d:%02d%c%02d:%02d",
+                      tm->tm_year + 1900,
+                      tm->tm_mon + 1,
+                      tm->tm_mday,
+                      tm->tm_hour, tm->tm_min, tm->tm_sec,
+                      sign, tz / 100, tz % 100 );
+  }
+  else if( mode->type == DATE_RFC2822 )
+    strbuf_addf( sb, "%.3s, %d %.3s %d %02d:%02d:%02d %+05d",
+                      weekday_names[tm->tm_wday], tm->tm_mday,
+                      month_names[tm->tm_mon], tm->tm_year + 1900,
+                      tm->tm_hour, tm->tm_min, tm->tm_sec, tz );
+  else
+    show_date_normal( sb, t, tm, tz, &human_tm, human_tz, mode->local );
+}
Index: csvn-ui-0.1.5/csvncgi/date.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/date.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/date.h	(revision 12)
@@ -0,0 +1,49 @@
+
+#ifndef    __DATE_H
+#define    __DATE_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+enum date_mode_type {
+  DATE_NORMAL = 0,
+  DATE_HUMAN,
+  DATE_RELATIVE,
+  DATE_SHORT,
+  DATE_ISO8601,
+  DATE_ISO8601_STRICT,
+  DATE_RFC2822,
+  DATE_RAW,
+  DATE_UNIX
+};
+
+struct date_mode {
+  enum date_mode_type type;
+  int local;
+};
+
+/*******************************************************
+  Convenience helper for passing a constant type, like:
+
+    show_date( t, tz, DATE_MODE(NORMAL) );
+ */
+#define DATE_MODE(t) date_mode_from_type(DATE_##t)
+struct date_mode *date_mode_from_type(enum date_mode_type type);
+
+
+/*
+  Parse data in the input TEXT, fill struct tm TM and return
+  UTC time_t. On error parse_data returns -1:
+ */
+extern time_t parse_date( struct tm *tm, const char *text );
+
+extern void show_date_relative( struct strbuf *sb, time_t t );
+extern void show_date( struct strbuf *sb, time_t t, int tz, const struct date_mode *mode );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __DATE_H */
Index: csvn-ui-0.1.5/csvncgi/dlist.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/dlist.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/dlist.c	(revision 12)
@@ -0,0 +1,691 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <dlist.h>
+
+
+#define DLIST_ERRMSG_SIZE 4096
+
+void dlist_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[DLIST_ERRMSG_SIZE];
+  char  msg[DLIST_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, DLIST_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, DLIST_ERRMSG_SIZE, format, "dlist", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+dlist_errfunc dlist_fatal = dlist_error;
+
+
+struct dlist *__dlist_alloc( void )
+{
+  struct dlist *list = NULL;
+
+  list = (struct dlist *)malloc( sizeof( struct dlist ) );
+  if( !list ) { dlist_fatal( "Cannot allocate memory" ); }
+
+  bzero( (void *)list, sizeof( struct dlist ) );
+
+  return list;
+}
+
+
+
+struct dlist *dlist_first( struct dlist *list )
+{
+  while( list && dlist_prev( list ) ) list = dlist_prev( list );
+
+  return list;
+}
+
+struct dlist *dlist_last( struct dlist *list )
+{
+  while( list && dlist_next( list ) ) list = dlist_next( list );
+
+  return list;
+}
+
+int dlist_length( struct dlist *list )
+{
+  int n = 0;
+
+  while( list )
+  {
+    list = dlist_next( list );
+    ++n;
+  }
+
+  return n;
+}
+
+struct dlist *dlist_nth( struct dlist *list, int n )
+{
+  while( list && (n-- > 0) )
+  {
+    list = dlist_next( list );
+  }
+
+  return list;
+}
+
+void *dlist_nth_data( struct dlist *list, int n )
+{
+  while( list && (n-- > 0) )
+  {
+    list = dlist_next( list );
+  }
+
+  return list ? list->data : NULL;
+}
+
+int dlist_position( struct dlist *list, struct dlist *link )
+{
+  int n = 0;
+
+  while( list )
+  {
+    if( list == link ) return n;
+    ++n;
+    list = dlist_next( list );
+  }
+
+  return -1;
+}
+
+int dlist_index( struct dlist *list, const void *data )
+{
+  int n = 0;
+
+  while( list )
+  {
+    if( list->data == data ) return n;
+    ++n;
+    list = dlist_next( list );
+  }
+
+  return -1;
+}
+
+struct dlist *dlist_find( struct dlist *list, const void *data )
+{
+  while( list )
+  {
+    if( list->data == data ) { break; }
+    list = dlist_next( list );
+  }
+
+  return list;
+}
+
+
+struct dlist *dlist_find_data( struct dlist *list, DLCMPF cmp_func, const void *data )
+{
+  if( !list || !cmp_func ) return NULL;
+
+  while( list )
+  {
+    if( ! cmp_func( list->data, data ) ) { return list; }
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+
+struct dlist *dlist_append( struct dlist *list, void *data )
+{
+  struct dlist *node = NULL;
+  struct dlist *last = NULL;
+
+  node = __dlist_alloc();
+  node->data = data;
+
+  if( list )
+  {
+    last = dlist_last( list );
+
+    dlist_next( last ) = node;
+    dlist_prev( node ) = last;
+
+    return list;
+  }
+
+  return node;
+}
+
+struct dlist *dlist_prepend( struct dlist *list, void *data )
+{
+  struct dlist *node  = NULL;
+  struct dlist *first = NULL;
+
+  node = __dlist_alloc();
+  node->data = data;
+
+  if( list )
+  {
+    first = dlist_first( list );
+
+    dlist_prev( first ) = node;
+    dlist_next( node )  = first;
+
+    return node;
+  }
+
+  return node;
+}
+
+struct dlist *dlist_insert( struct dlist *list, void *data, int position )
+{
+  struct dlist *node  = NULL;
+  struct dlist *ptr   = NULL;
+
+  if( position  < 0 ) { return dlist_append( list, data );  }
+  if( position == 0 ) { return dlist_prepend( list, data ); }
+
+  ptr = dlist_nth( list, position );
+  if( !ptr ) { return dlist_append( list, data ); }
+
+  node = __dlist_alloc();
+  node->data = data;
+
+  node->prev = ptr->prev;
+  ptr->prev->next = node;
+  node->next = ptr;
+  ptr->prev = node;
+
+  return list;
+}
+
+struct dlist *dlist_insert_sorted( struct dlist *list, DLCMPF cmp_func, void *data )
+{
+  struct dlist *node  = NULL;
+  struct dlist *ptr   = list;
+  int cmp;
+
+  if( !cmp_func ) return list;
+
+  if( !list )
+  {
+    node = __dlist_alloc();
+    node->data = data;
+    return node;
+  }
+
+  cmp = cmp_func( data, ptr->data );
+
+  while( (ptr->next) && (cmp > 0) )
+  {
+    ptr = ptr->next;
+    cmp = cmp_func( data, ptr->data );
+  }
+
+  node = __dlist_alloc();
+  node->data = data;
+
+  if( (!ptr->next) && (cmp > 0) )
+  {
+    ptr->next = node;
+    node->prev = ptr;
+    return list;
+  }
+
+  if( ptr->prev )
+  {
+    ptr->prev->next = node;
+    node->prev = ptr->prev;
+  }
+  node->next = ptr;
+  ptr->prev = node;
+
+  if( ptr == list )
+    return node;
+  else
+    return list;
+}
+
+struct dlist *dlist_insert_sorted_with_data( struct dlist *list, DLCMPDF cmp_func, void *data, void *user_data )
+{
+  struct dlist *node  = NULL;
+  struct dlist *ptr   = list;
+  int cmp;
+
+  if( !cmp_func ) return list;
+
+  if( !list )
+  {
+    node = __dlist_alloc();
+    node->data = data;
+    return node;
+  }
+
+  cmp = cmp_func( data, ptr->data, user_data );
+
+  while( (ptr->next) && (cmp > 0) )
+  {
+    ptr = ptr->next;
+    cmp = cmp_func( data, ptr->data, user_data );
+  }
+
+  node = __dlist_alloc();
+  node->data = data;
+
+  if( (!ptr->next) && (cmp > 0) )
+  {
+    ptr->next = node;
+    node->prev = ptr;
+    return list;
+  }
+
+  if( ptr->prev )
+  {
+    ptr->prev->next = node;
+    node->prev = ptr->prev;
+  }
+  node->next = ptr;
+  ptr->prev = node;
+
+  if( ptr == list )
+    return node;
+  else
+    return list;
+}
+
+struct dlist *dlist_concat( struct dlist *list1, struct dlist *list2 )
+{
+  struct dlist *ptr   = NULL;
+
+  if( list2 )
+  {
+    ptr = dlist_last( list1 );
+    if( ptr )
+      ptr->next = list2;
+    else
+      list1 = list2;
+
+    list2->prev = ptr;
+  }
+
+  return list1;
+}
+
+struct dlist *dlist_insert_list( struct dlist *list1, struct dlist *list2, int position )
+{
+  struct dlist *last  = NULL;
+  struct dlist *ptr   = NULL;
+
+  if( position  < 0 ) { return dlist_concat( list1, list2 ); }
+  if( position == 0 ) { return dlist_concat( list2, list1 ); }
+
+  ptr = dlist_nth( list1, position );
+  if( !ptr ) { return dlist_concat( list1, list2 ); }
+
+  last = dlist_last( list2 );
+  if( last )
+  {
+    list2->prev = ptr->prev;
+    ptr->prev->next = list2;
+    last->next = ptr;
+    ptr->prev = last;
+  }
+
+  return list1;
+}
+
+struct dlist *__dlist_remove_link( struct dlist *list, struct dlist *link )
+{
+  if( link == NULL ) return list;
+
+  if( link->prev )
+  {
+    if( link->prev->next == link )
+    {
+        link->prev->next = link->next;
+    }
+    else
+    {
+      dlist_fatal( "Corrupted double-linked list detected" );
+    }
+  }
+  if( link->next )
+  {
+    if( link->next->prev == link )
+    {
+      link->next->prev = link->prev;
+    }
+    else
+    {
+      dlist_fatal( "Corrupted double-linked list detected" );
+    }
+  }
+
+  if( link == list ) list = list->next;
+
+  link->next = NULL;
+  link->prev = NULL;
+
+  return list;
+}
+
+struct dlist *dlist_remove( struct dlist *list, const void *data )
+{
+  struct dlist *ptr = list;
+
+  while( ptr )
+  {
+    if( ptr->data != data )
+    {
+      ptr = ptr->next;
+    }
+    else
+    {
+      list = __dlist_remove_link( list, ptr );
+      free( ptr );
+
+      break;
+    }
+  }
+
+  return list;
+}
+
+struct dlist *dlist_remove_all( struct dlist *list, const void *data )
+{
+  struct dlist *ptr = list;
+
+  while( ptr )
+  {
+    if( ptr->data != data )
+    {
+      ptr = ptr->next;
+    }
+    else
+    {
+      struct dlist *next = ptr->next;
+
+      if( ptr->prev )
+        ptr->prev->next = next;
+      else
+        list = next;
+
+      if( next )
+        next->prev = ptr->prev;
+
+      free( ptr );
+
+      ptr = next;
+    }
+  }
+
+  return list;
+}
+
+struct dlist *dlist_remove_data( struct dlist *list, DLCMPF cmp_func, DLFUNC free_func, const void *data )
+{
+  struct dlist *ptr = list;
+
+  if( !cmp_func ) return list;
+
+  while( ptr )
+  {
+    if( cmp_func( ptr->data, data ) != 0 )
+    {
+      ptr = ptr->next;
+    }
+    else
+    {
+      list = __dlist_remove_link( list, ptr );
+      if( free_func ) free_func( ptr->data, (void *)data ); /* free_func() can compare pointers */
+      free( ptr );
+
+      break;
+    }
+  }
+
+  return list;
+}
+
+struct dlist *dlist_remove_data_all( struct dlist *list, DLCMPF cmp_func, DLFUNC free_func, const void *data )
+{
+  struct dlist *ptr = list;
+
+  if( !cmp_func ) return list;
+
+  while( ptr )
+  {
+    if( cmp_func( ptr->data, data ) != 0 )
+    {
+      ptr = ptr->next;
+    }
+    else
+    {
+      struct dlist *next = ptr->next;
+
+      if( ptr->prev )
+        ptr->prev->next = next;
+      else
+        list = next;
+
+      if( next )
+        next->prev = ptr->prev;
+
+      if( free_func ) free_func( ptr->data, (void *)data ); /* free_func() can compare pointers */
+      free( ptr );
+
+      ptr = next;
+    }
+  }
+
+  return list;
+}
+
+
+struct dlist *dlist_copy( struct dlist *list )
+{
+  struct dlist *copy = NULL;
+
+  while( list )
+  {
+    copy = dlist_append( copy, list->data );
+    list = dlist_next( list );
+  }
+
+  return copy;
+}
+
+/* It simply switches the next and prev pointers of each element. */
+struct dlist *dlist_reverse( struct dlist *list )
+{
+  struct dlist *last = NULL;
+
+  while( list )
+  {
+    last = list;
+    list = last->next;
+    last->next = last->prev;
+    last->prev = list;
+  }
+
+  return last;
+}
+
+
+static struct dlist *__dlist_sort_merge( struct dlist *l1, struct dlist *l2, DLCMPF cmp_func )
+{
+  struct dlist list, *l, *lprev;
+  int   cmp;
+
+  l = &list; 
+  lprev = NULL;
+
+  while( l1 && l2 )
+  {
+    cmp = ((DLCMPF) cmp_func)( l1->data, l2->data );
+
+    if( cmp <= 0 )
+    {
+      l->next = l1;
+      l1 = l1->next;
+    }
+    else
+    {
+      l->next = l2;
+      l2 = l2->next;
+    }
+    l = l->next;
+    l->prev = lprev; 
+    lprev = l;
+  }
+  l->next = l1 ? l1 : l2;
+  l->next->prev = l;
+
+  return list.next;
+}
+
+static struct dlist *__dlist_sort_merge_with_data( struct dlist *l1, struct dlist *l2, DLCMPDF cmp_func, void *user_data )
+{
+  struct dlist list, *l, *lprev;
+  int   cmp;
+
+  l = &list; 
+  lprev = NULL;
+
+  while( l1 && l2 )
+  {
+    cmp = ((DLCMPDF) cmp_func)( l1->data, l2->data, user_data );
+
+    if( cmp <= 0 )
+    {
+      l->next = l1;
+      l1 = l1->next;
+    }
+    else
+    {
+      l->next = l2;
+      l2 = l2->next;
+    }
+    l = l->next;
+    l->prev = lprev; 
+    lprev = l;
+  }
+  l->next = l1 ? l1 : l2;
+  l->next->prev = l;
+
+  return list.next;
+}
+
+
+static struct dlist *__dlist_sort_real( struct dlist *list, DLCMPF cmp_func )
+{
+  struct dlist *l1, *l2;
+
+  if( !list )
+    return NULL;
+  if( !list->next )
+    return list;
+
+  l1 = list; 
+  l2 = list->next;
+
+  while( (l2 = l2->next) != NULL )
+  {
+    if( (l2 = l2->next) == NULL )
+      break;
+    l1 = l1->next;
+  }
+  l2 = l1->next;
+  l1->next = NULL;
+
+  return __dlist_sort_merge( __dlist_sort_real( list, cmp_func ),
+                             __dlist_sort_real( l2, cmp_func ),
+                             cmp_func );
+}
+
+static struct dlist *__dlist_sort_real_with_data( struct dlist *list, DLCMPDF cmp_func, void *user_data )
+{
+  struct dlist *l1, *l2;
+
+  if( !list )
+    return NULL;
+  if( !list->next )
+    return list;
+
+  l1 = list; 
+  l2 = list->next;
+
+  while( (l2 = l2->next) != NULL )
+  {
+    if( (l2 = l2->next) == NULL )
+      break;
+    l1 = l1->next;
+  }
+  l2 = l1->next;
+  l1->next = NULL;
+
+  return __dlist_sort_merge_with_data( __dlist_sort_real_with_data( list, cmp_func, user_data ),
+                                       __dlist_sort_real_with_data( l2, cmp_func, user_data ),
+                                       cmp_func,
+                                       user_data );
+}
+
+
+struct dlist *dlist_sort( struct dlist *list, DLCMPF cmp_func )
+{
+  return __dlist_sort_real( list, cmp_func );
+}
+
+struct dlist *dlist_sort_with_data( struct dlist *list, DLCMPDF cmp_func, void *user_data )
+{
+  return __dlist_sort_real_with_data( list, cmp_func, user_data );
+}
+
+
+void dlist_foreach( struct dlist *list, DLFUNC func, void *user_data )
+{
+  struct dlist *next = NULL;
+
+  while( list )
+  {
+    next = dlist_next( list );
+    if( func ) { func( list->data, user_data ); }
+    list = next;
+  }
+}
+
+
+void __dlist_free( struct dlist *list )
+{
+  struct dlist *next = NULL;
+
+  while( list )
+  {
+    next = dlist_next( list );
+    free( list ); list = NULL;
+    list = next;
+  }
+}
+
+void dlist_free( struct dlist *list, DLFUNC free_func )
+{
+  dlist_foreach( list, free_func, NULL );
+  __dlist_free( list );
+}
Index: csvn-ui-0.1.5/csvncgi/dlist.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/dlist.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/dlist.h	(revision 12)
@@ -0,0 +1,71 @@
+
+#ifndef __DLIST_H_
+#define __DLIST_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef void (*dlist_errfunc)( const char *fmt, ... );
+
+extern void dlist_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern dlist_errfunc dlist_fatal; /* Default Fatal Error Function == dlist_error() */
+
+struct dlist {
+  struct dlist *prev;
+  struct dlist *next;
+
+  void  *data;
+};
+
+typedef void (*DLFUNC)  ( void *data, void *user_data );
+typedef int  (*DLCMPF)  ( const void *a, const void *b );
+typedef int  (*DLCMPDF) ( const void *a, const void *b, void *user_data );
+
+#define dlist_prev( list )  ( (list)->prev )
+#define dlist_next( list )  ( (list)->next )
+
+extern struct dlist *__dlist_alloc( void );
+extern struct dlist *dlist_first( struct dlist *list );
+extern struct dlist *dlist_last( struct dlist *list );
+extern int dlist_length( struct dlist *list );
+extern struct dlist *dlist_nth( struct dlist *list, int n );
+extern void *dlist_nth_data( struct dlist *list, int n );
+extern int dlist_position( struct dlist *list, struct dlist *link );
+extern int dlist_index( struct dlist *list, const void *data );
+extern struct dlist *dlist_find( struct dlist *list, const void *data );
+extern struct dlist *dlist_find_data( struct dlist *list, DLCMPF func, const void *data );
+
+extern struct dlist *dlist_append( struct dlist *list, void *data );
+extern struct dlist *dlist_prepend( struct dlist *list, void *data );
+extern struct dlist *dlist_insert( struct dlist *list, void *data, int position );
+extern struct dlist *dlist_insert_sorted( struct dlist *list, DLCMPF cmp_func, void *data );
+extern struct dlist *dlist_insert_sorted_with_data( struct dlist *list, DLCMPDF cmp_func, void *data, void *user_data );
+extern struct dlist *dlist_concat( struct dlist *list1, struct dlist *list2 );
+extern struct dlist *dlist_insert_list( struct dlist *list1, struct dlist *list2, int position );
+
+extern struct dlist *__dlist_remove_link( struct dlist *list, struct dlist *link );
+extern struct dlist *dlist_remove( struct dlist *list, const void *data );
+extern struct dlist *dlist_remove_all( struct dlist *list, const void *data );
+extern struct dlist *dlist_remove_data( struct dlist *list, DLCMPF cmp_func, DLFUNC free_func, const void *data );
+extern struct dlist *dlist_remove_data_all( struct dlist *list, DLCMPF cmp_func, DLFUNC free_func, const void *data );
+
+extern struct dlist *dlist_copy( struct dlist *list );
+extern struct dlist *dlist_reverse( struct dlist *list );
+
+extern struct dlist *dlist_sort( struct dlist *list, DLCMPF cmp_func );
+extern struct dlist *dlist_sort_with_data( struct dlist *list, DLCMPDF cmp_func, void *user_data );
+
+extern void dlist_foreach( struct dlist *list, DLFUNC func, void *user_data );
+
+
+extern void __dlist_free( struct dlist *list );
+extern void dlist_free( struct dlist *list, DLFUNC free_func );
+
+
+#ifdef __cplusplus
+}  /* ... extern "C" */
+#endif
+
+#endif /* __DLIST_H_ */
Index: csvn-ui-0.1.5/csvncgi/fatal.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/fatal.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/fatal.c	(revision 12)
@@ -0,0 +1,179 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <defs.h>
+#include <fatal.h>
+#include <http.h>
+
+
+void fatal( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[HTTP_ERRMSG_SIZE];
+  char  msg[HTTP_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, HTTP_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, HTTP_ERRMSG_SIZE, format, PROGRAM_CGI, msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+void fatal_json( const char *fmt, ... )
+{
+  va_list arg_ptr;
+
+  char  resp[HTTP_ERRMSG_SIZE];
+  char  json[HTTP_ERRMSG_SIZE];
+  char   msg[HTTP_ERRMSG_SIZE];
+
+  char *http_format = "Status: 500 Internal Server Error\n"
+                      "Date: %s\n"
+                      "Cache-Control: no-cache, no-store\n"
+                      "Content-Type: application/json\n"
+                      "Content-Length: %d\n\n"
+                      "%s";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, HTTP_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( json, HTTP_ERRMSG_SIZE, "{\"error\":\"500\",\"description\":\"Internal Server Error\",\"message\":\"%s: %s\"}", PROGRAM_CGI, msg );
+
+  snprintf( resp, HTTP_ERRMSG_SIZE, http_format,
+            http_date( time(NULL) ), strlen( json ), json );
+
+  (void)write( STDOUT_FILENO, resp, strlen( resp ) );
+
+  exit( 1 );
+}
+
+void fatal_html( const char *fmt, ... )
+{
+  va_list arg_ptr;
+
+  char  resp[HTTP_ERRMSG_SIZE];
+  char  html[HTTP_ERRMSG_SIZE];
+  char   msg[HTTP_ERRMSG_SIZE];
+
+  char *http_format = "Status: 500 Internal Server Error\n"
+                      "Date: %s\n"
+                      "Cache-Control: no-cache, no-store\n"
+                      "Content-Type: text/html; charset=utf-8\n"
+                      "Content-Length: %d\n\n"
+                      "%s";
+
+  char *html_format =
+    "<!DOCTYPE html>\n"
+    "<html lang=\"en-US\">\n"
+    "  <head>\n"
+    "    <meta charset=\"utf-8\">\n"
+    "    <!--[if IE]><meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge,chrome=1\"><![endif]-->\n"
+    "    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n"
+    "    <title>HTTP/%s 500 Internal Server Error</title>\n"
+    "    <style>\n"
+    "      body {\n"
+    "        min-width: 460px;\n"
+    "      }\n"
+    "      .csvn-internal-server-error {\n"
+    "        margin: 48px auto;\n"
+    "        padding: 24px 48px 28px 48px;\n"
+    "        width: 70%%;\n"
+    "        color: #fff;\n"
+    "        background: #db2828;\n"
+    "        box-shadow: 3px 3px 10px rgba(0,0,0,0.5);\n"
+    "        border-radius: 4px;\n"
+    "      }\n"
+    "      .csvn-internal-server-error h1 {\n"
+    "        margin-bottom: 2px;\n"
+    "        font-family: sans-serif;\n"
+    "        font-size: 28px;\n"
+    "      }\n"
+    "      .csvn-internal-server-error p.http-date {\n"
+    "        margin-top: 2px;\n"
+    "        padding-left: 0px 0px 12px 0px;\n"
+    "        color: #fc0;\n"
+    "        font-family: monospace;\n"
+    "        font-size: 18px;\n"
+    "      }\n"
+    "      .csvn-internal-server-error p {\n"
+    "        padding-left: 1px;\n"
+    "        font-family: monospace;\n"
+    "        font-size: 14px;\n"
+    "      }\n"
+    "      @media screen and (max-width: 680px) {\n"
+    "        .csvn-internal-server-error {\n"
+    "          padding: 24px 28px 24px 28px;\n"
+    "          width: 80%%;\n"
+    "        }\n"
+    "        .csvn-internal-server-error h1 {\n"
+    "          font-size: 22px;\n"
+    "        }\n"
+    "        .csvn-internal-server-error p.http-date {\n"
+    "          font-size: 16px;\n"
+    "        }\n"
+    "        .csvn-internal-server-error p {\n"
+    "          font-size: 12px;\n"
+    "        }\n"
+    "      }\n"
+    "    </style>\n"
+    "  </head>\n"
+    "  <body>\n"
+    "    <div class=\"csvn-internal-server-error\">\n"
+    "      <h1>HTTP/%s 500 Internal Server Error</h1>\n"
+    "      <p class=\"http-date\">Date: %s</p>\n"
+    "      <p>%s: %s</p>\n"
+    "    </div>\n"
+    "  </body>\n"
+    "</html>\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, HTTP_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( html, HTTP_ERRMSG_SIZE, html_format,
+            HTTP_VERSION, HTTP_VERSION,
+            http_date( time(NULL) ), PROGRAM_CGI, msg );
+
+  snprintf( resp, HTTP_ERRMSG_SIZE, http_format,
+            http_date( time(NULL) ), strlen( html ), html );
+
+  (void)write( STDOUT_FILENO, resp, strlen( resp ) );
+
+  exit( 1 );
+}
Index: csvn-ui-0.1.5/csvncgi/fatal.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/fatal.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/fatal.h	(revision 12)
@@ -0,0 +1,22 @@
+
+#ifndef    __FATAL_H
+#define    __FATAL_H
+
+#define HTTP_ERRMSG_SIZE  4096
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void fatal( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+
+extern void fatal_json( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern void fatal_html( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __FATAL_H */
Index: csvn-ui-0.1.5/csvncgi/html.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/html.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/html.c	(revision 12)
@@ -0,0 +1,81 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <defs.h>
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+#include <strbuf.h>
+
+
+#define HTML_ERRMSG_SIZE 4096
+
+void html_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[HTML_ERRMSG_SIZE];
+  char  msg[HTML_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, HTML_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, HTML_ERRMSG_SIZE, format, "http", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+html_errfunc html_fatal = html_error;
+
+
+void html_raw( const char *data, size_t size )
+{
+  if( write( STDOUT_FILENO, data, size ) != size )
+    html_fatal( "write error on html output" );
+}
+
+void html( const char *txt )
+{
+  html_raw( txt, strlen(txt) );
+}
+
+void htmlf( const char *format, ... )
+{
+  va_list args;
+  struct strbuf buf = STRBUF_INIT;
+
+  va_start( args, format );
+  strbuf_vaddf( &buf, format, args );
+  va_end( args );
+  html( buf.buf );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/html.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/html.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/html.h	(revision 12)
@@ -0,0 +1,25 @@
+
+#ifndef    __HTML_H
+#define    __HTML_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef void (*html_errfunc)( const char *fmt, ... );
+
+extern void html_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern html_errfunc html_fatal; /* Default Fatal Error Function == html_error() */
+
+
+extern void html_raw( const char *data, size_t size );
+extern void html( const char *txt );
+extern void htmlf( const char *format, ... ) __attribute__((format (printf,1,2)));
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __HTML_H */
Index: csvn-ui-0.1.5/csvncgi/http.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/http.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/http.c	(revision 12)
@@ -0,0 +1,298 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <defs.h>
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+#include <strbuf.h>
+
+
+const signed char hexval_table[256] = {
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 00-07 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 08-0f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 10-17 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 18-1f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 20-27 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 28-2f */
+   0,  1,  2,  3,  4,  5,  6,  7,  /* 30-37 */
+   8,  9, -1, -1, -1, -1, -1, -1,  /* 38-3f */
+  -1, 10, 11, 12, 13, 14, 15, -1,  /* 40-47 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 48-4f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 50-57 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 58-5f */
+  -1, 10, 11, 12, 13, 14, 15, -1,  /* 60-67 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 68-67 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 70-77 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 78-7f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 80-87 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 88-8f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 90-97 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* 98-9f */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* a0-a7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* a8-af */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* b0-b7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* b8-bf */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* c0-c7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* c8-cf */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* d0-d7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* d8-df */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* e0-e7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* e8-ef */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* f0-f7 */
+  -1, -1, -1, -1, -1, -1, -1, -1,  /* f8-ff */
+};
+
+
+static char *
+url_decode_internal( const char **query, int len,
+                     const char *stop_at, struct strbuf *out,
+                     int decode_plus )
+{
+  const char *q = *query;
+
+  while( len )
+  {
+    unsigned char c = *q;
+
+    if( !c )
+      break;
+    if( stop_at && strchr( stop_at, c ) )
+    {
+      ++q;
+      --len;
+      break;
+    }
+
+    if( c == '%' && (len < 0 || len >= 3) )
+    {
+      int val = hex2chr( q + 1 );
+      if( 0 < val )
+      {
+        strbuf_addch( out, val );
+        q += 3;
+        len -= 3;
+        continue;
+      }
+    }
+
+    if( decode_plus && c == '+' )
+      strbuf_addch( out, ' ' );
+    else
+      strbuf_addch( out, c );
+    ++q;
+    --len;
+  }
+  *query = q;
+
+  return strbuf_detach( out, NULL );
+}
+
+char *url_decode_mem( const char *url, int len )
+{
+  struct strbuf out = STRBUF_INIT;
+  const char *colon = memchr( url, ':', len );
+
+  /* Skip protocol part if present */
+  if( colon && url < colon )
+  {
+    strbuf_add( &out, url, colon - url );
+    len -= colon - url;
+    url = colon;
+  }
+  return url_decode_internal( &url, len, NULL, &out, 0 );
+}
+
+char *url_percent_decode( const char *encoded )
+{
+  struct strbuf out = STRBUF_INIT;
+  return url_decode_internal( &encoded, strlen(encoded), NULL, &out, 0 );
+}
+
+char *url_decode_parameter_name( const char **query )
+{
+  struct strbuf out = STRBUF_INIT;
+  return url_decode_internal( query, -1, "&=", &out, 1 );
+}
+
+char *url_decode_parameter_value( const char **query )
+{
+  struct strbuf out = STRBUF_INIT;
+  return url_decode_internal( query, -1, "&", &out, 1 );
+}
+
+void http_parse_querystring( const char *txt, void (*fn)(const char *name, const char *value) )
+{
+  const char *t = txt;
+
+  while( t && *t )
+  {
+    char *name = url_decode_parameter_name( &t );
+    if( *name )
+    {
+      char *value = url_decode_parameter_value( &t );
+      fn( name, value );
+      free( value );
+    }
+    free( name );
+  }
+}
+
+
+
+#define HTTP_ERRMSG_SIZE 4096
+
+void http_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[HTTP_ERRMSG_SIZE];
+  char  msg[HTTP_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, HTTP_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, HTTP_ERRMSG_SIZE, format, "http", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+http_errfunc http_fatal = http_error;
+
+
+static struct
+{
+  int         code;
+  const char *desc;
+}
+status[] =
+{
+  { 100, "Continue" },
+  { 101, "Switching Protocols" },
+  { 200, "OK" },
+  { 201, "Created" },
+  { 202, "Accepted" },
+  { 203, "Non-Authoritative Information" },
+  { 204, "No Content" },
+  { 205, "Reset Content" },
+  { 206, "Partial Content" },
+  { 300, "Multiple Choices" },
+  { 301, "Moved Permanently" },
+  { 302, "Found" },
+  { 303, "See Other" },
+  { 304, "Not Modified" },
+  { 305, "Use Proxy" },
+  { 307, "Temporary Redirect" },
+  { 400, "Bad Request" },
+  { 401, "Unauthorized" },
+  { 402, "Payment Required" },
+  { 403, "Forbidden" },
+  { 404, "Not Found" },
+  { 405, "Method Not Allowed" },
+  { 406, "Not Acceptable" },
+  { 407, "Proxy Authentication Required" },
+  { 408, "Request Timeout" },
+  { 409, "Conflict" },
+  { 410, "Gone" },
+  { 411, "Length Required" },
+  { 412, "Precondition Failed" },
+  { 413, "Request Entity Too Large" },
+  { 414, "Request-URI Too Long" },
+  { 415, "Unsupported Media Type" },
+  { 416, "Requested Range Not Satisfiable" },
+  { 417, "Expectation Failed" },
+  { 418, "I'm a teapot" },
+  { 500, "Internal Server Error" },
+  { 501, "Not Implemented" },
+  { 502, "Bad Gateway" },
+  { 503, "Service Unavailable" },
+  { 504, "Gateway Timeout" },
+  { 505, "HTTP Version Not Supported" },
+  {   0, NULL }
+};
+
+const char *http_status( int status_code )
+{
+  int i = 0, code;
+
+  while( (code = status[i].code) )
+  {
+    if( code == status_code ) return status[i].desc;
+    ++i;
+  }
+  return NULL;
+}
+
+char *fmt( const char *format, ... )
+{
+  static char buf[8][1024];
+  static int bufidx;
+  int len;
+  va_list args;
+
+  bufidx++;
+  bufidx &= 7;
+
+  va_start( args, format );
+  len = vsnprintf( buf[bufidx], sizeof(buf[bufidx]), format, args );
+  va_end(args);
+  if( len > sizeof(buf[bufidx]) ) {
+    http_fatal( "string truncated: %s", format );
+  }
+  return buf[bufidx];
+}
+
+char *fmtalloc( const char *format, ... )
+{
+  struct strbuf sb = STRBUF_INIT;
+  va_list args;
+
+  va_start( args, format );
+  strbuf_vaddf( &sb, format, args );
+  va_end( args );
+
+  return strbuf_detach( &sb, NULL );
+}
+
+
+char *http_date( time_t t )
+{
+  static char day[][4] =
+    { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
+  static char month[][4] =
+    { "Jan", "Feb", "Mar", "Apr", "May", "Jun",
+      "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" };
+  struct tm *tm = gmtime(&t);
+  return fmt( "%s, %02d %s %04d %02d:%02d:%02d GMT", day[tm->tm_wday],
+              tm->tm_mday, month[tm->tm_mon], 1900 + tm->tm_year,
+              tm->tm_hour, tm->tm_min, tm->tm_sec );
+}
Index: csvn-ui-0.1.5/csvncgi/http.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/http.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/http.h	(revision 12)
@@ -0,0 +1,52 @@
+
+#ifndef    __HTTP_H
+#define    __HTTP_H
+
+#define HTTP_VERSION  "2"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef void (*http_errfunc)( const char *fmt, ... );
+
+extern void http_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern http_errfunc http_fatal; /* Default Fatal Error Function == http_error() */
+
+
+extern const signed char hexval_table[256];
+static inline unsigned int hexval( unsigned char c )
+{
+  return hexval_table[c];
+}
+/*******************************************************************
+  Convert two consecutive hexadecimal digits into a char. Return a
+  negative value on error. Don't run over the end of short strings.
+ */
+static inline int hex2chr( const char *s )
+{
+  unsigned int val = hexval(s[0]);
+  return (val & ~0xf) ? val : (val << 4) | hexval(s[1]);
+}
+
+extern char *url_decode_mem( const char *url, int len );
+extern char *url_percent_decode( const char *encoded );
+extern char *url_decode_parameter_name( const char **query );
+extern char *url_decode_parameter_value( const char **query );
+extern void http_parse_querystring( const char *txt, void (*fn)(const char *name, const char *value) );
+
+
+extern char *fmt( const char *format,... ) __attribute__((format (printf,1,2)));
+extern char *fmtalloc( const char *format,... ) __attribute__((format (printf,1,2)));
+
+
+extern char *http_date( time_t t );
+extern const char *http_status( int status_code );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __HTTP_H */
Index: csvn-ui-0.1.5/csvncgi/repolist.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/repolist.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/repolist.c	(revision 12)
@@ -0,0 +1,878 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <defs.h>
+#include <cscm/bcf.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+
+
+#define RLIST_ERRMSG_SIZE 4096
+
+void rlist_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[RLIST_ERRMSG_SIZE];
+  char  msg[RLIST_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, RLIST_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, RLIST_ERRMSG_SIZE, format, "rlist", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+rlist_errfunc rlist_fatal = rlist_error;
+
+
+struct dlist *config = NULL;
+
+static void *bcf = NULL;
+
+static size_t read_bcf( void )
+{
+  int fd;
+  struct stat st;
+  void *addr;
+
+  fd = shm_open( CSVN_SHM_BCF, O_RDONLY, S_IRUSR | S_IWUSR );
+  if( fd == -1 )
+  {
+    rlist_fatal( "Canot open SHM/%s data", "csvn.bcf" );
+    return 0;
+  }
+  if( !fstat( fd, (struct stat *)&st ) )
+  {
+    addr = mmap( NULL, (size_t)st.st_size, PROT_READ, MAP_SHARED, fd, 0 );
+    if( addr != MAP_FAILED )
+    {
+      bcf = malloc( (size_t)st.st_size );
+      if( !bcf )
+      {
+        (void)munmap( addr, (size_t)st.st_size );
+        rlist_fatal( "Canot allocate memory for SHM/%s data", "csvn.bcf" );
+        return 0;
+      }
+      memcpy( bcf, addr, (size_t)st.st_size );
+      (void)munmap( addr, (size_t)st.st_size );
+      return (size_t)st.st_size;
+    }
+    else
+    {
+      rlist_fatal( "Canot mmap SHM/%s data", "csvn.bcf" );
+      return 0;
+    }
+  }
+  else
+  {
+    rlist_fatal( "Canot stat SHM/%s data", "csvn.bcf" );
+    return 0;
+  }
+}
+
+
+static void check_bcf_ident( const void *bf, size_t size )
+{
+  Bcf32_fhdr *fhdr = (Bcf32_fhdr *)bf;
+
+  if( !fhdr )
+    rlist_fatal( "Invalid address of SHM/%s data", "csvn.bcf" );
+
+  if( (size_t)fhdr->b_fsize != size )
+    rlist_fatal( "Binary Config SHM/%s: invalid size", "csvn.bcf" );
+  if( memcmp( fhdr->b_ident, BCFMAG, (size_t)SZBCFMAG ) )
+    rlist_fatal( "Binary Config SHM/%s: invalid MAGIC number", "csvn.bcf" );
+  if( fhdr->b_ident[BI_CLASS] != BCF_CLASS_32 )
+    rlist_fatal( "Binary Config SHM/%s: invalid objects class", "csvn.bcf" );
+#if __BYTE_ORDER == __LITTLE_ENDIAN
+  if( fhdr->b_ident[BI_DATA] != BCF_DATA_LSB )
+    rlist_fatal( "Binary Config SHM/%s: invalid byte-order", "csvn.bcf" );
+#else
+  if( fhdr->b_ident[BI_DATA] != BCF_DATA_MSB )
+    rlist_fatal( "Binary Config SHM/%s: invalid byte-order", "csvn.bcf" );
+#endif
+  if( fhdr->b_ident[BI_VERSION] != BV_CURRENT )
+    rlist_fatal( "Binary Config SHM/%s: invalid version", "csvn.bcf" );
+}
+
+
+/***************************************************************
+  Print config file functions:
+ */
+static void __print_global_variable( void *data, void *user_data )
+{
+  struct variable *variable = (struct variable *)data;
+  struct strbuf   *sb   = (struct strbuf *)user_data;
+
+  if( !variable || !sb ) return;
+
+  switch( variable->type )
+  {
+    case DT_NUMERICAL:
+      strbuf_addf( sb, "  %s = %d;\n", variable->name, variable->_v.val );
+      break;
+    case DT_PATH:
+      strbuf_addf( sb, "  %s = '%s';\n", variable->name, variable->_v.vptr );
+      break;
+    case DT_STRING:
+      strbuf_addf( sb, "  %s = \"%s\";\n", variable->name, variable->_v.vptr );
+      break;
+    default:
+      break;
+  }
+}
+
+static void print_global_variables( struct strbuf *sb, struct dlist *list )
+{
+  if( list ) { dlist_foreach( list, __print_global_variable, (void *)sb ); }
+}
+
+static void __print_repo_variable( void *data, void *user_data )
+{
+  struct variable *variable = (struct variable *)data;
+  struct strbuf   *sb   = (struct strbuf *)user_data;
+
+  if( !variable || !sb ) return;
+
+  switch( variable->type )
+  {
+    case DT_NUMERICAL:
+      strbuf_addf( sb, "    %s = %d;\n", variable->name, variable->_v.val );
+      break;
+    case DT_PATH:
+      strbuf_addf( sb, "    %s = '%s';\n", variable->name, variable->_v.vptr );
+      break;
+    case DT_STRING:
+      strbuf_addf( sb, "    %s = \"%s\";\n", variable->name, variable->_v.vptr );
+      break;
+    default:
+      break;
+  }
+}
+
+static void print_repo_variables( struct strbuf *sb, struct dlist *list )
+{
+  if( list ) { dlist_foreach( list, __print_repo_variable, (void *)sb ); }
+}
+
+static void __print_repo( void *data, void *user_data )
+{
+  struct repo   *repo = (struct repo *)data;
+  struct strbuf *sb   = (struct strbuf *)user_data;
+
+  if( !repo || !sb ) return;
+
+  strbuf_addf( sb, "  repo '%s' {\n", repo->path );
+  if( repo->list )
+  {
+    print_repo_variables( sb, repo->list );
+  }
+  strbuf_addf( sb, "  }\n\n" );
+}
+
+static void print_repos( struct strbuf *sb, struct dlist *list )
+{
+  if( list ) { dlist_foreach( list, __print_repo, (void *)sb ); }
+}
+
+static void __print_section( void *data, void *user_data )
+{
+  struct section *section = (struct section *)data;
+  struct strbuf  *sb      = (struct strbuf *)user_data;
+
+  if( !section || !sb ) return;
+
+  if( section->list )
+  {
+    if( section->type == ST_REPOS )
+    {
+      strbuf_addf( sb, "section \"%s\" {\n\n", section->name );
+      print_repos( sb, section->list );
+      strbuf_addf( sb, "}\n\n" );
+    }
+    else if( section->type == ST_GLOBAL )
+    {
+      strbuf_addf( sb, "section \".global\" {\n" );
+      print_global_variables( sb, section->list );
+      strbuf_addf( sb, "}\n\n" );
+    }
+  }
+}
+
+void print_config( struct strbuf *sb, struct dlist *list )
+{
+  strbuf_addf( sb, "<pre><code class='language-C'>\n" );
+  strbuf_addf( sb, "/*******************************************************\n" );
+  strbuf_addf( sb, "  Global variables are propagate into repo sections but\n" );
+  strbuf_addf( sb, "  their values overrides by correspond repo variables.\n" );
+  strbuf_addf( sb, " */\n\n" );
+  if( list ) { dlist_foreach( list, __print_section, (void *)sb ); }
+  strbuf_addf( sb, "</code></pre>\n" );
+}
+/*
+  End of print config file functions.
+ ***************************************************************/
+
+
+/**************************
+  lookup variable in repo:
+ */
+static int __compare_variables_by_name( const void *a, const void *b )
+{
+  struct variable *va = (struct variable *)a;
+  struct variable *vb = (struct variable *)b;
+
+  if( !va || !vb ) return -1;
+
+  return strcmp( (const char *)va->name, (const char *)vb->name );
+}
+
+struct variable *lookup( struct repo *repo, struct variable *variable )
+{
+  struct dlist *found = NULL;
+
+  if( !repo || !repo->list ) return NULL;
+
+  found = dlist_find_data( repo->list, __compare_variables_by_name, (const void *)variable );
+  if( found )
+    return (struct variable *)(found->data);
+  return NULL;
+}
+
+struct variable *lookup_global( struct section *section, struct variable *variable )
+{
+  struct dlist *found = NULL;
+
+  if( !section || !section->list ) return NULL;
+
+  found = dlist_find_data( section->list, __compare_variables_by_name, (const void *)variable );
+  if( found )
+    return (struct variable *)(found->data);
+  return NULL;
+}
+
+/**************
+  lookup repo:
+ */
+struct repo *lookup_repo( struct dlist *config, const char *path )
+{
+  struct dlist *list = NULL;
+
+  if( !config || !path ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        struct repo *repo = (struct repo *)rlist->data;
+        if( !strcmp( (const char *)repo->path, path ) )
+          return repo;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+/*****************
+  lookup section:
+ */
+struct section *lookup_section( struct dlist *config, const char *name )
+{
+  struct dlist *list = NULL;
+
+  if( !config || !name ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section && section->type == ST_REPOS && !strcmp( (const char *)section->name, name ) )
+        return section;
+
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+/************************
+  lookup global section:
+ */
+struct section *lookup_global_section( struct dlist *config )
+{
+  struct dlist *list = NULL;
+
+  if( !config ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section && section->type == ST_GLOBAL )
+        return section;
+
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+/******************
+  repolist length:
+ */
+int repolist_length( struct dlist *config )
+{
+  struct dlist *list = NULL;
+  int length = 0;
+
+  if( !config ) return length;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        ++length;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return length;
+}
+
+/***************
+  repolist nth:
+ */
+struct repo *repolist_nth( struct dlist *config, int n )
+{
+  struct dlist *list = NULL;
+  int length = 0;
+
+  if( !config || n < 0 ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        if( length == n )
+        {
+          struct repo *repo = (struct repo *)rlist->data;
+          return repo;
+        }
+        ++length;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+/**************************
+  repo position in config:
+ */
+int repo_position( struct dlist *config, struct repo *repo )
+{
+  struct dlist *list = NULL;
+  int position = -1;
+
+  if( !config || !repo ) return position;
+
+  position = 0;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        if( (struct repo *)rlist->data == repo )
+        {
+          return position;
+        }
+        ++position;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return -1;
+}
+
+
+/**************************************
+  parent section node of repolist nth:
+ */
+struct dlist *parent_section_node_repolist_nth( struct dlist *config, int n )
+{
+  struct dlist *list = NULL;
+  int length = 0;
+
+  if( !config || n < 0 ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        if( length == n )
+        {
+          return list;
+        }
+        ++length;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+/************************************
+  parent rlist node of repolist nth:
+ */
+struct dlist *parent_rlist_node_repolist_nth( struct dlist *config, int n )
+{
+  struct dlist *list = NULL;
+  int length = 0;
+
+  if( !config || n < 0 ) return NULL;
+
+  list = config;
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        if( length == n )
+        {
+          return rlist;
+        }
+        ++length;
+        rlist = dlist_next( rlist );
+      }
+    }
+    list = dlist_next( list );
+  }
+
+  return NULL;
+}
+
+
+
+/**********************************************
+  Provide all global variables into each repo
+  if that variable is not present in the repo:
+ */
+static void __provide_foreach_data( void *data, void *user_data )
+{
+  struct variable *variable = (struct variable *)data;
+  struct repo     *repo     = (struct repo *)user_data;
+
+  if( !repo || !variable ) return;
+
+  if( !lookup( repo, variable ) )
+  {
+    struct variable *var = (struct variable *)xmalloc( sizeof(struct variable) );
+    memcpy( (void *)var, (void *)variable, sizeof(struct variable) );
+    repo->list = dlist_append( repo->list, (void *)var );
+  }
+}
+
+static void __provide_foreach_repos( void *data, void *user_data )
+{
+  struct section *global = (struct section *)user_data;
+
+  if( !global || !global->list ) return;
+
+  dlist_foreach( global->list, __provide_foreach_data, data );
+}
+
+static void __provide_foreach_sections( void *data, void *user_data )
+{
+  struct section *section = (struct section *)data;
+  if( !section || section->type == ST_GLOBAL || !section->list ) return;
+
+  dlist_foreach( section->list, __provide_foreach_repos, user_data );
+}
+
+static void provide_global_data( struct dlist *tree, struct section *global )
+{
+  if( tree ) { dlist_foreach( tree, __provide_foreach_sections, (void *)global ); }
+}
+/*
+ **********************************************/
+
+/**********************************************
+  Free REPO list functions:
+ */
+static void __free_variable( void *data, void *user_data )
+{
+  struct variable *variable = (struct variable *)data;
+  if( variable ) free( variable );
+}
+
+static void free_variables( struct dlist *list )
+{
+  if( list ) { dlist_free( list, __free_variable ); }
+}
+
+static void __free_repo( void *data, void *user_data )
+{
+  struct repo *repo = (struct repo *)data;
+  if( !repo ) return;
+  if( repo->list ) { free_variables( repo->list ); }
+  free( repo );
+}
+
+static void free_repos( struct dlist *list )
+{
+  if( list ) { dlist_free( list, __free_repo ); }
+}
+
+static void __free_section( void *data, void *user_data )
+{
+  struct section *section = (struct section *)data;
+  if( !section ) return;
+
+  if( section->list )
+  {
+    if( section->type == ST_GLOBAL )
+      free_variables( section->list );
+    else if( section->type == ST_REPOS )
+      free_repos( section->list );
+  }
+  free( section );
+}
+
+static void free_repolist( struct dlist *list )
+{
+  if( list ) { dlist_free( list, __free_section ); }
+}
+/*
+ **********************************************/
+
+void free_config( void )
+{
+  free_repolist( config ); config = NULL;
+  if( bcf ) { free( bcf ); bcf = NULL; }
+}
+
+static struct dlist *read_repolist( const void *bf )
+{
+  struct dlist  *tree = NULL;
+  Bcf32_fhdr    *fhdr = NULL;
+  unsigned char *ftab, *stab;
+
+  ftab = (unsigned char *)bf;
+  fhdr = (Bcf32_fhdr *)ftab;
+
+  if( !fhdr )
+    return tree;
+
+  stab = (unsigned char *)(ftab + (int)fhdr->b_stoff);
+
+#if __DEBUG__ == 1
+  fprintf( stderr, "BCF: header's size in bytes: %d\n",  fhdr->b_hsize );
+  fprintf( stderr, "BCF: Whole BCF file size in bytes: %d\n",  fhdr->b_fsize );
+  fprintf( stderr, "BCF: section header table’s file offset in bytes: %d\n",  fhdr->b_shoff );
+  fprintf( stderr, "BCF: section header's size in bytes: %d\n",  fhdr->b_shentsize );
+  fprintf( stderr, "BCF: number of entries in section headers table: %d\n",  fhdr->b_shnum );
+  fprintf( stderr, "BCF: repository header table’s file offset in bytes: %d\n",  fhdr->b_rhoff );
+  fprintf( stderr, "BCF: repository header's size in bytes: %d\n",  fhdr->b_rhentsize );
+  fprintf( stderr, "BCF: number of entries in repository headers table: %d\n",  fhdr->b_rhnum );
+  fprintf( stderr, "BCF: data entries table’s file offset in bytes: %d\n",  fhdr->b_dtoff );
+  fprintf( stderr, "BCF: data entry's size in bytes: %d\n",  fhdr->b_dtentsize );
+  fprintf( stderr, "BCF: number of entries in data entries table: %d\n",  fhdr->b_dtnum );
+  fprintf( stderr, "BCF: string table’s file offset in bytes: %d\n\n",  fhdr->b_stoff );
+#endif
+
+  {
+    Bcf32_shdr *shdr = NULL;
+    int s = 0;
+
+    struct section *global = NULL;
+
+    shdr = (Bcf32_shdr *)((unsigned char *)bf + (int)fhdr->b_shoff);
+
+    while( s < fhdr->b_shnum )
+    {
+#if __DEBUG__ == 1
+      fprintf( stderr, "SECTION: s_name: %s\n",  shdr->s_name );
+      fprintf( stderr, "SECTION: s_type: %d\n",  shdr->s_type );
+      fprintf( stderr, "SECTION: s_shdr (offset in string table): %d\n",  shdr->s_shdr );
+      fprintf( stderr, "SECTION: s_sdata (file offset to data): %d\n",  shdr->s_sdata );
+      fprintf( stderr, "SECTION: s_dnum (number of data entries): %d\n",  shdr->s_dnum );
+      fprintf( stderr, "SECTION: name: \"%s\"\n\n",  stab + (int)shdr->s_shdr );
+#endif
+
+      if( shdr->s_type == ST_GLOBAL )
+      {
+        Bcf32_dntr *dntr = NULL;
+        int d = 0;
+
+        struct section *sec = NULL;
+        sec = (struct section *)xmalloc( sizeof(struct section) );
+        sec->type = ST_GLOBAL;
+        sec->name = (unsigned char *)(stab + (int)shdr->s_shdr); /*do not allocate, all in bcf */
+        tree = dlist_append( tree, (void *)sec );
+        global = sec;
+
+        dntr = (Bcf32_dntr *)(ftab + (int)shdr->s_sdata);
+
+        while( d < shdr->s_dnum )
+        {
+#if __DEBUG__ == 1
+          fprintf( stderr, "DATA: d_name: %s\n",  stab + (int)dntr->d_name );
+#endif
+
+          switch( dntr->d_type )
+          {
+            case DT_NUMERICAL:
+#if __DEBUG__ == 1
+              fprintf( stderr, "DATA: _v.d_value: %d\n\n",  dntr->_v.d_value );
+#endif
+              {
+                struct variable *var = NULL;
+                var = (struct variable *)xmalloc( sizeof(struct variable) );
+                var->type = DT_NUMERICAL;
+                var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                var->_v.val = (int)dntr->_v.d_value;
+                sec->list = dlist_append( sec->list, (void *)var );
+              }
+              break;
+            case DT_PATH:
+#if __DEBUG__ == 1
+              fprintf( stderr, "DATA: _v.d_valptr (path): '%s';\n\n", stab + (int)dntr->_v.d_valptr );
+#endif
+              {
+                struct variable *var = NULL;
+                var = (struct variable *)xmalloc( sizeof(struct variable) );
+                var->type = DT_PATH;
+                var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                var->_v.vptr = (unsigned char *)(stab + (int)dntr->_v.d_valptr);
+                sec->list = dlist_append( sec->list, (void *)var );
+              }
+              break;
+            case DT_STRING:
+#if __DEBUG__ == 1
+              fprintf( stderr, "DATA: _v.d_valptr (string): \"%s\";\n\n", stab + (int)dntr->_v.d_valptr );
+#endif
+              {
+                struct variable *var = NULL;
+                var = (struct variable *)xmalloc( sizeof(struct variable) );
+                var->type = DT_STRING;
+                var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                var->_v.vptr = (unsigned char *)(stab + (int)dntr->_v.d_valptr);
+                sec->list = dlist_append( sec->list, (void *)var );
+              }
+              break;
+            default:
+              break;
+          }
+
+          ++d;
+          ++dntr;
+
+        } /* End of while( global data ) */
+
+      }
+      else if( shdr->s_type == ST_REPOS )
+      {
+        Bcf32_rhdr *rhdr = NULL;
+        int r = 0;
+
+        struct section *sec = NULL;
+        sec = (struct section *)xmalloc( sizeof(struct section) );
+        sec->type = ST_REPOS;
+        sec->name = (unsigned char *)(stab + (int)shdr->s_shdr); /*do not allocate, all in bcf */
+        tree = dlist_append( tree, (void *)sec );
+
+        rhdr = (Bcf32_rhdr *)(ftab + (int)shdr->s_sdata);
+
+        while( r < shdr->s_dnum )
+        {
+          int d = 0;
+          Bcf32_dntr *dntr = NULL;
+
+          struct repo *repo = NULL;
+          repo = (struct repo *)xmalloc( sizeof(struct repo) );
+          repo->path = (unsigned char *)(stab + (int)rhdr->r_rhdr); /*do not allocate, all in bcf */
+          sec->list = dlist_append( sec->list, (void *)repo );
+
+#if __DEBUG__ == 1
+          fprintf( stderr, "REPO: path: %s\n",  stab + (int)rhdr->r_rhdr );
+#endif
+          dntr = (Bcf32_dntr *)(ftab + (int)rhdr->r_rdata);
+
+          while( d < rhdr->r_dnum )
+          {
+#if __DEBUG__ == 1
+            fprintf( stderr, "REPO's DATA: d_name: %s\n",  stab + (int)dntr->d_name );
+#endif
+            switch( dntr->d_type )
+            {
+              case DT_NUMERICAL:
+#if __DEBUG__ == 1
+                fprintf( stderr, "REPO's DATA: _v.d_value: %d\n\n",  dntr->_v.d_value );
+#endif
+                {
+                  struct variable *var = NULL;
+                  var = (struct variable *)xmalloc( sizeof(struct variable) );
+                  var->type = DT_NUMERICAL;
+                  var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                  var->_v.val = (int)dntr->_v.d_value;
+                  repo->list = dlist_append( repo->list, (void *)var );
+                }
+                break;
+              case DT_PATH:
+#if __DEBUG__ == 1
+                fprintf( stderr, "REPO's DATA: _v.d_valptr (path): '%s';\n\n", stab + (int)dntr->_v.d_valptr );
+#endif
+                {
+                  struct variable *var = NULL;
+                  var = (struct variable *)xmalloc( sizeof(struct variable) );
+                  var->type = DT_PATH;
+                  var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                  var->_v.vptr = (unsigned char *)(stab + (int)dntr->_v.d_valptr);
+                  repo->list = dlist_append( repo->list, (void *)var );
+                }
+                break;
+              case DT_STRING:
+#if __DEBUG__ == 1
+                fprintf( stderr, "REPO's DATA: _v.d_valptr (string): \"%s\";\n\n", stab + (int)dntr->_v.d_valptr );
+#endif
+                {
+                  struct variable *var = NULL;
+                  var = (struct variable *)xmalloc( sizeof(struct variable) );
+                  var->type = DT_STRING;
+                  var->name = (unsigned char *)(stab + (int)dntr->d_name); /*do not allocate, all in bcf */
+                  var->_v.vptr = (unsigned char *)(stab + (int)dntr->_v.d_valptr);
+                  repo->list = dlist_append( repo->list, (void *)var );
+                }
+                break;
+              default:
+                break;
+            }
+
+            ++d;
+            ++dntr;
+
+          } /* End of while( repo data ) */
+
+          ++r;
+          ++rhdr;
+
+        } /* End of while( repos ) */
+
+#if __DEBUG__ == 1
+        fprintf( stderr, "\n" );
+#endif
+      }
+      else
+      {
+        rlist_fatal( "Invalid section in the SHM/%s data", "csvn.bcf" );
+#if __DEBUG__ == 1
+        fprintf( stderr, "SECTION: empty\n" );
+#endif
+      }
+
+      ++s;
+      ++shdr;
+
+    } /* End of while( sections ) */
+
+    if( global )
+      provide_global_data( tree, global );
+  }
+
+  return tree;
+}
+
+
+struct dlist *read_config( void )
+{
+  size_t  bsize = 0;
+
+  if( (bsize = read_bcf()) )
+  {
+    check_bcf_ident( bcf, bsize ); /* fatal on error */
+    return read_repolist( bcf );
+  }
+
+  return NULL;
+}
Index: csvn-ui-0.1.5/csvncgi/repolist.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/repolist.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/repolist.h	(revision 12)
@@ -0,0 +1,85 @@
+
+#ifndef    __REPO_LIST_H
+#define    __REPO_LIST_H
+
+#ifndef __DEBUG__
+#define __DEBUG__  0
+#endif
+
+#ifndef ST_GLOBAL
+#define ST_GLOBAL 1
+#endif
+#ifndef ST_REPOS
+#define ST_REPOS  2
+#endif
+
+#ifndef DT_NUMERICAL
+#define DT_NUMERICAL  0x01
+#endif
+#ifndef DT_PATH
+#define DT_PATH       0x02
+#endif
+#ifndef DT_STRING
+#define DT_STRING     0x04
+#endif
+
+struct section
+{
+  int type;
+  unsigned char *name;
+  struct dlist  *list;
+};
+
+struct variable
+{
+  unsigned char *name;
+  union
+  {
+    int val;
+    unsigned char *vptr;
+  } _v;
+  unsigned int type;
+};
+
+struct repo
+{
+  unsigned char *path;
+  struct dlist  *list;
+};
+
+extern struct dlist *config;
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+typedef void (*rlist_errfunc)( const char *fmt, ... );
+
+extern void rlist_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern rlist_errfunc rlist_fatal; /* Default Fatal Error Function == rlist_error() */
+
+
+extern struct dlist *read_config( void );
+extern void print_config( struct strbuf *sb, struct dlist *list );
+extern struct variable *lookup( struct repo *repo, struct variable *variable );
+extern struct variable *lookup_global( struct section *section, struct variable *variable );
+extern struct repo *lookup_repo( struct dlist *config, const char *path );
+extern struct section *lookup_section( struct dlist *config, const char *name );
+extern struct section *lookup_global_section( struct dlist *config );
+
+extern int repolist_length( struct dlist *config );
+extern struct repo *repolist_nth( struct dlist *config, int n );
+extern int repo_position( struct dlist *config, struct repo *repo );
+
+extern struct dlist *parent_section_node_repolist_nth( struct dlist *config, int n );
+extern struct dlist *parent_rlist_node_repolist_nth( struct dlist *config, int n );
+
+extern void free_config( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __REPO_LIST_H */
Index: csvn-ui-0.1.5/csvncgi/robots.txt
===================================================================
--- csvn-ui-0.1.5/csvncgi/robots.txt	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/robots.txt	(revision 12)
@@ -0,0 +1,5 @@
+User-agent: Yandex
+Disallow: /.csvn/snapshot/
+
+User-agent: *
+Disallow: /.csvn/snapshot/
Index: csvn-ui-0.1.5/csvncgi/strbuf.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/strbuf.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/strbuf.c	(revision 12)
@@ -0,0 +1,708 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#define PCRE2_CODE_UNIT_WIDTH 8
+#include <pcre2.h>
+
+#include <nls.h>
+
+#include <defs.h>
+#include <wrapper.h>
+#include <strbuf.h>
+
+
+struct symbol *strbuf_envtab = (struct symbol *)0;
+
+struct symbol *envtab_install( struct symbol **sym, const char *n, const char *v, envtab_error fatal )
+{
+  struct symbol *ep = NULL;
+  size_t len;
+
+  if( !sym || !n || !v || !fatal )
+    return (struct symbol *)NULL;
+
+  ep = (struct symbol *)malloc( sizeof(struct symbol) );
+  if( !ep )
+  {
+    fatal( "cannot allocate memory for symbol '%s'", n );
+  }
+  bzero( (void *)ep, sizeof(struct symbol) );
+
+  len = strlen( n ) + 1;
+  ep->name = (char *)malloc( len );
+  if( !ep->name )
+  {
+    fatal( "cannot allocate memory for symbol name '%s'", n );
+  }
+  bzero( (void *)ep->name, len );
+  strncpy( ep->name, n, len );
+
+  len = strlen( v ) + 1;
+  ep->value = (char *)malloc( len );
+  if( !ep->value )
+  {
+    fatal( "cannot allocate memory for symbol value '%s'", v );
+  }
+  bzero( (void *)ep->value, len );
+  strncpy( ep->value, v, len );
+
+  ep->next = *sym;
+  *sym = ep;
+
+  return ep;
+}
+
+struct symbol *envtab_lookup( struct symbol **sym, const char *n )
+{
+  struct symbol *ep = NULL;
+
+  if( !sym || !n )
+    return (struct symbol *)NULL;
+
+  for( ep = *sym; ep != (struct symbol *)0; ep = ep->next )
+      if( strcmp( ep->name, n ) == 0 ) return( ep );
+
+  return (struct symbol *)NULL;
+}
+
+void envtab_release( struct symbol **sym )
+{
+  struct symbol *tab = *sym;
+
+  while( tab )
+  {
+    struct symbol *ep = tab;
+    tab = ep->next;
+    if( ep->name )  free( ep->name );
+    if( ep->value ) free( ep->value );
+    free( ep );
+  }
+  *sym = (struct symbol *)NULL;
+}
+
+
+#define STRBUF_ERRMSG_SIZE 4096
+
+void strbuf_fatal( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[STRBUF_ERRMSG_SIZE];
+  char  msg[STRBUF_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, STRBUF_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, STRBUF_ERRMSG_SIZE, format, "strbuf", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+char strbuf_slopbuf[1];
+
+#define alloc_nz(x) (((x)+16)*3/2)
+
+static void alloc_grow( struct strbuf *sb, size_t size )
+{
+  if( size > sb->alloc )
+  {
+    if( alloc_nz(sb->alloc) < (size) )
+      sb->alloc = size;
+    else
+      sb->alloc = alloc_nz(sb->alloc);
+
+    sb->buf = xrealloc( (void *)sb->buf, sb->alloc );
+    memset( (void *)(sb->buf + sb->len), 0, (size_t)(sb->alloc - sb->len) );
+  }
+}
+
+void strbuf_grow( struct strbuf *sb, size_t extra )
+{
+  int new_buf = !sb->alloc;
+
+  if( new_buf )
+    sb->buf = NULL;
+
+  alloc_grow( sb, sb->len + extra + 1 );
+
+  if( new_buf )
+    sb->buf[0] = '\0';
+}
+
+/*
+   Функцию strbuf_init() надо вызывать в том случае, когда необходимо
+   задать внешнюю функцию обработки фатальной ошибки. Функция обработки
+   фатальной ошибки, в отличие от стандартной, может выводить как JSON
+   ответы, так и файлы 404.html, 50x.html, используя собственный буфер.
+ */
+void strbuf_init( struct strbuf *sb, strbuf_error fatal, size_t hint )
+{
+  sb->alloc = sb->len = 0;
+  sb->fatal = strbuf_fatal;
+  sb->buf   = strbuf_slopbuf;
+
+  if( fatal )
+    sb->fatal = fatal;
+
+  if( hint )
+    strbuf_grow( sb, hint );
+}
+
+void strbuf_release( struct strbuf *sb )
+{
+  if( sb->alloc )
+  {
+    free( sb->buf );
+    strbuf_init( sb, (strbuf_error)0, 0 );
+  }
+}
+
+char *strbuf_detach( struct strbuf *sb, size_t *sz )
+{
+  char *ret;
+  strbuf_grow( sb, 0 );
+  ret = sb->buf;
+  if( sz )
+    *sz = sb->len;
+  strbuf_init( sb, sb->fatal, 0 );
+  return ret;
+}
+
+void strbuf_attach( struct strbuf *sb, void *buf, size_t len, size_t alloc )
+{
+  strbuf_release( sb );
+  sb->buf   = buf;
+  sb->len   = len;
+  sb->alloc = alloc;
+  strbuf_grow( sb, 0 );
+  sb->buf[sb->len] = '\0';
+}
+
+void strbuf_ltrim( struct strbuf *sb )
+{
+  char *b = sb->buf;
+  while( sb->len > 0 && isspace(*b) )
+  {
+    b++;
+    sb->len--;
+  }
+  memmove( sb->buf, b, sb->len );
+  sb->buf[sb->len] = '\0';
+}
+
+void strbuf_rtrim( struct strbuf *sb )
+{
+  while( sb->len > 0 && isspace((unsigned char)sb->buf[sb->len - 1]) )
+    sb->len--;
+  sb->buf[sb->len] = '\0';
+}
+
+void strbuf_trim( struct strbuf *sb )
+{
+  strbuf_rtrim( sb );
+  strbuf_ltrim( sb );
+}
+
+
+void strbuf_trim_trailing_dir_sep( struct strbuf *sb )
+{
+  while( sb->len > 0 && is_dir_sep((unsigned char)sb->buf[sb->len - 1]) )
+    sb->len--;
+  sb->buf[sb->len] = '\0';
+}
+
+void strbuf_trim_trailing_newline( struct strbuf *sb )
+{
+  if( sb->len > 0 && sb->buf[sb->len - 1] == '\n' )
+  {
+    if( --sb->len > 0 && sb->buf[sb->len - 1] == '\r' )
+      --sb->len;
+    sb->buf[sb->len] = '\0';
+  }
+}
+
+int strbuf_cmp( const struct strbuf *a, const struct strbuf *b )
+{
+  size_t len = a->len < b->len ? a->len: b->len;
+  int    cmp = memcmp( a->buf, b->buf, len );
+  if( cmp )
+    return cmp;
+  return a->len < b->len ? -1: a->len != b->len;
+}
+
+
+/* Adding data to the buffer */
+
+void strbuf_add( struct strbuf *sb, const void *data, size_t len )
+{
+  strbuf_grow( sb, len );
+  memcpy( sb->buf + sb->len, data, len );
+  strbuf_setlen( sb, sb->len + len );
+}
+
+void strbuf_addbuf( struct strbuf *sb, const struct strbuf *sb2 )
+{
+  strbuf_grow( sb, sb2->len );
+  memcpy( sb->buf + sb->len, sb2->buf, sb2->len );
+  strbuf_setlen( sb, sb->len + sb2->len );
+}
+
+void strbuf_addbuf_percentquote( struct strbuf *dst, const struct strbuf *src )
+{
+  size_t i, len = src->len;
+
+  for (i = 0; i < len; i++) {
+    if( src->buf[i] == '%' )
+      strbuf_addch( dst, '%' );
+    strbuf_addch( dst, src->buf[i] );
+  }
+}
+
+void strbuf_addchars( struct strbuf *sb, int c, size_t n )
+{
+  strbuf_grow( sb, n );
+  memset( sb->buf + sb->len, c, n );
+  strbuf_setlen( sb, sb->len + n );
+}
+
+void strbuf_vaddf( struct strbuf *sb, const char *fmt, va_list ap )
+{
+  int len;
+  va_list cp;
+
+  if( !strbuf_avail( sb ) )
+    strbuf_grow( sb, 64 );
+  va_copy( cp, ap );
+  len = vsnprintf( sb->buf + sb->len, sb->alloc - sb->len, fmt, cp );
+  va_end( cp );
+  if( len < 0 )
+    sb->fatal( "your vsnprintf is broken (returned %d)", len );
+  if( len > strbuf_avail( sb ) )
+  {
+    strbuf_grow( sb, len );
+    len = vsnprintf( sb->buf + sb->len, sb->alloc - sb->len, fmt, ap );
+    if( len > strbuf_avail( sb ) )
+      sb->fatal( "your vsnprintf is broken (insatiable)" );
+  }
+  strbuf_setlen( sb, sb->len + len );
+}
+
+void strbuf_addf( struct strbuf *sb, const char *fmt, ... )
+{
+  va_list ap;
+  va_start( ap, fmt );
+  strbuf_vaddf( sb, fmt, ap );
+  va_end( ap );
+}
+
+
+size_t strbuf_fread( struct strbuf *sb, FILE *fp )
+{
+  size_t ret, nb = 64, read = 0;
+  size_t oldalloc = sb->alloc;
+
+  if( !sb || !fp ) return read;
+
+  do
+  {
+    strbuf_grow( sb, nb );
+    ret = fread( sb->buf + sb->len, 1, nb, fp );
+    if( ret > 0 )
+    {
+      strbuf_setlen( sb, sb->len + ret );
+      read += ret;
+    }
+    else if( oldalloc == 0 )
+    {
+      strbuf_release( sb );
+      return ret;
+    }
+
+  } while( ret == nb );
+
+  return read;
+}
+
+
+#define NAMELEN_MAX  128
+
+size_t strbuf_env_fread( struct strbuf *sb, FILE *fp )
+{
+  size_t  read = 0;
+  char   *ln, line[STRBUF_MAXLINE], retline[STRBUF_MAXLINE];
+
+  if( !sb || !fp ) return read;
+
+  bzero( (void *)line, STRBUF_MAXLINE );
+  bzero( (void *)retline, STRBUF_MAXLINE );
+
+  while( (ln = fgets( line, STRBUF_MAXLINE, fp )) )
+  {
+    char *start = NULL, *stop = NULL;
+    char *sp = ln;
+
+    if( (start = strstr( sp, "${" )) && (stop = strstr( sp, "}" )) && ((stop - start) > 1) )
+    {
+      struct symbol *sym = NULL;
+      char  *lp = retline;
+
+      do
+      {
+        /* may be multiple variables on a single line: */
+
+        *start = '\0'; *stop++ = '\0';
+        if( (sym = envtab_lookup( &strbuf_envtab, start+2 )) && sym->value && sym->value[0] )
+        {
+          strncpy( lp, (const char *)sp, (size_t)(start - sp + 1) );
+          lp += (start - sp);
+          strcpy( lp, (const char *)sym->value );
+          lp += strlen( sym->value );
+          strcpy( lp, (const char *)stop );
+          sp = stop;
+        }
+        else
+        {
+          strncpy( lp, (const char *)sp, (size_t)(start - sp + 1) );
+          lp += (start - sp);
+          strcpy( lp, (const char *)stop );
+          sp = stop;
+        }
+
+      } while( (start = strstr( sp, "${" )) && (stop = strstr( sp, "}" )) && ((stop - start) > 1) );
+
+      strbuf_addstr( sb, retline );
+      read += strlen( retline );;
+    }
+    else
+    {
+      strbuf_addstr( sb, line );
+      read += strlen( line );;
+    }
+
+  } /* End of while( ln ) */
+
+  return read;
+}
+
+ssize_t strbuf_read( struct strbuf *sb, int fd, size_t hint )
+{
+  size_t oldlen   = sb->len;
+  size_t oldalloc = sb->alloc;
+
+  strbuf_grow(sb, hint ? hint : 8192);
+  for( ;; )
+  {
+    ssize_t want = sb->alloc - sb->len - 1;
+    ssize_t got  = read_in_full( fd, sb->buf + sb->len, want );
+
+    if( got < 0 )
+    {
+      if( oldalloc == 0 )
+        strbuf_release( sb );
+      else
+        strbuf_setlen( sb, oldlen );
+      return -1;
+    }
+    sb->len += got;
+    if( got < want )
+      break;
+    strbuf_grow( sb, 8192 );
+  }
+
+  sb->buf[sb->len] = '\0';
+  return sb->len - oldlen;
+}
+
+
+size_t strbuf_fwrite( struct strbuf *sb, FILE *fp )
+{
+  return sb->len ? fwrite( sb->buf, 1, sb->len, fp ) : 0;
+}
+
+ssize_t strbuf_write( struct strbuf *sb, int fd )
+{
+  return sb->len ? write( fd, (const void *)sb->buf, sb->len ) : 0;
+}
+
+
+/* XML quoted: */
+
+void strbuf_addstr_xml_quoted( struct strbuf *sb, const char *s )
+{
+  while( *s )
+  {
+    size_t len = strcspn( s, "\"<>&" );
+    strbuf_add( sb, s, len );
+    s += len;
+
+    switch( *s )
+    {
+      case '"':
+        strbuf_addstr( sb, "&quot;" );
+        break;
+      case '<':
+        strbuf_addstr( sb, "&lt;" );
+        break;
+      case '>':
+        strbuf_addstr( sb, "&gt;" );
+        break;
+      case '&':
+        strbuf_addstr( sb, "&amp;" );
+        break;
+      case 0:
+        return;
+    }
+    s++;
+  }
+}
+
+static int is_html_quoted( const char *str )
+{
+  int         rc = 0, error = 0;
+  PCRE2_SIZE  offset = 0;
+  const char  pattern[] = "^(&[#A-Za-z0-9]*;)";
+
+  pcre2_match_data *match;
+
+  pcre2_code *regexp = pcre2_compile( (PCRE2_SPTR)pattern, PCRE2_ZERO_TERMINATED, 0, &error, &offset, NULL );
+  if( regexp == NULL )
+  {
+    return 0; /* PCRE compilation failed */
+  }
+
+  match = pcre2_match_data_create_from_pattern( regexp, NULL );
+
+  rc = pcre2_match( regexp, (PCRE2_SPTR)str, (PCRE2_SIZE)strlen(str), 0, 0, match, NULL ); /* sizeof(match)/sizeof(match[0]) */
+  if( rc < 0 )
+  {
+    /* not match */
+    pcre2_match_data_free( match );
+    pcre2_code_free( regexp );
+    return 0;
+  }
+  else
+  {
+    /* match */
+    pcre2_match_data_free( match );
+    pcre2_code_free( regexp );
+    return 1;
+  }
+}
+
+void strbuf_addstr_html_quoted( struct strbuf *sb, const char *s )
+{
+  while( *s )
+  {
+    size_t len = strcspn( s, "\"<>&" );
+    strbuf_add( sb, s, len );
+    s += len;
+
+    switch( *s )
+    {
+      case '"':
+        strbuf_addstr( sb, "&quot;" );
+        break;
+      case '<':
+        strbuf_addstr( sb, "&lt;" );
+        break;
+      case '>':
+        strbuf_addstr( sb, "&gt;" );
+        break;
+      case '&':
+        if( !is_html_quoted( s ) )
+          strbuf_addstr( sb, "&amp;" );
+        else
+          strbuf_addch( sb, *s );
+        break;
+      case 0:
+        return;
+    }
+    s++;
+  }
+}
+
+
+/* urlencode: */
+
+int is_rfc3986_reserved_or_unreserved( char ch )
+{
+  if( is_rfc3986_unreserved(ch) )
+    return 1;
+  switch( ch )
+  {
+    case '!': case '*': case '\'': case '(': case ')': case ';':
+    case ':': case '@': case '&': case '=': case '+': case '$':
+    case ',': case '/': case '?': case '#': case '[': case ']':
+      return 1;
+  }
+  return 0;
+}
+
+int is_rfc3986_unreserved( char ch )
+{
+  return isalnum(ch) || ch == '-' || ch == '_' || ch == '.' || ch == '~';
+}
+
+static void
+strbuf_add_urlencode( struct strbuf *sb, const char *s, size_t len,
+                      char_predicate allow_unencoded_fn )
+{
+  strbuf_grow( sb, len );
+  while( len-- )
+  {
+    char ch = *s++;
+    if( allow_unencoded_fn(ch) )
+      strbuf_addch( sb, ch );
+    else
+      strbuf_addf( sb, "%%%02x", (unsigned char)ch );
+  }
+}
+
+void strbuf_addstr_urlencode( struct strbuf *sb, const char *s, char_predicate allow_unencoded_fn )
+{
+  strbuf_add_urlencode( sb, s, strlen(s), allow_unencoded_fn );
+}
+
+
+/* humanise: */
+
+static void strbuf_humanise( struct strbuf *sb, off_t bytes, int humanise_rate )
+{
+  if( bytes > 1 << 30 )
+  {
+    strbuf_addf( sb,
+      humanise_rate == 0 ?
+        /* TRANSLATORS: IEC 80000-13:2008 gibibyte */
+        _("%u.%2.2u GiB") :
+        /* TRANSLATORS: IEC 80000-13:2008 gibibyte/second */
+        _("%u.%2.2u GiB/s"),
+        (unsigned)(bytes >> 30),
+        (unsigned)(bytes & ((1 << 30) - 1)) / 10737419 );
+  }
+  else if( bytes > 1 << 20 )
+  {
+    unsigned x = bytes + 5243;  /* for rounding */
+    strbuf_addf( sb,
+      humanise_rate == 0 ?
+        /* TRANSLATORS: IEC 80000-13:2008 mebibyte */
+        _("%u.%2.2u MiB") :
+        /* TRANSLATORS: IEC 80000-13:2008 mebibyte/second */
+        _("%u.%2.2u MiB/s"),
+        x >> 20, ((x & ((1 << 20) - 1)) * 100) >> 20 );
+  }
+  else if( bytes > 1 << 10 )
+  {
+    unsigned x = bytes + 5;  /* for rounding */
+    strbuf_addf( sb,
+      humanise_rate == 0 ?
+        /* TRANSLATORS: IEC 80000-13:2008 kibibyte */
+        _("%u.%2.2u KiB") :
+        /* TRANSLATORS: IEC 80000-13:2008 kibibyte/second */
+        _("%u.%2.2u KiB/s"),
+        x >> 10, ((x & ((1 << 10) - 1)) * 100) >> 10 );
+  }
+  else
+  {
+    strbuf_addf( sb,
+      humanise_rate == 0 ?
+        /* TRANSLATORS: IEC 80000-13:2008 byte */
+        Q_("%u byte", "%u bytes", (unsigned)bytes) :
+        /* TRANSLATORS: IEC 80000-13:2008 byte/second */
+        Q_("%u byte/s", "%u bytes/s", (unsigned)bytes),
+      (unsigned)bytes );
+  }
+}
+
+void strbuf_humanise_bytes( struct strbuf *sb, off_t bytes )
+{
+  strbuf_humanise( sb, bytes, 0 );
+}
+
+void strbuf_humanise_rate( struct strbuf *sb, off_t bytes )
+{
+  strbuf_humanise( sb, bytes, 1 );
+}
+
+
+int is_directory( const char *path )
+{
+  struct stat st;
+  return ( !stat( path, &st ) && S_ISDIR(st.st_mode) );
+}
+
+void strbuf_selfdir( struct strbuf *sb )
+{
+  char    path[PATH_MAX];
+  ssize_t len;
+
+  bzero( (void *)path, PATH_MAX );
+
+  len = readlink( "/proc/self/exe", &path[0], (size_t)PATH_MAX );
+  if( len > 0 && len < PATH_MAX )
+  {
+    strbuf_addstr( sb, (const char *)dirname( (char *)&path[0] ) );
+  }
+  else
+    sb->fatal( "cannot get selfdir" );
+}
+
+void strbuf_relpath( struct strbuf *sb, const char *path )
+{
+  struct strbuf self = STRBUF_INIT;
+  char   p[PATH_MAX];
+
+  bzero( (void *)p, PATH_MAX );
+
+  if( realpath( path, (char *)&p[0] ) == NULL )
+  {
+    sb->fatal( "cannot get relative path of '%s'", path );
+  }
+
+  strbuf_init( &self, sb->fatal, 0 );
+  strbuf_selfdir( &self );
+
+  strbuf_addstr( sb, (const char *)&p[self.len] );
+
+  strbuf_release( &self );
+}
+
+void strbuf_abspath( struct strbuf *sb, const char *path )
+{
+  char p[PATH_MAX];
+
+  if( realpath( path, (char *)&p[0] ) == NULL )
+  {
+    sb->fatal( "cannot get absolute path of '%s'", path );
+  }
+
+  strbuf_addstr( sb, (char *)&p[0] );
+}
Index: csvn-ui-0.1.5/csvncgi/strbuf.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/strbuf.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/strbuf.h	(revision 12)
@@ -0,0 +1,202 @@
+
+#ifndef    __STRBUF_H
+#define    __STRBUF_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define STRBUF_MAXLINE (2*PATH_MAX)
+
+typedef void (*strbuf_error)( const char *fmt, ... );
+
+struct strbuf
+{
+  size_t  alloc;
+  size_t  len;
+  strbuf_error fatal;
+  char   *buf;
+};
+
+/************************************************************************
+  Таблица размещается на стороне клиента, а указатель присваивается
+  переменной strbuf_envtab, который используется функциями чтения файлов
+  для подстановки значений вместо переменных:
+
+    ${root-title}, ${root-desc}, ${repo}, ${repo-desc}, ...
+
+  Освобождать выделенную память нет необходимости, так как таблица
+  используется в CGI-скрипте, который срабатывает однократно.
+
+  При необходимости повторного создания таблицы переменных,
+  надо освободить память с помощью envtab_release( &strbuf_envtab )
+  которая обнулит указатель strbuf_envtab, являющийся адресом первой
+  записи в таблице.
+ */
+typedef void (*envtab_error)( const char *fmt, ... );
+
+struct symbol
+{
+  char *name;
+  char *value;
+
+  struct symbol *next;
+};
+
+extern struct symbol *strbuf_envtab;
+
+extern struct symbol *envtab_install( struct symbol **sym, const char *n, const char *v, envtab_error fatal );
+extern struct symbol *envtab_lookup( struct symbol **sym, const char *n );
+extern void envtab_release( struct symbol **sym );
+/*
+ ************************************************************************/
+
+
+extern char strbuf_slopbuf[];
+extern void strbuf_fatal( const char *fmt, ... );
+
+#define STRBUF_INIT  { .alloc = 0, .len = 0, .fatal = strbuf_fatal, .buf = strbuf_slopbuf }
+
+extern void  strbuf_grow( struct strbuf *sb, size_t amount );
+extern void  strbuf_init( struct strbuf *sb, strbuf_error fatal, size_t alloc );
+extern void  strbuf_release( struct strbuf *sb );
+extern char *strbuf_detach( struct strbuf *sb, size_t *sz );
+extern void  strbuf_attach( struct strbuf *sb, void *str, size_t len, size_t mem );
+
+static inline size_t strbuf_avail( const struct strbuf *sb )
+{
+  return sb->alloc ? sb->alloc - sb->len - 1 : 0;
+}
+
+static inline void strbuf_setlen(struct strbuf *sb, size_t len)
+{
+  if( len > (sb->alloc ? sb->alloc - 1 : 0) )
+    sb->fatal( "BUG: strbuf_setlen() beyond buffer" );
+  sb->len = len;
+  if (sb->buf != strbuf_slopbuf)
+    sb->buf[len] = '\0';
+  else
+    if( !strbuf_slopbuf[0] ) sb->fatal( "BUG: strbuf_slopbuf[0] = '\0'" );
+}
+
+#define strbuf_reset(sb)  strbuf_setlen(sb, 0)
+
+
+/***************************************************************************
+  BUILD_ASSERT_OR_ZERO - assert a build-time dependency, as an expression.
+  @cond: the compile-time condition which must be true.
+
+  Your compile will fail if the condition isn't true, or can't be evaluated
+  by the compiler.  This can be used in an expression: its value is "0".
+
+  Example:
+    #define foo_to_char(foo) \
+      ((char *)(foo)         \
+       + BUILD_ASSERT_OR_ZERO(offsetof(struct foo, string) == 0))
+ ***************************************************************************/
+#define BUILD_ASSERT_OR_ZERO(cond) \
+  (sizeof(char [1 - 2*!(cond)]) - 1)
+
+#define SWAP(a, b) \
+  do {                                               \
+    void *_swap_a_ptr = &(a);                        \
+    void *_swap_b_ptr = &(b);                        \
+    unsigned char _swap_buffer[sizeof(a)];           \
+    memcpy(_swap_buffer, _swap_a_ptr, sizeof(a));    \
+    memcpy(_swap_a_ptr, _swap_b_ptr, sizeof(a) +     \
+      BUILD_ASSERT_OR_ZERO(sizeof(a) == sizeof(b))); \
+    memcpy(_swap_b_ptr, _swap_buffer, sizeof(a));    \
+  } while (0)
+
+static inline void strbuf_swap( struct strbuf *a, struct strbuf *b )
+{
+  SWAP(*a, *b);
+}
+
+
+extern void strbuf_ltrim( struct strbuf *sb );
+extern void strbuf_rtrim( struct strbuf *sb );
+extern void strbuf_trim( struct strbuf *sb );
+
+#ifndef is_dir_sep
+static inline int is_dir_sep( int c )
+{
+  return c == '/';
+}
+#endif
+static inline int is_absolute_path( const char *path )
+{
+  return is_dir_sep( path[0] );
+}
+
+extern void strbuf_trim_trailing_dir_sep( struct strbuf *sb );
+extern void strbuf_trim_trailing_newline( struct strbuf *sb );
+
+extern int strbuf_cmp( const struct strbuf *a, const struct strbuf *b );
+
+
+/* Adding data to the buffer */
+
+extern void strbuf_add( struct strbuf *sb, const void *data, size_t len );
+extern void strbuf_addbuf( struct strbuf *sb, const struct strbuf *sb2 );
+extern void strbuf_addbuf_percentquote( struct strbuf *dst, const struct strbuf *src );
+
+
+/* Add a single ASCII character to the buffer. */
+static inline void strbuf_addch( struct strbuf *sb, int c )
+{
+  if( !strbuf_avail(sb) )
+    strbuf_grow(sb, 1);
+  sb->buf[sb->len++] = c;
+  sb->buf[sb->len] = '\0';
+}
+
+/* Add n ASCII characters to the buffer. */
+extern void strbuf_addchars( struct strbuf *sb, int c, size_t n );
+
+/* Add a NUL-terminated string to the buffer. */
+static inline void strbuf_addstr( struct strbuf *sb, const char *s )
+{
+  strbuf_add( sb, (const void *)s, strlen(s) );
+}
+
+extern void strbuf_vaddf( struct strbuf *sb, const char *fmt, va_list ap );
+extern void strbuf_addf( struct strbuf *sb, const char *fmt, ... );
+
+extern size_t strbuf_fread( struct strbuf *sb, FILE *fp );
+extern size_t strbuf_env_fread( struct strbuf *sb, FILE *fp );
+extern size_t strbuf_fwrite( struct strbuf *sb, FILE *fp );
+
+extern ssize_t strbuf_read( struct strbuf *sb, int fd, size_t hint );
+extern ssize_t strbuf_write( struct strbuf *sb, int fd );
+
+
+/* XML/HTML quoted: */
+extern void strbuf_addstr_xml_quoted( struct strbuf *sb, const char *s );
+extern void strbuf_addstr_html_quoted( struct strbuf *sb, const char *s );
+
+/* urlencode: */
+typedef int (*char_predicate)(char ch);
+
+extern int is_rfc3986_unreserved( char ch );
+extern int is_rfc3986_reserved_or_unreserved( char ch );
+
+extern void strbuf_addstr_urlencode( struct strbuf *sb, const char *name, char_predicate allow_unencoded_fn );
+
+
+extern void strbuf_humanise_bytes( struct strbuf *sb, off_t bytes );
+extern void strbuf_humanise_rate( struct strbuf *sb, off_t bytes );
+
+
+extern int is_directory( const char *path );
+
+extern void strbuf_selfdir( struct strbuf *sb );
+extern void strbuf_relpath( struct strbuf *sb, const char *path );
+extern void strbuf_abspath( struct strbuf *sb, const char *path );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __STRBUF_H */
Index: csvn-ui-0.1.5/csvncgi/system.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/system.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/system.c	(revision 12)
@@ -0,0 +1,177 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+#include <errno.h>
+#include <error.h>
+#include <sys/stat.h>
+#include <sys/wait.h>
+#include <stdarg.h>
+#include <unistd.h>
+
+#include <defs.h>
+
+#include <strbuf.h>
+#include <system.h>
+
+
+#define SYSTEM_ERRMSG_SIZE 4096
+
+void system_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[SYSTEM_ERRMSG_SIZE];
+  char  msg[SYSTEM_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, SYSTEM_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, SYSTEM_ERRMSG_SIZE, format, "system", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+system_errfunc system_fatal = system_error;
+
+
+static void xexec( const char *cmd )
+{
+  char *argv[4];
+  const char *shell = getenv ("SHELL");
+
+  if( !shell ) shell = "/bin/sh";
+
+  argv[0] = (char *) shell;
+  argv[1] = (char *) "-c";
+  argv[2] = (char *) cmd;
+  argv[3] = NULL;
+
+  execv( shell, argv );
+
+  /******************************************
+    xexec() is called by child process, and
+    here child process faced to FATAL error:
+   */
+  system_fatal( "Cannot exec '%s'\n", cmd );
+}
+
+static pid_t xfork( void )
+{
+  pid_t p = fork();
+
+  if( p == (pid_t) -1 )
+  {
+    system_fatal( "Cannot %s: %s\n", "fork()", strerror( errno ) );
+  }
+
+  return p;
+}
+
+pid_t sys_exec_command( struct strbuf *sb, const char *cmd )
+{
+  int pipe_fh[2];
+
+  pid_t pid = -1;
+
+  if( sb )
+  {
+    if( pipe(pipe_fh ) == -1 )
+    {
+      system_fatal( "Cannot create pipe: %s\n", strerror( errno ) );
+    }
+  }
+
+  pid = xfork();
+
+  if( pid != 0 )
+  {
+    if( sb )
+    {
+      ssize_t ret;
+
+      close(pipe_fh[1]);
+      ret = strbuf_read( sb, pipe_fh[0], 1024 );
+      if( ret < 0 )
+        system_fatal( "Cannot read pipe: %s\n", strerror( errno ) );
+      close(pipe_fh[0]);
+    }
+
+    return pid;
+  }
+
+  if( sb )
+  {
+    dup2(pipe_fh[1], STDOUT_FILENO);
+    close(pipe_fh[1]);
+    close(pipe_fh[0]);
+  }
+
+  xexec( cmd );
+  return pid; /* only to avoid compilaton warning */
+}
+
+/*****************************************************************
+  sys_wait_command() - Wait for pid.
+
+  Return values:
+  -------------
+     0  - SUCCESS
+   >=1  - status returned by child process
+    -1  - Child terminated on signal
+    -2  - Child terminated on unknown reason
+    -3  - Cannot waitpid: waitpid() retusrs -1
+
+     Error message with SIZE length saved into *ERRMSG buffer.
+ *****************************************************************/
+int sys_wait_command( pid_t pid, struct strbuf *errmsg )
+{
+  int status;
+
+  if( pid < 0 ) return (pid_t) -1;
+
+  while( waitpid( pid, &status, 0 ) == -1 )
+    if( errno != EINTR )
+    {
+      if( errmsg ) {
+        strbuf_addf( errmsg, "PID %lu: Cannot %s", (unsigned long)pid, "waitpid" );
+      }
+      return (int) -3;
+    }
+
+  if( WIFEXITED( status ) )
+  {
+    if( WEXITSTATUS (status) )
+    {
+      if( errmsg ) {
+        strbuf_addf( errmsg, "PID %lu: Child returned status %d", (unsigned long)pid, WEXITSTATUS( status ) );
+      }
+      return (int) WEXITSTATUS( status );
+    }
+  }
+  else if( WIFSIGNALED( status ) )
+  {
+    if( errmsg ) {
+      strbuf_addf( errmsg, "PID %lu: Child terminated on signal %d", (unsigned long)pid, WTERMSIG( status ) );
+    }
+    return (int) -1;
+  }
+  else
+  {
+    if( errmsg ) {
+      strbuf_addf( errmsg, "PID %lu: Child terminated on unknown reason", (unsigned long)pid );
+    }
+    return (int) -2;
+  }
+
+  return 0;
+}
Index: csvn-ui-0.1.5/csvncgi/system.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/system.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/system.h	(revision 12)
@@ -0,0 +1,25 @@
+
+#ifndef    __SYSTEM_H
+#define    __SYSTEM_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef void (*system_errfunc)( const char *fmt, ... );
+
+extern void system_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern system_errfunc system_fatal; /* Default Fatal Error Function == system_error() */
+
+
+extern pid_t sys_exec_command( struct strbuf *sb, const char *cmd );
+extern int sys_wait_command( pid_t pid, struct strbuf *errmsg );
+
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __SYSTEM_H */
Index: csvn-ui-0.1.5/csvncgi/ui-blame.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-blame.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-blame.c	(revision 12)
@@ -0,0 +1,145 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+static void csvn_print_blame( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !sb || !relative_path ) return;
+
+  strbuf_addf( sb, "<div class=\"blame\">" );
+  strbuf_addf( sb, "  <pre><code class='language-PlainText'>" );
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    char  *raw = NULL;
+    pid_t  p = (pid_t) -1;
+    int    rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn blame --revision %d %s/%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn blame %s/%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    raw = strbuf_detach( &buf, NULL );
+    strbuf_addstr_xml_quoted( &buf, (const char *)raw );
+    free( raw );
+
+    strbuf_addbuf( sb, (const struct strbuf *)&buf );
+    strbuf_release( &buf );
+  }
+
+  strbuf_addstr( sb, "\n  </code></pre>\n" );
+  strbuf_addstr( sb, "</div>\n" );
+
+  return;
+}
+
+void csvn_print_blame_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.repo.name )
+  {
+    csvn_print_blame( &buf, ctx.repo.relative_path, ctx.query.rev );
+  }
+  else
+  {
+    strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+    strbuf_addf( &buf, "              <p class='leading'>Repository '%s' not found.</p>\n", ctx.repo.name );
+  }
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-blame.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-blame.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-blame.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_BLAME_H
+#define    __UI_BLAME_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_blame_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_BLAME_H */
Index: csvn-ui-0.1.5/csvncgi/ui-diff.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-diff.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-diff.c	(revision 12)
@@ -0,0 +1,146 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+static void csvn_print_diff( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !sb || !relative_path || !revision ) return;
+
+  strbuf_addf( sb, "<pre><code class='language-Diff'>" );
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    char  *raw = NULL;
+    pid_t  p = (pid_t) -1;
+    int    rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    snprintf( (char *)&cmd[0], 1024,
+              "svn diff --revision %d:%d %s/%s/%s 2>/dev/null",
+              revision-1, revision, co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    raw = strbuf_detach( &buf, NULL );
+    strbuf_addstr_xml_quoted( &buf, (const char *)raw );
+    free( raw );
+
+    strbuf_addbuf( sb, (const struct strbuf *)&buf );
+    strbuf_release( &buf );
+  }
+
+  strbuf_addstr( sb, "\n</code></pre>\n" );
+
+  return;
+}
+
+void csvn_print_diff_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.repo.name )
+  {
+    if( ctx.query.rev )
+    {
+      csvn_print_diff( &buf, ctx.repo.relative_path, ctx.query.rev );
+    }
+    else
+    {
+      strbuf_addf( &buf, "              <h1>Requested diff cannot be shown</h1>\n" );
+      strbuf_addf( &buf, "              <p class='leading'>Revision for diff operation is not defined.</p>\n" );
+    }
+  }
+  else
+  {
+    strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+    strbuf_addf( &buf, "              <p class='leading'>Repository '%s' not found.</p>\n", ctx.repo.name );
+  }
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-diff.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-diff.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-diff.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_DIFF_H
+#define    __UI_DIFF_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_diff_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_DIFF_H */
Index: csvn-ui-0.1.5/csvncgi/ui-file.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-file.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-file.c	(revision 12)
@@ -0,0 +1,408 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <md4c.h>
+#include <md4c-html.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+static int csvn_file_last_changed_revision( const char *relative_path )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+  int ret = 0;
+
+  if( !relative_path ) return ret;
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    snprintf( (char *)&cmd[0], 1024,
+              "svn info --show-item last-changed-revision --no-newline %s/%s/%s 2>/dev/null",
+              co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      return ret;
+    }
+    strbuf_trim( &buf );
+    ret = atoi( buf.buf );
+    strbuf_release( &buf );
+  }
+  return ret;
+}
+
+static void csvn_print_file_links( struct strbuf *sb, const char *relative_path, int revision, int top )
+{
+  const char *query_string = NULL;
+  const char *place = NULL;
+  char rev[80] = { 0 };
+
+  if( !sb || !relative_path ) return;
+
+  if( top )
+    place = "top";
+  else
+    place = "bottom";
+
+  strbuf_addf( sb, "<div class=\"%s file-links-menu\">\n", place );
+  strbuf_addf( sb, "  <div class=\"right links-menu\">\n" );
+
+  query_string = ctx_remove_query_param( ctx.env.query_string, "rev" );
+  query_string = ctx_remove_query_param( query_string, "op" );
+
+  if( !revision )
+    revision = csvn_file_last_changed_revision( relative_path );
+  sprintf( (char *)&rev[0], "%d", revision );
+
+  if( query_string && *query_string )
+  {
+    if( ctx.repo.repo_root && *ctx.repo.repo_root )
+    {
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-scroll\"></span><a href=\"/%s/%s/%s/?op=log&rev=%s&%s\">log</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-diff\"></span><a href=\"/%s/%s/%s/?op=diff&rev=%s&%s\">diff</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-blame\"></span><a href=\"/%s/%s/%s/?op=blame&rev=%s&%s\">blame</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+    }
+    else
+    {
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-scroll\"></span><a href=\"/%s/%s/?op=log&rev=%s&%s\">log</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-diff\"></span><a href=\"/%s/%s/?op=diff&rev=%s&%s\">diff</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-blame\"></span><a href=\"/%s/%s/?op=blame&rev=%s&%s\">blame</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0], query_string );
+    }
+  }
+  else
+  {
+    if( ctx.repo.repo_root && *ctx.repo.repo_root )
+    {
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-scroll\"></span><a href=\"/%s/%s/%s/?op=log&rev=%s\">log</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0] );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-diff\"></span><a href=\"/%s/%s/%s/?op=diff&rev=%s\">diff</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0] );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-blame\"></span><a href=\"/%s/%s/%s/?op=blame&rev=%s\">blame</a></div>\n", ctx.repo.repo_root, ctx.repo.name, relative_path, (char *)&rev[0] );
+    }
+    else
+    {
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-scroll\"></span><a href=\"/%s/%s/?op=log&rev=%s\">log</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0] );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-diff\"></span><a href=\"/%s/%s/?op=diff&rev=%s\">diff</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0] );
+      strbuf_addf( sb, "    <div class=\"item\"><span class=\"icon las la-blame\"></span><a href=\"/%s/%s/?op=blame&rev=%s\">blame</a></div>\n", ctx.repo.name, relative_path, (char *)&rev[0] );
+    }
+  }
+
+  strbuf_addf( sb, "  </div>\n" );
+  strbuf_addf( sb, "</div>\n" );
+}
+
+static void process_markdown_output( const MD_CHAR *text, MD_SIZE size, void *sb )
+{
+  strbuf_add( (struct strbuf *)sb, (const void *)text, (size_t)size );
+}
+
+static int csvn_write_markdown_content( struct strbuf *sb, const struct strbuf *input )
+{
+  unsigned parser_flags   = MD_DIALECT_GITHUB; /* | MD_DIALECT_COMMONMARK */
+  unsigned renderer_flags = MD_FLAG_WIKILINKS; /* | MD_HTML_FLAG_DEBUG    */
+
+  /*********************************
+    md_html() returns 0 on success:
+   */
+  return md_html( input->buf, input->len, process_markdown_output,
+                  (void *)sb, parser_flags, renderer_flags );
+}
+
+static void csvn_print_markdown_file( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !sb || !relative_path ) return;
+
+  csvn_print_file_links( sb, relative_path, revision, 1 );
+
+  strbuf_addstr( sb, "<div class='markdown-content'>" );
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat --revision %d %s/%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat %s/%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    (void)csvn_write_markdown_content( sb, (const struct strbuf *)&buf );
+
+    strbuf_release( &buf );
+  }
+
+  strbuf_addstr( sb, "\n</div> <!-- End of Markdown Content -->\n" );
+
+  csvn_print_file_links( sb, relative_path, revision, 0 );
+
+  return;
+}
+
+
+static void csvn_print_file( struct strbuf *sb, const char *relative_path, int revision, const char *lang )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !sb || !relative_path ) return;
+
+  csvn_print_file_links( sb, relative_path, revision, 1 );
+
+  if( lang )
+    strbuf_addf( sb, "<pre><code class='language-%s'>", lang );
+  else
+    strbuf_addstr( sb, "<pre><code class='highlight'>" );
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    char  *raw = NULL;
+    pid_t  p = (pid_t) -1;
+    int    rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat --revision %d %s/%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat %s/%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    raw = strbuf_detach( &buf, NULL );
+    strbuf_addstr_xml_quoted( &buf, (const char *)raw );
+    free( raw );
+
+    strbuf_addbuf( sb, (const struct strbuf *)&buf );
+    strbuf_release( &buf );
+  }
+
+  strbuf_addstr( sb, "\n</code></pre>\n" );
+
+  csvn_print_file_links( sb, relative_path, revision, 0 );
+
+  return;
+}
+
+static void csvn_print_image_file( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !sb || !relative_path ) return;
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t  p = (pid_t) -1;
+    int    rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat --revision %d %s/%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat %s/%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    /****************************************************
+      This call should terminate the program on success:
+     */
+    csvn_print_raw_file( &buf, ctx.repo.relative_info.mime );
+
+    strbuf_release( &buf );
+  }
+
+  return;
+}
+
+void csvn_print_file_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.repo.relative_info.kind == KIND_FILE )
+  {
+    if( !strncmp( ctx.repo.relative_info.mime, "text/", 5 ) )
+    {
+      if( ctx.repo.name )
+      {
+        if( ctx.repo.relative_info.lang )
+        {
+          if( !strcmp( ctx.repo.relative_info.lang, "Markdown" ) )
+            csvn_print_markdown_file( &buf, ctx.repo.relative_path, ctx.query.rev );
+          else
+            csvn_print_file( &buf, ctx.repo.relative_path, ctx.query.rev, ctx.repo.relative_info.lang );
+        }
+        else
+          csvn_print_file( &buf, ctx.repo.relative_path, ctx.query.rev, NULL );
+      }
+      else
+      {
+        strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+        strbuf_addf( &buf, "              <p class='leading'>Repository '%s' not found.</p>\n", ctx.repo.name );
+      }
+    }
+    else if( !strncmp( ctx.repo.relative_info.mime, "image/", 6 ) )
+    {
+      /****************************************************
+        This call should terminate the program on success:
+       */
+      csvn_print_image_file( &buf, ctx.repo.relative_path, ctx.query.rev );
+
+      strbuf_addf( &buf, "              <h1>Requested file cannot be shown</h1>\n" );
+      strbuf_addf( &buf, "              <p class='leading'>Files with mime type such as '%s' cannot be present.</p>\n", ctx.repo.relative_info.mime );
+    }
+    else
+    {
+      strbuf_addf( &buf, "              <h1>Requested file cannot be shown</h1>\n" );
+      strbuf_addf( &buf, "              <p class='leading'>Files with mime type such as '%s' cannot be present.</p>\n", ctx.repo.relative_info.mime );
+    }
+  }
+  else
+  {
+    strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+    strbuf_addf( &buf, "              <p class='leading'>This page assume plain text files to be present.</p>\n" );
+  }
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-file.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-file.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-file.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_FILE_H
+#define    __UI_FILE_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_file_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_FILE_H */
Index: csvn-ui-0.1.5/csvncgi/ui-log.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-log.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-log.c	(revision 12)
@@ -0,0 +1,402 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <libxml/parser.h>
+#include <libxml/tree.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+static void xml_csvn_log( struct strbuf *sb, const struct strbuf *buf, const char *relative_path )
+{
+  xmlDocPtr doc = NULL;
+  xmlNode *root = NULL;
+  char    *path = NULL;
+
+  int count = 0, printed = 0, reminder = 0, page_size = 200;
+
+  if( !sb || !sb->len || !buf || !buf->buf ) return;
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  page_size = atoi( ctx.vars.page_size );
+
+  LIBXML_TEST_VERSION
+
+  doc = xmlReadMemory( buf->buf, buf->len, "log.xml", NULL, 0 );
+  if( !doc )
+  {
+    html_fatal( "cannot parse svn log.xml" );
+    return;
+  }
+
+  root = xmlDocGetRootElement( doc );
+  if( !root )
+  {
+    free( path );
+    xmlFreeDoc( doc );
+    xmlCleanupParser();
+    return;
+  }
+
+  if( !strcmp( "log", (char *)root->name ) )
+  {
+    xmlNode *node = NULL;
+
+    strbuf_addstr( sb, "\n" );
+    strbuf_addf( sb, "              <div class=\"repo-log-header\">\n" );
+    strbuf_addf( sb, "                <div class=\"row\">\n" );
+    strbuf_addf( sb, "                  <div class=\"col-date\"><div class=\"log-date\">Date</div></div>\n" );
+    strbuf_addf( sb, "                  <div class=\"col-cmsg\"><div class=\"log-cmsg trunc\">Commit Message</div></div>\n" );
+    strbuf_addf( sb, "                  <div class=\"col-rev\"><div class=\"log-rev trunc\">Rev</div></div>\n" );
+    strbuf_addf( sb, "                  <div class=\"col-author\"><div class=\"log-author trunc\">Author</div></div>\n" );
+    strbuf_addf( sb, "                </div>\n" );
+    strbuf_addf( sb, "              </div>\n\n" );
+
+    strbuf_addf( sb, "              <div class=\"log\">\n\n" );
+
+    /**************************
+      Print directories first:
+     */
+    for( node = root->children; node; node = node->next )
+    {
+      if( node->type == XML_ELEMENT_NODE && !strcmp( "logentry", (char *)node->name ) )
+      {
+        xmlNode *param = NULL;
+        xmlChar *date = NULL, *cmsg = NULL, *revision = NULL, *author = NULL;
+
+        revision = xmlGetProp( node, (const unsigned char *)"revision" );
+
+        for( param = node->children; param; param= param->next )
+        {
+          if( param->type == XML_ELEMENT_NODE && !strcmp( "date", (char *)param->name ) )
+          {
+            date = xmlNodeGetContent( param );
+          }
+          if( param->type == XML_ELEMENT_NODE && !strcmp( "msg", (char *)param->name ) )
+          {
+            cmsg = xmlNodeGetContent( param );
+          }
+          if( param->type == XML_ELEMENT_NODE && !strcmp( "author", (char *)param->name ) )
+          {
+            author = xmlNodeGetContent( param );
+          }
+
+        } /* End for entry parameters */
+
+        if( date && cmsg && revision && author )
+        {
+          struct tm   tm;
+          time_t      time = -1;
+          const char *query_string = ctx_remove_query_param( ctx.env.query_string, "rev" );
+
+          query_string = ctx_remove_query_param( query_string, "op" );
+
+          time = parse_date( &tm, (const char *)date );
+
+          ++count;
+          if( count > ctx.query.ofs && printed < page_size )
+          {
+
+            strbuf_addf( sb, "                <div class=\"row\">\n" );
+            if( time != -1 )
+            {
+              strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"log-date trunc\">" );
+              csvn_print_age( sb, time, 0, 0 );
+              strbuf_addf( sb, "</div></div>\n" );
+            }
+            else
+            {
+              strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"log-date trunc\">unknown</div></div>\n" );
+            }
+            strbuf_addf( sb, "                  <div class=\"col-cmsg\"><div onclick=\"trunc(this)\" class=\"log-cmsg trunc\">%s</div></div>\n", (char *)cmsg );
+            if( query_string && *query_string )
+            {
+              if( ctx.repo.repo_root && *ctx.repo.repo_root )
+              {
+                strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"log-rev trunc\"><a title=\"Compare with Previous\" href=\"/%s/%s%s/?op=diff&rev=%s&%s\">%s</a></div></div>\n", ctx.repo.repo_root, ctx.repo.name, path, (char *)revision, query_string, (char *)revision );
+              }
+              else
+              {
+                strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"log-rev trunc\"><a title=\"Compare with Previous\" href=\"/%s%s/?op=diff&rev=%s&%s\">%s</a></div></div>\n", ctx.repo.name, path, (char *)revision, query_string, (char *)revision );
+              }
+            }
+            else
+            {
+              if( ctx.repo.repo_root && *ctx.repo.repo_root )
+              {
+                strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"log-rev trunc\"><a title=\"Compare with Previous\" href=\"/%s/%s%s/?op=diff&rev=%s\">%s</a></div></div>\n", ctx.repo.repo_root, path, ctx.repo.name, path, (char *)revision, (char *)revision );
+              }
+              else
+              {
+                strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"log-rev trunc\"><a title=\"Compare with Previous\" href=\"/%s%s/?op=diff&rev=%s\">%s</a></div></div>\n", ctx.repo.name, path, (char *)revision, (char *)revision );
+              }
+            }
+            strbuf_addf( sb, "                  <div class=\"col-author\"><div onclick=\"trunc(this)\" class=\"log-author trunc\">%s</div></div>\n", (char *)author );
+            strbuf_addf( sb, "                </div>\n\n" );
+
+            ++printed;
+          }
+
+          xmlFree( date );
+          xmlFree( cmsg );
+          xmlFree( revision );
+          xmlFree( author );
+        }
+        else
+        {
+          if( date )     xmlFree( date );
+          if( cmsg )     xmlFree( cmsg );
+          if( revision ) xmlFree( revision );
+          if( author )   xmlFree( author );
+        }
+      }
+    }
+
+    strbuf_addf( sb, "              </div> <!-- End of Log -->\n\n" );
+
+    /********************************
+      Print log direction:
+     */
+    reminder = count - ctx.query.ofs - printed;
+    if( page_size < count )
+    {
+      int prev, next;
+
+      strbuf_addf( sb, "              <div class=\"log-direction\">\n" );
+      strbuf_addf( sb, "                <div class=\"row\">\n" );
+      strbuf_addf( sb, "                  <div class=\"left col-prev\">\n" );
+      strbuf_addf( sb, "                    <div class=\"prev-log-direction\">\n" );
+
+      if( ctx.query.ofs )
+      {
+        prev = ctx.query.ofs - page_size;
+        if( prev < 0 ) prev = 0;
+
+        if( ctx.env.query_string && *ctx.env.query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/?ofs=%d&%s\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.repo_root, ctx.repo.name, path, prev, ctx.env.query_string );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/?ofs=%d&%s\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.name, path, prev, ctx.env.query_string );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/?ofs=%d\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.repo_root, ctx.repo.name, path, prev );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/?ofs=%d\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.name, path, prev );
+          }
+        }
+      }
+
+      strbuf_addf( sb, "                    </div>\n" );
+      strbuf_addf( sb, "                  </div>\n" );
+      strbuf_addf( sb, "                  <div class=\"right col-next\">\n" );
+      strbuf_addf( sb, "                    <div class=\"next-log-direction\">\n" );
+
+      if( reminder )
+      {
+        next = ctx.query.ofs + page_size;
+
+        if( ctx.env.query_string && *ctx.env.query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/?ofs=%d&%s\">Next &nbsp;&#x226b;</a>\n", ctx.repo.repo_root, ctx.repo.name, path, next, ctx.env.query_string );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/?ofs=%d&%s\">Next &nbsp;&#x226b;</a>\n", ctx.repo.name, path, next, ctx.env.query_string );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/?ofs=%d\">Next &nbsp;&#x226b;</a>\n", ctx.repo.repo_root, ctx.repo.name, path, next );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/?ofs=%d\">Next &nbsp;&#x226b;</a>\n", ctx.repo.name, path, next );
+          }
+        }
+      }
+
+      strbuf_addf( sb, "                    </div>\n" );
+      strbuf_addf( sb, "                  </div>\n" );
+      strbuf_addf( sb, "                </div>\n" );
+      strbuf_addf( sb, "              </div>\n" );
+    }
+    /*
+      End of printing log direction.
+     ********************************/
+
+  }
+
+  free( path );
+  xmlFreeDoc(doc);
+  xmlCleanupParser();
+}
+
+static void csvn_print_log( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+  char *path = NULL;
+
+  if( !sb ) return;
+
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn log --revision %d:0 --xml %s/%s%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn log --xml %s/%s%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      free( path );
+      return;
+    }
+
+    xml_csvn_log( sb, (const struct strbuf *)&buf, relative_path );
+
+    strbuf_release( &buf );
+  }
+
+  free( path );
+  return;
+}
+
+
+void csvn_print_log_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.repo.name )
+  {
+    csvn_print_log( &buf, ctx.repo.relative_path, ctx.query.rev );
+  }
+  else
+  {
+    strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+    strbuf_addf( &buf, "              <p class='leading'>Repository '%s' not found.</p>\n", ctx.repo.name );
+  }
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-log.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-log.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-log.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_LOG_H
+#define    __UI_LOG_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_log_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_LOG_H */
Index: csvn-ui-0.1.5/csvncgi/ui-repolist.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-repolist.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-repolist.c	(revision 12)
@@ -0,0 +1,306 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+#include <ui-repolist.h>
+
+
+
+void csvn_print_direction( struct strbuf *sb, int prev, int next )
+{
+  strbuf_addf( sb, "              <div class=\"direction\">\n" );
+  strbuf_addf( sb, "                <div class=\"row\">\n" );
+  strbuf_addf( sb, "                  <div class=\"left col-prev\">\n" );
+  strbuf_addf( sb, "                    <div class=\"prev-direction\">\n" );
+
+  if( prev )
+  {
+    if( ctx.env.query_string && *ctx.env.query_string )
+      strbuf_addf( sb, "                      <a href=\"%s?ofs=%d&%s\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.relative_href, prev, ctx.env.query_string );
+    else
+      strbuf_addf( sb, "                      <a href=\"%s?ofs=%d\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.relative_href, prev );
+  }
+  else
+  {
+    if( ctx.env.query_string && *ctx.env.query_string )
+      strbuf_addf( sb, "                      <a href=\"%s?%s\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.relative_href, ctx.env.query_string );
+    else
+      strbuf_addf( sb, "                      <a href=\"%s\">&#x226a;&nbsp; Prev</a>\n", ctx.repo.relative_href );
+  }
+
+  strbuf_addf( sb, "                    </div>\n" );
+  strbuf_addf( sb, "                  </div>\n" );
+  strbuf_addf( sb, "                  <div class=\"right col-next\">\n" );
+  strbuf_addf( sb, "                    <div class=\"next-direction\">\n" );
+
+  if( next )
+  {
+    if( ctx.env.query_string && *ctx.env.query_string )
+      strbuf_addf( sb, "                      <a href=\"%s?ofs=%d&%s\">Next &nbsp;&#x226b;</a>\n", ctx.repo.relative_href, next, ctx.env.query_string );
+    else
+      strbuf_addf( sb, "                      <a href=\"%s?ofs=%d\">Next &nbsp;&#x226b;</a>\n", ctx.repo.relative_href, next );
+  }
+  else
+  {
+    if( ctx.env.query_string && *ctx.env.query_string )
+      strbuf_addf( sb, "                      <a href=\"%s?%s\">Next &nbsp;&#x226b;</a>\n", ctx.repo.relative_href, ctx.env.query_string );
+    else
+      strbuf_addf( sb, "                      <a href=\"%s\">Next &nbsp;&#x226b;</a>\n", ctx.repo.relative_href );
+  }
+
+  strbuf_addf( sb, "                    </div>\n" );
+  strbuf_addf( sb, "                  </div>\n" );
+  strbuf_addf( sb, "                </div>\n" );
+  strbuf_addf( sb, "              </div>\n" );
+}
+
+void csvn_print_repolist_header( struct strbuf *sb )
+{
+  strbuf_addf( sb, "              <div class=\"repo-list-header\">\n" );
+  strbuf_addf( sb, "                <div class=\"row\">\n" );
+  strbuf_addf( sb, "                  <div class=\"col-name\">Name</div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-desc\">Description</div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-owner\"><div class=\"repo-owner trunc\">Owner</div></div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-rev\"><div class=\"repo-rev trunc\">Rev</div></div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-idle\"><div class=\"repo-idle trunc\">Idle</div></div>\n" );
+  strbuf_addf( sb, "                </div>\n" );
+  strbuf_addf( sb, "              </div>\n" );
+}
+
+void csvn_print_section_start( struct strbuf *sb, const char *name )
+{
+  if( !sb ) return;
+
+  strbuf_addf( sb, "              <div class=\"section\">\n" );
+  if( name && *name )
+    strbuf_addf( sb, "                <div class=\"section-header\">%s</div>\n\n", name );
+  else
+    strbuf_addf( sb, "                <div class=\"section-header\"></div>\n\n" );
+}
+
+void csvn_print_section_stop( struct strbuf *sb )
+{
+  if( !sb ) return;
+  strbuf_addf( sb, "              </div> <!-- end of section -->\n\n" );
+}
+
+void csvn_print_repo( struct strbuf *sb, struct repo *repo )
+{
+  struct variable repo_root   = { (unsigned char *)"repo-root",   { 0 }, DT_PATH   },
+                  owner       = { (unsigned char *)"owner",       { 0 }, DT_STRING },
+                  description = { (unsigned char *)"description", { 0 }, DT_STRING };
+  struct variable *rroot = NULL;
+  struct variable *auth = NULL;
+  struct variable *desc = NULL;
+
+  struct strbuf buf = STRBUF_INIT;
+  size_t revision   = csvn_repo_last_changed_revision( &buf, repo );
+
+  time_t time = 0;
+
+  if( !sb || !repo || !repo->path ) return;
+
+  rroot = lookup( repo, &repo_root );
+  auth  = lookup( repo, &owner );
+  desc  = lookup( repo, &description );
+  time  = csvn_repo_last_changed_time( repo );
+
+  strbuf_addf( sb, "                <div class=\"row\">\n" );
+  if( rroot )
+    strbuf_addf( sb, "                  <div class=\"col-name\"><a href=\"/%s/%s/\"><div class=\"repo-name\">%s</div></a></div>\n", (const char *)rroot->_v.vptr, repo->path, repo->path );
+  else
+    strbuf_addf( sb, "                  <div class=\"col-name\"><a href=\"/%s/\"><div class=\"repo-name\">%s</div></a></div>\n", repo->path, repo->path );
+
+  if( desc )
+    strbuf_addf( sb, "                  <div class=\"col-desc\"><div onclick=\"trunc(this)\" class=\"repo-desc trunc\">%s</div></div>\n", (const char *)desc->_v.vptr );
+  else
+    strbuf_addf( sb, "                  <div class=\"col-desc\"><div onclick=\"trunc(this)\" class=\"repo-desc trunc\">none</div></div>\n" );
+
+  if( auth )
+    strbuf_addf( sb, "                  <div class=\"col-owner\"><div onclick=\"trunc(this)\" class=\"repo-owner trunc\">%s</div></div>\n", (const char *)auth->_v.vptr );
+  else
+    strbuf_addf( sb, "                  <div class=\"col-owner\"><div onclick=\"trunc(this)\" class=\"repo-owner trunc\">none</div></div>\n" );
+
+  if( revision )
+    strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"repo-rev trunc\">%s</div></div>\n", buf.buf );
+  else
+    strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"repo-rev trunc\">%s</div></div>\n", "0" );
+
+  strbuf_release( &buf );
+
+  if( time != -1 )
+  {
+    struct strbuf buf = STRBUF_INIT;
+    csvn_print_age( &buf, time, 0, TM_YEAR );
+    strbuf_addf( sb, "                  <div class=\"col-idle\"><div onclick=\"trunc(this)\" class=\"repo-idle trunc\">%s</div></div>\n", buf.buf );
+    strbuf_release( &buf );
+  }
+  else
+    strbuf_addf( sb, "                  <div class=\"col-idle\"><div onclick=\"trunc(this)\" class=\"repo-idle trunc\">%s</div></div>\n", "unknown" );
+
+  strbuf_addf( sb, "                </div>\n\n" );
+}
+
+
+int csvn_print_page_repolist( struct strbuf *sb, struct dlist *config, int start_no, int n )
+{
+  struct dlist *list = NULL;
+  int length = 0;
+
+  if( !config || !sb ) return length;
+
+  list = config;
+
+  if( start_no > 0 )
+  {
+    list = parent_section_node_repolist_nth( config, start_no );
+    {
+      struct section *section = (struct section *)list->data;
+      struct dlist *rlist = parent_rlist_node_repolist_nth( config, start_no );
+
+      csvn_print_section_start( sb, (const char *)section->name );
+
+      while( rlist )
+      {
+        struct repo *repo = (struct repo *)rlist->data;
+
+        csvn_print_repo( sb, repo );
+        if( n && ++length == n )
+        {
+          csvn_print_section_stop( sb );
+          return length;
+        }
+
+        rlist = dlist_next( rlist );
+      }
+      csvn_print_section_stop( sb );
+    }
+    list = dlist_next( list );
+  }
+
+  while( list )
+  {
+    struct section *section = (struct section *)list->data;
+
+    if( section->type == ST_REPOS )
+    {
+      csvn_print_section_start( sb, (const char *)section->name );
+
+      struct dlist *rlist = section->list;
+      while( rlist )
+      {
+        struct repo *repo = (struct repo *)rlist->data;
+
+        csvn_print_repo( sb, repo );
+        if( n && ++length == n )
+        {
+          csvn_print_section_stop( sb );
+          return length;
+        }
+
+        rlist = dlist_next( rlist );
+      }
+
+      csvn_print_section_stop( sb );
+    }
+    list = dlist_next( list );
+  }
+
+  return length;
+}
+
+
+void csvn_print_repolist_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+  int psize = 200, rnum = 0, pos = 0, prev, next;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.vars.page_size && *ctx.vars.page_size )
+    sscanf( ctx.vars.page_size, "%d", &psize );
+
+  if( ctx.vars.num_of_repos && *ctx.vars.num_of_repos )
+    sscanf( ctx.vars.num_of_repos, "%d", &rnum );
+
+  if( ctx.query.ofs > 0)       pos = ctx.query.ofs;
+  if( ctx.query.ofs > rnum-1 ) pos = rnum - rnum % psize;
+  if( pos < 0 )                pos = 0;
+
+  prev = pos - psize;
+  if( prev < 0 ) prev = 0;
+
+  next = pos + psize;
+  if( next > rnum-1 ) next = rnum - rnum % psize;
+  if( next < 0 ) next = 0;
+
+  csvn_print_repolist_header( &buf );
+  (void)csvn_print_page_repolist( &buf, config, pos, psize );
+  csvn_print_direction( &buf, prev, next );
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-repolist.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-repolist.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-repolist.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_REPOLIST_H
+#define    __UI_REPOLIST_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_repolist_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_REPOLIST_H */
Index: csvn-ui-0.1.5/csvncgi/ui-shared.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-shared.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-shared.c	(revision 12)
@@ -0,0 +1,1018 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <math.h>
+#include <unistd.h>
+
+#include <libxml/parser.h>
+#include <libxml/tree.h>
+#include <magic.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+void csvn_change_location( const char *location )
+{
+  if( ctx.env.no_http && !strcmp( ctx.env.no_http, "1" ) )
+    return;
+
+  htmlf( "Status: %d %s\n", 302, "Found" );
+  htmlf( "Location: %s\n", location );
+  html( "\n" );
+
+  exit( 0 );
+}
+
+void csvn_print_http_headers( void )
+{
+  if( ctx.env.no_http && !strcmp( ctx.env.no_http, "1" ) )
+    return;
+
+  /*****************************************************
+    If we pass 'Status: 200 OK' header then nginx+uWsgi
+    will duplicate other headers randomly 
+   */
+  if( ctx.page.status != 200 )
+    htmlf( "Status: %d %s\n", ctx.page.status, ctx.page.status_message );
+
+  if( ctx.page.mimetype && ctx.page.charset )
+    htmlf( "Content-Type: %s; charset=%s\n", ctx.page.mimetype, ctx.page.charset );
+  else if( ctx.page.mimetype )
+    htmlf( "Content-Type: %s\n", ctx.page.mimetype );
+
+  if( ctx.page.size )
+    htmlf( "Content-Length: %zd\n", ctx.page.size );
+
+  if( !ctx.env.authenticated )
+    html( "Cache-Control: no-cache, no-store\n" );
+
+  htmlf( "Last-Modified: %s\n", http_date( ctx.page.modified ) );
+  htmlf( "Expires: %s\n", http_date( ctx.page.expires ) );
+
+  html( "\n" );
+}
+
+const struct date_mode *csvn_date_mode( enum date_mode_type type )
+{
+  static struct date_mode mode;
+  mode.type = type;
+  mode.local = 0; /* may be from ctx.cfg.local_time; =0/1 */
+  return &mode;
+}
+/* OR data_mode_from_type():
+   struct date_mode *mode = DATE_MODE( DATE_ISO8601 );
+   but in this case mode.local is always zero!
+ */
+
+static void print_rel_date( struct strbuf *sb, time_t t, int tz,
+                            const char *class, const char *value )
+{
+  if( !sb || !t ) return;
+
+  strbuf_addf( sb, "<span class='%s' title='", class );
+  show_date( sb, t, tz, csvn_date_mode( DATE_ISO8601 ) );
+  strbuf_addf( sb, "'>%s</span>", value );
+}
+
+void csvn_print_age( struct strbuf *sb, time_t t, int tz, time_t max_relative )
+{
+  time_t now, secs;
+  char buf[32] = { 0 };
+  size_t val;
+
+  if( !sb || !t ) return;
+
+  now = time( NULL );
+  secs = now - t;
+  if( secs < 0 )
+    secs = 0;
+
+  if( secs > max_relative && max_relative >= 0 )
+  {
+
+    strbuf_addstr( sb, "<span title='" );
+    show_date( sb, t, tz, csvn_date_mode( DATE_ISO8601 ) );
+    strbuf_addstr( sb, "'>" );
+    show_date( sb, t, tz, csvn_date_mode( DATE_SHORT ) );
+    strbuf_addstr( sb, "</span>" );
+    return;
+  }
+
+  if( secs < TM_HOUR * 2 )
+  {
+    val = (size_t)round(secs * 1.0 / TM_MIN);
+    snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" minute", "%"PRIdMAX" minutes", val), val );
+    print_rel_date( sb, t, tz, "age-mins", (const char *)&buf[0] );
+    return;
+  }
+  if( secs < TM_DAY * 2 )
+  {
+    val = (size_t)round(secs * 1.0 / TM_HOUR);
+    snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" hour", "%"PRIdMAX" hours", val), val );
+    print_rel_date( sb, t, tz, "age-hours", (const char *)&buf[0] );
+    return;
+  }
+  if( secs < TM_WEEK * 2 )
+  {
+    val = (size_t)round(secs * 1.0 / TM_DAY);
+    snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" day", "%"PRIdMAX" days", val), val );
+    print_rel_date( sb, t, tz, "age-days", (const char *)&buf[0] );
+    return;
+  }
+  if( secs < TM_MONTH * 2 )
+  {
+    val = (size_t)round(secs * 1.0 / TM_WEEK);
+    snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" week", "%"PRIdMAX" weeks", val), val );
+    print_rel_date( sb, t, tz, "age-weeks", (const char *)&buf[0] );
+    return;
+  }
+  if( secs < TM_YEAR * 2 )
+  {
+    val = (size_t)round(secs * 1.0 / TM_MONTH);
+    snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" month", "%"PRIdMAX" months", val), val );
+    print_rel_date( sb, t, tz, "age-months", (const char *)&buf[0] );
+    return;
+  }
+
+  val = (size_t)round(secs * 1.0 / TM_YEAR);
+  snprintf( (char *)&buf[0], 32, Q_("%"PRIdMAX" year", "%"PRIdMAX" years", val), val );
+  print_rel_date( sb, t, tz, "age-years", (const char *)&buf[0] );
+}
+
+void csvn_search_repo( const char *path )
+{
+  struct repo *repo = NULL;
+
+  if( !path || !*path ) return;
+
+  repo = lookup_repo( config, path );
+  if( repo )
+  {
+    int position = repo_position( config, repo );
+    if( position != -1 )
+    {
+      char location[1024] = { 0 };
+
+      sprintf( (char *)&location[0], "/?ofs=%d", position );
+      csvn_change_location( (const char *)&location[0] );
+    }
+  }
+}
+
+size_t csvn_repo_last_changed_revision( struct strbuf *sb, struct repo *repo )
+{
+  struct variable  ro_prefix = { (unsigned char *)"checkout-prefix-readonly", { 0 }, DT_PATH };
+  struct variable *prefix = NULL;
+
+  if( !repo || !repo->path ) return 0;
+
+  prefix = lookup( repo, &ro_prefix );
+  if( prefix )
+  {
+    char cmd[1024];
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    snprintf( (char *)&cmd[0], 1024,
+              "svn info --show-item last-changed-revision --no-newline %s/%s/ 2>/dev/null",
+              prefix->_v.vptr, repo->path );
+    p = sys_exec_command( sb, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      return 0;
+    }
+    strbuf_trim( sb );
+    return sb->len;
+  }
+  return 0;
+}
+
+time_t csvn_repo_last_changed_time( struct repo *repo )
+{
+  struct variable  ro_prefix = { (unsigned char *)"checkout-prefix-readonly", { 0 }, DT_PATH };
+  struct variable *prefix = NULL;
+  time_t ret = -1;
+
+  if( !repo || !repo->path ) return ret;
+
+  prefix = lookup( repo, &ro_prefix );
+  if( prefix )
+  {
+    char cmd[1024];
+    struct tm tm;
+    time_t    time = -1;
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    snprintf( (char *)&cmd[0], 1024,
+              "svn info --show-item last-changed-date --no-newline %s/%s/ 2>/dev/null",
+              prefix->_v.vptr, repo->path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return ret;
+    }
+
+    strbuf_trim( &buf );
+    time = parse_date( &tm, (const char *)buf.buf );
+
+    if( time != -1 )
+    {
+      strbuf_release( &buf );
+      return time;
+    }
+
+    strbuf_release( &buf );
+  }
+  return ret;
+}
+
+
+static xmlNode *xml_find_node_by_name( xmlNode *root, const char *name )
+{
+  xmlNode *node = NULL;
+  xmlNode *ret  = NULL;
+
+  if( !name || !*name || !root || !root->children ) return ret;
+
+  for( node = root->children; node; node = node->next )
+  {
+    if( node->type == XML_ELEMENT_NODE )
+    {
+      if( !strcmp( (char *)name, (char *)node->name ) )
+      {
+        return node;
+      }
+    }
+  }
+  return ret;
+}
+
+static void xml_csvn_info( struct strbuf *sb, struct csvn_info *info )
+{
+  xmlDocPtr doc = NULL;
+  xmlNode *root = NULL;
+
+  if( !sb || !sb->len || !info ) return;
+
+  LIBXML_TEST_VERSION
+
+  doc = xmlReadMemory( sb->buf, sb->len, "info.xml", NULL, 0 );
+  if( !doc )
+  {
+    html_fatal( "cannot parse svn info.xml" );
+    return;
+  }
+
+  root = xmlDocGetRootElement( doc );
+  if( !root )
+  {
+    xmlFreeDoc( doc );
+    xmlCleanupParser();
+    return;
+  }
+
+  if( !strcmp( "info", (char *)root->name ) )
+  {
+    xmlNode *entry = NULL, *commit  = NULL, *cnode   = NULL;
+    xmlChar *content = NULL;
+
+    entry = xml_find_node_by_name( root, "entry" );
+    if( !entry )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return;
+    }
+    content = xmlGetProp( entry, (const unsigned char *)"kind" );
+    if( !content )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return;
+    }
+    {
+      if( !strcmp( (char *)content, "dir" ) )
+        info->kind = KIND_DIR;
+      else if( !strcmp( (char *)content, "file" ) )
+        info->kind = KIND_FILE;
+      else
+        info->kind = KIND_UNKNOWN;
+    }
+    xmlFree( content );
+
+    commit = xml_find_node_by_name( entry, "commit" );
+    if( !commit )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return;
+    }
+    content = xmlGetProp( commit, (const unsigned char *)"revision");
+    if( !content )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return;
+    }
+    info->revision = atoi( (const char *)content );
+    xmlFree( content );
+
+    for( cnode = commit->children; cnode; cnode = cnode->next )
+    {
+      if( cnode->type == XML_ELEMENT_NODE )
+      {
+        if( !strcmp( "author", (char *)cnode->name ) )
+        {
+          content = xmlNodeGetContent( cnode );
+          if( !content ) continue;
+          {
+            int   len = (int)strlen( (const char *)content ) + 1;
+            char *author = (char *)__sbrk( len );
+            memcpy( (void *)author, (const void *)content, len );
+            info->author = (const char *)author;
+          }
+          xmlFree( content );
+        }
+        if( !strcmp( "date", (char *)cnode->name ) )
+        {
+          content = xmlNodeGetContent( cnode );
+          if( !content ) continue;
+          {
+            struct tm tm;
+            time_t    time = -1;
+
+            time = parse_date( &tm, (const char *)content );
+            info->date = time;
+          }
+          xmlFree( content );
+        }
+      }
+    } /* End for( cnode = commit->children; cnode; cnode = cnode->next ) */
+  }
+
+  xmlFreeDoc(doc);
+  xmlCleanupParser();
+}
+
+void csvn_repo_info( struct csvn_info *info, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn info --revision %d --xml %s/%s/ 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0] );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn info --xml %s/%s/ 2>/dev/null",
+                co_prefix, (char *)&repo_path[0] );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    xml_csvn_info( &buf, info );
+    strbuf_release( &buf );
+  }
+  return;
+}
+
+
+static const char *lang_info_by_path( const char *path )
+{
+  char *lang = NULL, *name = NULL, *ext = NULL;
+
+  if( !path || !*path ) return (const char *)lang;
+
+  ext = rindex( path, '.' );
+  if( ext )
+  {
+    if( !strncasecmp( ext, ".mk", 3 )       ||
+        !strncasecmp( ext, ".make", 5 )     ||
+        !strncasecmp( ext, ".Makefile", 9 )   )
+    {
+      lang = (char *)__sbrk( 9 );
+      sprintf( lang, "Makefile" );
+    }
+    else if( !strncasecmp( ext, ".md", 3 ) )
+    {
+      lang = (char *)__sbrk( 9 );
+      sprintf( lang, "Markdown" );
+    }
+    else if( !strncasecmp( ext, ".diff", 5 ) ||
+             !strncasecmp( ext, ".patch", 6 )  )
+    {
+      lang = (char *)__sbrk( 9 );
+      sprintf( lang, "Diff" );
+    }
+    else if( !strncasecmp( ext, ".c", 2 ) ||
+             !strncasecmp( ext, ".h", 2 )   )
+    {
+      lang = (char *)__sbrk( 2 );
+      sprintf( lang, "C" );
+    }
+    else if( !strncasecmp( ext, ".cpp", 4 ) ||
+             !strncasecmp( ext, ".cxx", 4 ) ||
+             !strncasecmp( ext, ".hpp", 4 )   )
+    {
+      lang = (char *)__sbrk( 4 );
+      sprintf( lang, "C++" );
+    }
+    else if( !strncasecmp( ext, ".html", 5 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "HTML" );
+    }
+    else if( !strncasecmp( ext, ".css", 4 ) )
+    {
+      lang = (char *)__sbrk( 4 );
+      sprintf( lang, "CSS" );
+    }
+    else if( !strncasecmp( ext, ".js", 3 ) )
+    {
+      lang = (char *)__sbrk( 11 );
+      sprintf( lang, "javascript" );
+    }
+    else if( !strncasecmp( ext, ".json", 5 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "JSON" );
+    }
+    else if( !strncasecmp( ext, ".less", 5 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "LESS" );
+    }
+    else if( !strncasecmp( ext, ".scss", 5 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "SCSS" );
+    }
+    else if( !strncasecmp( ext, ".pl", 3 ) ||
+             !strncasecmp( ext, ".pm", 3 )   )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "Perl" );
+    }
+    else if( !strncasecmp( ext, ".py", 3 ) )
+    {
+      lang = (char *)__sbrk( 7 );
+      sprintf( lang, "Python" );
+    }
+    else if( !strncasecmp( ext, ".php", 4 ) )
+    {
+      lang = (char *)__sbrk( 4 );
+      sprintf( lang, "PHP" );
+    }
+    else if( !strncasecmp( ext, ".txt", 4 ) )
+    {
+      lang = (char *)__sbrk( 10 );
+      sprintf( lang, "plaintext" );
+    }
+    else if( !strncasecmp( ext, ".go", 3 ) )
+    {
+      lang = (char *)__sbrk( 3 );
+      sprintf( lang, "Go" );
+    }
+  }
+
+  name = rindex( path, '/' );
+  if( name )
+  {
+    ++name;
+    if( !strncasecmp( name, "Makefile", 8 ) )
+    {
+      lang = (char *)__sbrk( 9 );
+      sprintf( lang, "Makefile" );
+    }
+    else if( !strcasecmp( name, "README" ) )
+    {
+      lang = (char *)__sbrk( 10 );
+      sprintf( lang, "Plaintext" );
+    }
+    else if( !strcasecmp( name, "LICENSE" ) )
+    {
+      lang = (char *)__sbrk( 10 );
+      sprintf( lang, "Plaintext" );
+    }
+  }
+
+  /***************************
+    all chances are exhausted. probably highlight.js do it correctly...
+   */
+  /*
+  if( !lang )
+  {
+    lang = (char *)__sbrk( 10 );
+    sprintf( lang, "plaintext" );
+  }
+  */
+
+  return (const char *)lang;
+}
+
+static const char *lang_info( const char *mime_type, const char *path )
+{
+  char *lang = NULL;
+
+  if( !mime_type ) return (const char *)lang;
+
+  if( !strncmp( mime_type, "text/", 5 ) )
+  {
+    if( !strncmp( mime_type, "text/x-c", 8 ) || !strncmp( mime_type, "text/x-csrc", 11 ) )
+    {
+      lang = (char *)__sbrk( 2 );
+      sprintf( lang, "C" );
+    }
+    else if( !strncmp( mime_type, "text/x-diff", 11 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "Diff" );
+    }
+    else if( !strncmp( mime_type, "text/x-makefile", 15 ) )
+    {
+      lang = (char *)__sbrk( 9 );
+      sprintf( lang, "Makefile" );
+    }
+    else if( !strncmp( mime_type, "text/x-shell", 12 ) )
+    {
+      lang = (char *)__sbrk( 5 );
+      sprintf( lang, "Bash" );
+    }
+
+    /*
+      The 'text/plain;' mime type does not mean that the file contains plain text.
+      But we have to identify the language:
+     */
+    if( !lang && path )
+    {
+      /* Here we can make lang identification by filename or extension */
+      lang = (char *)lang_info_by_path( path );
+    }
+  }
+
+  return (const char *)lang;
+}
+
+static const char *mime_info( struct csvn_info *info, const char *buffer, size_t length )
+{
+  const char *mime = NULL;
+  magic_t     magic;
+
+  if( !info || !buffer || !length ) return mime;
+
+  magic = magic_open( MAGIC_MIME );
+  if( !magic )
+  {
+    html_fatal( "unable to initialize magic library" );
+    return mime;
+  }
+  if( magic_load( magic, NULL ) != 0 )
+  {
+    html_fatal( "cannot load magic database - %s\n", magic_error( magic ) );
+    magic_close( magic );
+    return mime;
+  }
+
+  mime = magic_buffer( magic, buffer, length );
+  if( mime )
+  {
+    int len = (int)strlen( mime ) + 1;
+    char *mime_type = (char *)__sbrk( len );
+    memcpy( (void *)mime_type, (const void *)mime, len );
+    info->mime = (const char *)mime_type;
+  }
+
+  magic_close( magic );
+  return mime;
+}
+
+void csvn_rpath_mime_info( struct csvn_info *info, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !info || !relative_path ) return;
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat --revision %d %s/%s/%s 2>/dev/null | tr -d '\\0' | head -c 1024",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn cat %s/%s/%s 2>/dev/null | tr -d '\\0' | head -c 1024",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+    if( buf.buf[0] )
+    {
+      mime_info( info, (const char *)buf.buf, buf.len );
+      info->lang = lang_info( (const char *)(info->mime), relative_path );
+    }
+    strbuf_release( &buf );
+  }
+  return;
+}
+
+void csvn_rpath_info( struct csvn_info *info, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+
+  if( !info || !relative_path ) return;
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn info --revision %d --xml %s/%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], relative_path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn info --xml %s/%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], relative_path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    xml_csvn_info( &buf, info );
+    if( info->kind == KIND_FILE )
+      csvn_rpath_mime_info( info, relative_path, revision );
+    strbuf_release( &buf );
+  }
+  return;
+}
+
+
+static int xml_csvn_dirs_number( const struct strbuf *buf )
+{
+  xmlDocPtr doc = NULL;
+  xmlNode *root = NULL;
+  int count     = 0;
+
+  LIBXML_TEST_VERSION
+
+  doc = xmlReadMemory( buf->buf, buf->len, "list.xml", NULL, 0 );
+  if( !doc )
+  {
+    html_fatal( "cannot parse svn list.xml" );
+    return count;
+  }
+
+  root = xmlDocGetRootElement( doc );
+  if( !root )
+  {
+    xmlFreeDoc( doc );
+    xmlCleanupParser();
+    return count;
+  }
+
+  if( !strcmp( "lists", (char *)root->name ) )
+  {
+    xmlNode *list = NULL, *node = NULL;
+
+    list = xml_find_node_by_name( root, "list" );
+    if( !list )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return count;
+    }
+
+    /************************************************
+      Count directories (excluding 'deadwood' name):
+     */
+    for( node = list->children; node; node = node->next )
+    {
+      if( node->type == XML_ELEMENT_NODE && !strcmp( "entry", (char *)node->name ) )
+      {
+        xmlChar *content = NULL;
+        xmlNode *param   = NULL;
+
+        content = xmlGetProp( node, (const unsigned char *)"kind" );
+        if( !strcmp( (const char *)content, "dir" ) )
+        {
+          xmlChar *name = NULL;
+
+          for( param = node->children; param; param= param->next )
+          {
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "name", (char *)param->name ) )
+            {
+              name = xmlNodeGetContent( param );
+            }
+          }
+
+          if( name && strcmp( (char *)name, "deadwood" ) )
+          {
+            count += 1;
+          }
+
+          if( name )
+            xmlFree( name );
+        }
+        xmlFree( content );
+      }
+    }
+  }
+
+  xmlFreeDoc(doc);
+  xmlCleanupParser();
+
+  return count;
+}
+
+
+void csvn_repo_branches_number( struct csvn_repository *rctx )
+{
+  const char *prefix = NULL, *name = NULL, *branches = NULL;
+
+  if( !rctx ) return;
+
+  name     = rctx->name;
+  branches = rctx->branches;
+  prefix   = rctx->checkout_ro_prefix;
+
+  if( prefix && name && branches )
+  {
+    char cmd[1024];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    snprintf( (char *)&cmd[0], 1024, "svn list --xml %s/%s/%s 2>/dev/null", prefix, name, branches );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    rctx->nbranches = xml_csvn_dirs_number( (const struct strbuf *)&buf );
+
+    strbuf_release( &buf );
+  }
+  return;
+}
+
+void csvn_repo_tags_number( struct csvn_repository *rctx )
+{
+  const char *prefix = NULL, *name = NULL, *tags = NULL;
+
+  if( !rctx ) return;
+
+  name   = rctx->name;
+  tags   = rctx->tags;
+  prefix = rctx->checkout_ro_prefix;
+
+  if( prefix && name && tags )
+  {
+    char cmd[1024];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    snprintf( (char *)&cmd[0], 1024, "svn list --xml %s/%s/%s 2>/dev/null", prefix, name, tags );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      return;
+    }
+
+    rctx->ntags = xml_csvn_dirs_number( (const struct strbuf *)&buf );
+
+    strbuf_release( &buf );
+  }
+  return;
+}
+
+void csvn_svn_version( struct csvn_versions *vctx )
+{
+  char cmd[1024];
+  struct strbuf buf = STRBUF_INIT;
+  pid_t p = (pid_t) -1;
+  int   rc;
+
+  char *version = NULL;
+  int   len = 0;
+
+  if( !vctx ) return;
+
+  snprintf( (char *)&cmd[0], 1024, "svn --version --quiet 2>/dev/null" );
+  p = sys_exec_command( &buf, cmd );
+  rc = sys_wait_command( p, NULL );
+  if( rc != 0 )
+  {
+    strbuf_release( &buf );
+    return;
+  }
+
+  strbuf_trim( &buf );
+
+  len = (int)strlen( buf.buf ) + 1;
+  version = (char *)__sbrk( len );
+  memcpy( (void *)version, (const void *)buf.buf, (size_t)len );
+  vctx->subversion = (const char *)version;
+
+  strbuf_release( &buf );
+
+  return;
+}
+
+void csvn_nginx_version( struct csvn_versions *vctx )
+{
+  char cmd[1024];
+  struct strbuf buf = STRBUF_INIT;
+  pid_t p = (pid_t) -1;
+  int   rc;
+
+  char *version = NULL;
+  int   len = 0;
+
+  if( !vctx ) return;
+
+  snprintf( (char *)&cmd[0], 1024, "nginx -v 2>&1 | cut -f2 -d'/'" );
+  p = sys_exec_command( &buf, cmd );
+  rc = sys_wait_command( p, NULL );
+  if( rc != 0 )
+  {
+    strbuf_release( &buf );
+    return;
+  }
+
+  if( buf.buf[0] )
+  {
+    strbuf_trim( &buf );
+
+    len = (int)strlen( buf.buf ) + 1;
+    version = (char *)__sbrk( len );
+    memcpy( (void *)version, (const void *)buf.buf, (size_t)len );
+    vctx->nginx = (const char *)version;
+  }
+
+  strbuf_release( &buf );
+
+  return;
+}
+
+
+void csvn_print_404_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+  strbuf_addf( &buf, "              <h1>Requested resource not found</h1>\n" );
+  strbuf_addf( &buf, "              <p class='leading'>Please check the requested URL or try again later.</p>\n" );
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
+
+
+void csvn_print_raw_file( struct strbuf *sb, const char *mime )
+{
+  struct strbuf buf = STRBUF_INIT;
+  char *p = (char *)mime;
+
+  char *http_format = "Date: %s\n"
+                      "Content-Type: %s\n"
+                      "Content-Length: %ld\n\n";
+
+  if( !sb || !mime ) return;
+
+  while( *p && *p != ';' ) ++p;
+  if( *p ) *p = '\0';
+
+  strbuf_addf( &buf, http_format, http_date( time(NULL) ), mime, sb->len );
+  strbuf_addbuf( &buf, (const struct strbuf *)sb );
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+
+  exit( 0 );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-shared.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-shared.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-shared.h	(revision 12)
@@ -0,0 +1,49 @@
+
+#ifndef    __UI_SHARED_H
+#define    __UI_SHARED_H
+
+/*********************************
+  Limits used for relative dates:
+ */
+#define TM_MIN    60
+#define TM_HOUR  (TM_MIN * 60)
+#define TM_DAY   (TM_HOUR * 24)
+#define TM_WEEK  (TM_DAY * 7)
+#define TM_YEAR  (TM_DAY * 365)
+#define TM_MONTH (TM_YEAR / 12.0)
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_http_headers( void );
+
+extern const struct date_mode *csvn_date_mode( enum date_mode_type type );
+extern void csvn_print_age( struct strbuf *sb, time_t t, int tz, time_t max_relative );
+
+extern void csvn_search_repo( const char *path );
+
+extern size_t csvn_repo_last_changed_revision( struct strbuf *sb, struct repo *repo );
+extern time_t csvn_repo_last_changed_time( struct repo *repo );
+
+extern void csvn_repo_info( struct csvn_info *info, int revision );
+extern void csvn_rpath_info( struct csvn_info *info, const char *relative_path, int revision );
+extern void csvn_rpath_mime_info( struct csvn_info *info, const char *relative_path, int revision );
+
+extern void csvn_repo_branches_number( struct csvn_repository *rctx );
+extern void csvn_repo_tags_number( struct csvn_repository *rctx );
+
+extern void csvn_svn_version( struct csvn_versions *vctx );
+extern void csvn_nginx_version( struct csvn_versions *vctx );
+
+
+extern void csvn_print_404_page( void );
+extern void csvn_print_raw_file( struct strbuf *sb, const char *mime );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_SHARED_H */
Index: csvn-ui-0.1.5/csvncgi/ui-tree.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-tree.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-tree.c	(revision 12)
@@ -0,0 +1,809 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#ifdef HAVE_INTTYPES_H
+#include <inttypes.h>
+#else
+#include <stdint.h>
+#endif
+#include <stddef.h>   /* offsetof(3) */
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <locale.h>
+#include <unistd.h>
+
+#include <libxml/parser.h>
+#include <libxml/tree.h>
+
+#include <nls.h>
+
+#include <defs.h>
+
+#include <fatal.h>
+#include <http.h>
+#include <html.h>
+
+#include <cmpvers.h>
+#include <dlist.h>
+#include <strbuf.h>
+#include <repolist.h>
+#include <wrapper.h>
+#include <system.h>
+#include <date.h>
+
+#include <ctx.h>
+#include <ui-shared.h>
+
+
+/********************************
+  Sorted dlist functions:
+ */
+struct tree_line {
+  char *name;
+  char *revision;
+  char *date;
+  char *size;
+};
+
+static struct dlist *directories = NULL;
+static struct dlist *files       = NULL;
+
+static struct tree_line *tree_line_alloc( const char *name, const char *revision, const char *date, const char *size  )
+{
+  struct tree_line *line = NULL;
+  line = (struct tree_line *)xmalloc( sizeof(struct tree_line) );
+
+  if( name )     { line->name     = xstrdup( name );     }
+  if( revision ) { line->revision = xstrdup( revision ); }
+  if( date )     { line->date     = xstrdup( date );     }
+  if( size )     { line->size     = xstrdup( size );     }
+
+  return line;
+}
+
+static void __line_free( void *data, void *user_data )
+{
+  struct tree_line *line = (struct tree_line *)data;
+  if( line )
+  {
+    if( line->name )     { free( line->name );     line->name     = NULL; }
+    if( line->revision ) { free( line->revision ); line->revision = NULL; }
+    if( line->date )     { free( line->date );     line->date     = NULL; }
+    if( line->size )     { free( line->size );     line->size     = NULL; }
+
+    free( line );
+  }
+}
+
+static struct dlist *tree_lines_free( struct dlist *lines )
+{
+  if( lines )
+  {
+    dlist_free( lines, __line_free );
+    lines = NULL;
+  }
+  return lines;
+}
+
+static int __cmp_tree_lines_bytag( const void *a, const void *b )
+{
+  char *v1 = NULL, *v2 = NULL;
+  int   ret = -1;
+
+  struct tree_line *line1 = (struct tree_line *)a;
+  struct tree_line *line2 = (struct tree_line *)b;
+
+  if( line1->name && line2->name )
+  {
+    v1 = line1->name;
+    v2 = line2->name;
+    while( *v1 && !isdigit( *v1 ) ) ++v1;
+    while( *v2 && !isdigit( *v2 ) ) ++v2;
+    ret = strcmp( line1->name, line2->name );
+  }
+  else
+    return ret;
+
+  if( !*v1 || !*v2 )
+  {
+    return ret;
+  }
+
+  /******************************************
+    sort reversive to show newest tag first:
+   */
+  return -cmp_version( (const char *)v1, (const char *)v2 );
+}
+
+static struct dlist *tree_lines_sort_bytag( struct dlist *lines )
+{
+  if( lines ) { lines = dlist_sort( lines, __cmp_tree_lines_bytag ); }
+  return lines;
+}
+/*
+  End of sorted dlist functions.
+ ********************************/
+
+
+static const char *is_file_executable( const char *relative_path, const char *name, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *repo_name = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+  const char *ret  = "";
+  char *path = NULL;
+
+  if( !name ) return ret;
+
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], repo_name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn propget svn:executable --revision %d %s/%s%s/%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], path, name );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn propget svn:executable %s/%s%s/%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], path, name );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      free( path );
+      return "";
+    }
+
+    strbuf_trim( &buf );
+    if( buf.buf[0] == '*' )
+      ret = " exec";
+    strbuf_release( &buf );
+  }
+
+  free( path );
+  return ret;
+}
+
+
+static xmlNode *xml_find_node_by_name( xmlNode *root, const char *name )
+{
+  xmlNode *node = NULL;
+  xmlNode *ret  = NULL;
+
+  if( !name || !*name || !root || !root->children ) return ret;
+
+  for( node = root->children; node; node = node->next )
+  {
+    if( node->type == XML_ELEMENT_NODE )
+    {
+      if( !strcmp( (char *)name, (char *)node->name ) )
+      {
+        return node;
+      }
+    }
+  }
+  return ret;
+}
+
+static void xml_csvn_tree( const struct strbuf *buf )
+{
+  xmlDocPtr doc = NULL;
+  xmlNode *root = NULL;
+
+  if( !buf || !buf->buf ) return;
+
+  LIBXML_TEST_VERSION
+
+  doc = xmlReadMemory( buf->buf, buf->len, "list.xml", NULL, 0 );
+  if( !doc )
+  {
+    html_fatal( "cannot parse svn list.xml" );
+    return;
+  }
+
+  root = xmlDocGetRootElement( doc );
+  if( !root )
+  {
+    xmlFreeDoc( doc );
+    xmlCleanupParser();
+    return;
+  }
+
+  if( !strcmp( "lists", (char *)root->name ) )
+  {
+    xmlNode *list = NULL, *node = NULL;
+
+    list = xml_find_node_by_name( root, "list" );
+    if( !list )
+    {
+      xmlFreeDoc( doc );
+      xmlCleanupParser();
+      return;
+    }
+
+    /****************************
+      Collect directories first:
+     */
+    for( node = list->children; node; node = node->next )
+    {
+      if( node->type == XML_ELEMENT_NODE && !strcmp( "entry", (char *)node->name ) )
+      {
+        xmlChar *content = NULL;
+        xmlNode *param   = NULL;
+
+        content = xmlGetProp( node, (const unsigned char *)"kind" );
+        if( !strcmp( (const char *)content, "dir" ) )
+        {
+          xmlChar *name = NULL, *revision = NULL, *date = NULL;
+
+          for( param = node->children; param; param= param->next )
+          {
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "name", (char *)param->name ) )
+            {
+              name = xmlNodeGetContent( param );
+            }
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "commit", (char *)param->name ) )
+            {
+              xmlNode *commit_date = NULL;
+              revision = xmlGetProp( param, (const unsigned char *)"revision" );
+              commit_date = xml_find_node_by_name( param, "date" );
+              if( commit_date )
+                date = xmlNodeGetContent( commit_date );
+            }
+          } /* End for entry parameters */
+
+          if( name && revision && date )
+          {
+            struct tree_line *line = NULL;
+
+            line = tree_line_alloc( (const char *)name, (const char *)revision, (const char *)date, NULL );
+            directories = dlist_append( directories, (void *)line );
+
+            xmlFree( name );
+            xmlFree( revision );
+            xmlFree( date );
+          }
+          else
+          {
+            if( name )     xmlFree( name );
+            if( revision ) xmlFree( revision );
+            if( date )     xmlFree( date );
+          }
+        }
+        xmlFree( content );
+      }
+    }
+
+    /****************************
+      Collect files:
+     */
+    for( node = list->children; node; node = node->next )
+    {
+      if( node->type == XML_ELEMENT_NODE && !strcmp( "entry", (char *)node->name ) )
+      {
+        xmlChar *content = NULL;
+        xmlNode *param   = NULL;
+
+        content = xmlGetProp( node, (const unsigned char *)"kind" );
+        if( !strcmp( (const char *)content, "file" ) )
+        {
+          xmlChar *name = NULL, *size = NULL, *revision = NULL, *date = NULL;
+
+          for( param = node->children; param; param= param->next )
+          {
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "name", (char *)param->name ) )
+            {
+              name = xmlNodeGetContent( param );
+            }
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "size", (char *)param->name ) )
+            {
+              size = xmlNodeGetContent( param );
+            }
+            if( param->type == XML_ELEMENT_NODE && !strcmp( "commit", (char *)param->name ) )
+            {
+              xmlNode *commit_date = NULL;
+              revision = xmlGetProp( param, (const unsigned char *)"revision" );
+              commit_date = xml_find_node_by_name( param, "date" );
+              if( commit_date )
+                date = xmlNodeGetContent( commit_date );
+            }
+          } /* End for entry parameters */
+
+          if( name && size && revision && date )
+          {
+            struct tree_line *line = NULL;
+
+            line = tree_line_alloc( (const char *)name, (const char *)revision, (const char *)date, (const char *)size );
+            files = dlist_append( files, (void *)line );
+
+            xmlFree( name );
+            xmlFree( size );
+            xmlFree( revision );
+            xmlFree( date );
+          }
+          else
+          {
+            if( name )     xmlFree( name );
+            if( size )     xmlFree( size );
+            if( revision ) xmlFree( revision );
+            if( date )     xmlFree( date );
+          }
+        }
+        xmlFree( content );
+      }
+    }
+  }
+
+  xmlFreeDoc(doc);
+  xmlCleanupParser();
+}
+
+
+static void dlist_csvn_tree( struct strbuf *sb, const char *relative_path, int rev )
+{
+  char  *path = NULL;
+
+  if( !sb || !sb->len ) return;
+
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  if( path && *path && !strcmp( (char *)&path[1], ctx.repo.tags ) )
+  {
+    directories = tree_lines_sort_bytag( directories );
+  }
+
+  strbuf_addstr( sb, "\n" );
+  strbuf_addf( sb, "              <div class=\"repo-tree-header\">\n" );
+  strbuf_addf( sb, "                <div class=\"row\">\n" );
+  strbuf_addf( sb, "                  <div class=\"col-path\">Path</div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-size\"><div class=\"tree-size trunc\">Size</div></div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-rev\"><div class=\"tree-rev trunc\">Rev</div></div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-date\"><div class=\"tree-date trunc\">Date</div></div>\n" );
+  strbuf_addf( sb, "                  <div class=\"col-links\"><div class=\"tree-links trunc\">Links</div></div>\n" );
+  strbuf_addf( sb, "                </div>\n" );
+  strbuf_addf( sb, "              </div>\n\n" );
+
+  strbuf_addf( sb, "              <div class=\"tree\">\n\n" );
+
+  /**************************
+    Print directories first:
+   */
+  if( directories )
+  {
+    struct dlist *list = directories;
+    while( list )
+    {
+      struct tree_line *line = (struct tree_line *)list->data;
+
+      if( line->name && line->revision && line->date )
+      {
+        struct tm   tm;
+        time_t      time = -1;
+        const char *query_string = ctx_remove_query_param( ctx.env.query_string, "rev" );
+
+        query_string = ctx_remove_query_param( query_string, "op" );
+
+        time = parse_date( &tm, (const char *)line->date );
+
+        strbuf_addf( sb, "                <div class=\"row\">\n" );
+        if( ctx.env.query_string && *ctx.env.query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s/%s%s/%s/?%s\"><div class=\"tree-path dir\">%s/</div></a></div>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, ctx.env.query_string, line->name );
+          }
+          else
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s%s/%s/?%s\"><div class=\"tree-path dir\">%s/</div></a></div>\n", ctx.repo.name, path, line->name, ctx.env.query_string, line->name );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s/%s%s/%s/\"><div class=\"tree-path dir\">%s/</div></a></div>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->name );
+          }
+          else
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s%s/%s/\"><div class=\"tree-path dir\">%s/</div></a></div>\n", ctx.repo.name, path, line->name, line->name );
+          }
+        }
+        strbuf_addf( sb, "                  <div class=\"col-size\"><div onclick=\"trunc(this)\" class=\"tree-size trunc\">4096</div></div>\n" );
+        strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"tree-rev trunc\">%s</div></div>\n", line->revision );
+        if( time != -1 )
+        {
+          strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"tree-date trunc\">" );
+          csvn_print_age( sb, time, 0, 0 );
+          strbuf_addf( sb, "</div></div>\n" );
+        }
+        else
+        {
+          strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"tree-date trunc\">unknown</div></div>\n" );
+        }
+        strbuf_addf( sb, "                  <div class=\"col-links\">\n" );
+        strbuf_addf( sb, "                    <div onclick=\"trunc(this)\" class=\"tree-links trunc\">\n" );
+        if( query_string && *query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=log&rev=%s&%s\">log</a> &nbsp;\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=diff&rev=%s&%s\">diff</a>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision, query_string );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=log&rev=%s&%s\">log</a> &nbsp;\n", ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=diff&rev=%s&%s\">diff</a>\n", ctx.repo.name, path, line->name, line->revision, query_string );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=log&rev=%s\">log</a> &nbsp;\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=diff&rev=%s\">diff</a>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=log&rev=%s\">log</a> &nbsp;\n", ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=diff&rev=%s\">diff</a>\n", ctx.repo.name, path, line->name, line->revision );
+          }
+        }
+        strbuf_addf( sb, "                    </div>\n" );
+        strbuf_addf( sb, "                  </div>\n" );
+        strbuf_addf( sb, "                </div>\n\n" );
+      }
+
+      list = dlist_next( list );
+    }
+    directories = tree_lines_free( directories );
+  }
+
+  /**************************
+    Print files:
+   */
+  if( files )
+  {
+    struct dlist *list = files;
+    while( list )
+    {
+      struct tree_line *line = (struct tree_line *)list->data;
+
+      if( line->name && line->size && line->revision && line->date )
+      {
+        struct tm   tm;
+        time_t      time = -1;
+        const char *query_string = ctx_remove_query_param( ctx.env.query_string, "rev" );
+        const char *exec         = is_file_executable( relative_path, (const char *)line->name, rev );
+
+        query_string = ctx_remove_query_param( query_string, "op" );
+
+        time = parse_date( &tm, (const char *)line->date );
+
+        strbuf_addf( sb, "                <div class=\"row\">\n" );
+        if( ctx.env.query_string && *ctx.env.query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s/%s%s/%s/?%s\"><div class=\"tree-path file%s\">%s</div></a></div>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, ctx.env.query_string, exec, line->name );
+          }
+          else
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s%s/%s/?%s\"><div class=\"tree-path file%s\">%s</div></a></div>\n", ctx.repo.name, path, line->name, ctx.env.query_string, exec, line->name );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s/%s%s/%s/\"><div class=\"tree-path file%s\">%s</div></a></div>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, exec, line->name );
+          }
+          else
+          {
+            strbuf_addf( sb, "                  <div class=\"col-path\"><a href=\"/%s%s/%s/\"><div class=\"tree-path file%s\">%s</div></a></div>\n", ctx.repo.name, path, line->name, exec, line->name );
+          }
+        }
+        strbuf_addf( sb, "                  <div class=\"col-size\"><div onclick=\"trunc(this)\" class=\"tree-size trunc\">%s</div></div>\n", line->size );
+        strbuf_addf( sb, "                  <div class=\"col-rev\"><div onclick=\"trunc(this)\" class=\"tree-rev trunc\">%s</div></div>\n", line->revision );
+        if( time != -1 )
+        {
+          strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"tree-date trunc\">" );
+          csvn_print_age( sb, time, 0, 0 );
+          strbuf_addf( sb, "</div></div>\n" );
+        }
+        else
+        {
+          strbuf_addf( sb, "                  <div class=\"col-date\"><div onclick=\"trunc(this)\" class=\"tree-date trunc\">unknown</div></div>\n" );
+        }
+        strbuf_addf( sb, "                  <div class=\"col-links\">\n" );
+        strbuf_addf( sb, "                    <div onclick=\"trunc(this)\" class=\"tree-links trunc\">\n" );
+        if( query_string && *query_string )
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=log&rev=%s&%s\">log</a> &nbsp;\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=diff&rev=%s&%s\">diff &nbsp;</a>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=blame&rev=%s&%s\">blame</a>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision, query_string );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=log&rev=%s&%s\">log</a> &nbsp;\n", ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=diff&rev=%s&%s\">diff &nbsp;</a>\n", ctx.repo.name, path, line->name, line->revision, query_string );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=blame&rev=%s&%s\">blame</a>\n", ctx.repo.name, path, line->name, line->revision, query_string );
+          }
+        }
+        else
+        {
+          if( ctx.repo.repo_root && *ctx.repo.repo_root )
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=log&rev=%s\">log</a> &nbsp;\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=diff&rev=%s\">diff</a> &nbsp;\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s/%s%s/%s/?op=blame&rev=%s\">blame</a>\n", ctx.repo.repo_root, ctx.repo.name, path, line->name, line->revision );
+          }
+          else
+          {
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=log&rev=%s\">log</a> &nbsp;\n", ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=diff&rev=%s\">diff</a> &nbsp;\n", ctx.repo.name, path, line->name, line->revision );
+            strbuf_addf( sb, "                      <a href=\"/%s%s/%s/?op=blame&rev=%s\">blame</a>\n", ctx.repo.name, path, line->name, line->revision );
+          }
+        }
+        strbuf_addf( sb, "                    </div>\n" );
+        strbuf_addf( sb, "                  </div>\n" );
+        strbuf_addf( sb, "                </div>\n\n" );
+      }
+
+      list = dlist_next( list );
+    }
+    files = tree_lines_free( files );
+  }
+
+  strbuf_addf( sb, "              </div> <!-- End of Tree -->\n\n" );
+
+  free( path );
+}
+
+static void csvn_print_tree( struct strbuf *sb, const char *relative_path, int revision )
+{
+  const char *co_prefix = ctx.repo.checkout_ro_prefix;
+  const char *name      = ctx.repo.name;
+  const char *repo_root = ctx.repo.repo_root;
+  char *path = NULL;
+
+  if( !sb ) return;
+
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  if( co_prefix )
+  {
+    char repo_path[PATH_MAX] = { 0 };
+    char cmd[PATH_MAX];
+    struct strbuf buf = STRBUF_INIT;
+    pid_t p = (pid_t) -1;
+    int   rc;
+
+    if( repo_root && *repo_root )
+    {
+      strcat( (char *)&repo_path[0], repo_root );
+      strcat( (char *)&repo_path[0], "/" );
+    }
+    strcat( (char *)&repo_path[0], name );
+
+    if( revision )
+      snprintf( (char *)&cmd[0], 1024,
+                "svn list --revision %d --xml %s/%s%s 2>/dev/null",
+                revision, co_prefix, (char *)&repo_path[0], path );
+    else
+      snprintf( (char *)&cmd[0], 1024,
+                "svn list --xml %s/%s%s 2>/dev/null",
+                co_prefix, (char *)&repo_path[0], path );
+    p = sys_exec_command( &buf, cmd );
+    rc = sys_wait_command( p, NULL );
+    if( rc != 0 )
+    {
+      strbuf_release( &buf );
+      free( path );
+      return;
+    }
+
+    xml_csvn_tree( (const struct strbuf *)&buf );
+    strbuf_release( &buf );
+
+    dlist_csvn_tree( sb, relative_path, revision );
+  }
+
+  free( path );
+  return;
+}
+
+static void csvn_print_checkout_urls( struct strbuf *sb, const char *relative_path, int revision )
+{
+  char *path = NULL;
+
+  if( !sb ) return;
+
+  if( relative_path && *relative_path )
+  {
+    path = (char *)xmalloc( strlen( relative_path ) + 2 );
+    path[0] = '/';
+    sprintf( (char *)&path[1], relative_path );
+  }
+  else
+  {
+    path = (char *)xmalloc( 1 );
+    path[0] = '\0';
+  }
+
+  strbuf_addf( sb, "                <div class=\"checkout-box\">\n" );
+  strbuf_addf( sb, "                  <div class=\"checkout-header\">Checkout</div>\n" );
+  strbuf_addf( sb, "                  <div class=\"checkout-urls\">\n" );
+  strbuf_addf( sb, "                    <div class=\"checkout-line\">\n" );
+  strbuf_addf( sb, "                      <div class=\"checkout-perms\">ro:</div>\n" );
+
+  if( revision )
+  {
+    if( ctx.repo.repo_root && *ctx.repo.repo_root )
+    {
+      strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout --revision %d %s/%s/%s%s</div>\n", revision, ctx.repo.checkout_ro_prefix, ctx.repo.repo_root, ctx.repo.name, path );
+    }
+    else
+    {
+      strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout --revision %d %s/%s%s</div>\n", revision, ctx.repo.checkout_ro_prefix, ctx.repo.name, path );
+    }
+  }
+  else
+  {
+    if( ctx.repo.repo_root && *ctx.repo.repo_root )
+    {
+      strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout %s/%s/%s%s</div>\n", ctx.repo.checkout_ro_prefix, ctx.repo.repo_root, ctx.repo.name, path );
+    }
+    else
+    {
+      strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout %s/%s%s</div>\n", ctx.repo.checkout_ro_prefix, ctx.repo.name, path );
+    }
+  }
+
+  strbuf_addf( sb, "                    </div>\n" );
+  if( ctx.repo.checkout_prefix && *ctx.repo.checkout_prefix )
+  {
+    strbuf_addf( sb, "                    <div class=\"checkout-line\">\n" );
+    strbuf_addf( sb, "                      <div class=\"checkout-perms\">rw:</div>\n" );
+
+    if( revision )
+    {
+      if( ctx.repo.repo_root && *ctx.repo.repo_root )
+      {
+        strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout --revision %d %s/%s/%s%s</div>\n", revision, ctx.repo.checkout_prefix, ctx.repo.repo_root, ctx.repo.name, path );
+      }
+      else
+      {
+        strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout --revision %d %s/%s%s</div>\n", revision, ctx.repo.checkout_prefix, ctx.repo.name, path );
+      }
+    }
+    else
+    {
+      if( ctx.repo.repo_root && *ctx.repo.repo_root )
+      {
+        strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout %s/%s/%s%s</div>\n", ctx.repo.checkout_prefix, ctx.repo.repo_root, ctx.repo.name, path );
+      }
+      else
+      {
+        strbuf_addf( sb, "                      <div class=\"checkout-url\">svn checkout %s/%s%s</div>\n", ctx.repo.checkout_prefix, ctx.repo.name, path );
+      }
+    }
+
+    strbuf_addf( sb, "                    </div>\n" );
+  }
+  strbuf_addf( sb, "                  </div>\n" );
+  strbuf_addf( sb, "                </div>\n" );
+
+  free( path );
+}
+
+void csvn_print_tree_page( void )
+{
+  FILE  *fp;
+  struct strbuf buf = STRBUF_INIT;
+
+  fp = xfopen( ctx.page.header, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  strbuf_addf( &buf, "        <div class=\"content segment\">\n" );
+  strbuf_addf( &buf, "          <div class=\"container\">\n" );
+  strbuf_addf( &buf, "            <div class=\"csvn-main-content\">\n" );
+
+  if( ctx.repo.relative_info.kind == KIND_DIR )
+  {
+    if( ctx.repo.name )
+    {
+      csvn_print_tree( &buf, ctx.repo.relative_path, ctx.query.rev );
+      csvn_print_checkout_urls( &buf, ctx.repo.relative_path, ctx.query.rev );
+    }
+    else
+    {
+      strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+      strbuf_addf( &buf, "              <p class='leading'>Repository '%s' not found.</p>\n", ctx.repo.name );
+    }
+  }
+  else
+  {
+    strbuf_addf( &buf, "              <h1>Requested resource cannot be shown</h1>\n" );
+    strbuf_addf( &buf, "              <p class='leading'>This page assume the repository tree to be shown.</p>\n" );
+  }
+
+  strbuf_addf( &buf, "            </div> <!-- End of csvn-main-content -->\n" );
+  strbuf_addf( &buf, "          </div> <!-- End of container -->\n" );
+  strbuf_addf( &buf, "        </div> <!-- End of content segment -->\n" );
+
+  fp = xfopen( ctx.page.footer, "r" );
+  (void)strbuf_env_fread( &buf, fp );
+  fclose( fp );
+
+  ctx.page.size = buf.len;
+  csvn_print_http_headers();
+  strbuf_write( &buf, STDOUT_FILENO );
+  strbuf_release( &buf );
+}
Index: csvn-ui-0.1.5/csvncgi/ui-tree.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/ui-tree.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/ui-tree.h	(revision 12)
@@ -0,0 +1,17 @@
+
+#ifndef    __UI_TREE_H
+#define    __UI_TREE_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+extern void csvn_print_tree_page( void );
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __UI_TREE_H */
Index: csvn-ui-0.1.5/csvncgi/wrapper.c
===================================================================
--- csvn-ui-0.1.5/csvncgi/wrapper.c	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/wrapper.c	(revision 12)
@@ -0,0 +1,305 @@
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/sysinfo.h>
+#include <sys/types.h>
+#include <stdint.h>
+#include <dirent.h>
+#include <sys/stat.h> /* chmod(2)    */
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <string.h>   /* strdup(3)   */
+#include <libgen.h>   /* basename(3) */
+#include <ctype.h>    /* tolower(3)  */
+#include <errno.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pwd.h>
+#include <grp.h>
+#include <stdarg.h>
+#include <poll.h>
+#include <unistd.h>
+
+#include <defs.h>
+#include <wrapper.h>
+
+
+#define WRAPPER_ERRMSG_SIZE 4096
+
+void wrapper_error( const char *fmt, ... )
+{
+  va_list arg_ptr;
+  char  buf[WRAPPER_ERRMSG_SIZE];
+  char  msg[WRAPPER_ERRMSG_SIZE];
+  char *format = "%s: %s\n";
+
+  va_start( arg_ptr, fmt );
+
+  vsnprintf( msg, WRAPPER_ERRMSG_SIZE, (const void *)fmt, arg_ptr );
+
+  va_end( arg_ptr ); /* Reset variable arguments. */
+
+  snprintf( buf, WRAPPER_ERRMSG_SIZE, format, "wrapper", msg );
+
+  (void)write( STDERR_FILENO, buf, strlen( buf ) );
+
+  exit( 1 );
+}
+
+wrapper_errfunc wrapper_fatal = wrapper_error;
+
+
+char *xstrdup( const char *str )
+{
+  char *ret;
+
+  ret = strdup( str );
+  if( !ret )
+    wrapper_fatal( "Out of memory, strdup failed" );
+  return ret;
+}
+
+void *xmalloc( size_t size )
+{
+  void *ret;
+
+  ret = malloc( size );
+  if( !ret )
+  {
+    wrapper_fatal( "Out of memory, malloc failed (tried to allocate %lu bytes)", (unsigned long)size );
+    return NULL;
+  }
+  memset( ret, 0, size );
+  return ret;
+}
+
+void *xrealloc( void *ptr, size_t size )
+{
+  void *ret = NULL;
+
+  ret = realloc( ptr, size );
+  if( !ret && !size )
+    ret = realloc( ptr, 1 );
+  if( !ret )
+    wrapper_fatal( "Out of memory, realloc failed" );
+  return ret;
+}
+
+/************************************************************************
+  Limit size of IO chunks, because huge chunks only cause pain.
+  OS X 64-bit is buggy, returning EINVAL if len >= INT_MAX; and even in
+  the absence of bugs, large chunks can result in bad latencies when
+  you decide to kill the process.
+
+  We pick 8 MiB as our default, but if the platform defines SSIZE_MAX
+  that is smaller than that, clip it to SSIZE_MAX, as a call to read(2)
+  or write(2) larger than that is allowed to fail. As the last resort,
+  we allow a port to pass via CFLAGS e.g. "-DMAX_IO_SIZE=value" to
+  override this, if the definition of SSIZE_MAX given by the platform
+  is broken.
+ ************************************************************************/
+#ifndef MAX_IO_SIZE
+# define MAX_IO_SIZE_DEFAULT (8*1024*1024)
+# if defined(SSIZE_MAX) && (SSIZE_MAX < MAX_IO_SIZE_DEFAULT)
+#  define MAX_IO_SIZE SSIZE_MAX
+# else
+#  define MAX_IO_SIZE MAX_IO_SIZE_DEFAULT
+# endif
+#endif
+
+/*
+  xopen() is the same as open(), but it die()s if the open() fails.
+ */
+int xopen( const char *path, int oflag, ... )
+{
+  mode_t mode = 0;
+  va_list ap;
+
+  /*
+    va_arg() will have undefined behavior if the specified type is not
+    compatible with the argument type. Since integers are promoted to
+    ints, we fetch the next argument as an int, and then cast it to a
+    mode_t to avoid undefined behavior.
+   */
+  va_start( ap, oflag );
+  if( oflag & O_CREAT )
+    mode = va_arg( ap, int );
+  va_end( ap );
+
+  for( ;; )
+  {
+    int fd = open( path, oflag, mode );
+    if( fd >= 0 )
+      return fd;
+    if( errno == EINTR )
+      continue;
+
+    if( (oflag & O_RDWR) == O_RDWR )
+      wrapper_fatal( "could not open '%s' for reading and writing", path );
+    else if( (oflag & O_WRONLY) == O_WRONLY )
+      wrapper_fatal( "could not open '%s' for writing", path );
+    else
+      wrapper_fatal( "could not open '%s' for reading", path );
+  }
+}
+
+static int handle_nonblock( int fd, short poll_events, int err )
+{
+  struct pollfd pfd;
+
+  if( err != EAGAIN && err != EWOULDBLOCK )
+    return 0;
+
+  pfd.fd = fd;
+  pfd.events = poll_events;
+
+  /*
+    no need to check for errors, here;
+    a subsequent read/write will detect unrecoverable errors
+   */
+  poll( &pfd, 1, -1 );
+  return 1;
+}
+
+/*
+  xread() is the same a read(), but it automatically restarts read()
+  operations with a recoverable error (EAGAIN and EINTR). xread()
+  DOES NOT GUARANTEE that "len" bytes is read even if the data is available.
+ */
+ssize_t xread(int fd, void *buf, size_t len)
+{
+  ssize_t nr;
+
+  if( len > MAX_IO_SIZE )
+    len = MAX_IO_SIZE;
+
+  while( 1 )
+  {
+    nr = read( fd, buf, len );
+    if( nr < 0 )
+    {
+      if( errno == EINTR )
+        continue;
+      if( handle_nonblock(fd, POLLIN, errno) )
+        continue;
+    }
+    return nr;
+  }
+}
+
+/*
+  xwrite() is the same a write(), but it automatically restarts write()
+  operations with a recoverable error (EAGAIN and EINTR). xwrite() DOES NOT
+  GUARANTEE that "len" bytes is written even if the operation is successful.
+ */
+ssize_t xwrite( int fd, const void *buf, size_t len )
+{
+  ssize_t nr;
+
+  if( len > MAX_IO_SIZE )
+    len = MAX_IO_SIZE;
+
+  while( 1 )
+  {
+    nr = write( fd, buf, len );
+    if( nr < 0 )
+    {
+      if( errno == EINTR )
+        continue;
+      if( handle_nonblock(fd, POLLOUT, errno) )
+        continue;
+    }
+    return nr;
+  }
+}
+
+ssize_t read_in_full( int fd, void *buf, size_t count )
+{
+  char *p = buf;
+  ssize_t total = 0;
+
+  while( count > 0 )
+  {
+    ssize_t loaded = xread( fd, p, count );
+
+    if (loaded < 0)
+      return -1;
+
+    if (loaded == 0)
+      return total;
+
+    count -= loaded;
+        p += loaded;
+    total += loaded;
+  }
+
+  return total;
+}
+
+ssize_t write_in_full( int fd, const void *buf, size_t count )
+{
+  const char *p = buf;
+  ssize_t total = 0;
+
+  while( count > 0 )
+  {
+    ssize_t written = xwrite( fd, p, count );
+    if( written < 0 )
+       return -1;
+
+    if( !written )
+    {
+      errno = ENOSPC;
+      return -1;
+    }
+    count -= written;
+        p += written;
+    total += written;
+  }
+
+  return total;
+}
+
+int xdup( int fd )
+{
+  int ret = dup( fd );
+  if( ret < 0 )
+    wrapper_fatal( "dup failed" );
+  return ret;
+}
+
+/*
+  xfopen() is the same as fopen(), but it die()s if the fopen() fails.
+ */
+FILE *xfopen( const char *path, const char *mode )
+{
+  for( ;;  )
+  {
+    FILE *fp = fopen( path, mode );
+    if (fp)
+      return fp;
+    if (errno == EINTR)
+      continue;
+
+    if( *mode && mode[1] == '+' )
+      wrapper_fatal( "could not open '%s' for reading and writing", path );
+    else if( *mode == 'w' || *mode == 'a' )
+      wrapper_fatal( "could not open '%s' for writing", path );
+    else
+      wrapper_fatal( "could not open '%s' for reading", path );
+  }
+}
+
+FILE *xfdopen( int fd, const char *mode )
+{
+  FILE *stream = fdopen( fd, mode );
+  if( stream == NULL )
+    wrapper_fatal( "Out of memory? fdopen failed" );
+  return stream;
+}
Index: csvn-ui-0.1.5/csvncgi/wrapper.h
===================================================================
--- csvn-ui-0.1.5/csvncgi/wrapper.h	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi/wrapper.h	(revision 12)
@@ -0,0 +1,38 @@
+
+#ifndef    __WRAPPER_H
+#define    __WRAPPER_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef void (*wrapper_errfunc)( const char *fmt, ... );
+
+extern void wrapper_error( const char *fmt, ... ) __attribute__((format (printf,1,2)));
+extern wrapper_errfunc wrapper_fatal; /* Default Fatal Error Function == wrapper_error() */
+
+
+extern char *xstrdup( const char *str );
+extern void *xmalloc( size_t size );
+extern void *xrealloc( void *ptr, size_t size );
+
+extern int xopen( const char *path, int oflag, ... );
+extern ssize_t xread(int fd, void *buf, size_t len);
+extern ssize_t xwrite( int fd, const void *buf, size_t len );
+
+extern ssize_t read_in_full( int fd, void *buf, size_t count );
+extern ssize_t write_in_full( int fd, const void *buf, size_t count );
+
+extern int xdup( int fd );
+
+extern FILE *xfopen( const char *path, const char *mode );
+extern FILE *xfdopen( int fd, const char *mode );
+
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __WRAPPER_H */
Index: csvn-ui-0.1.5/csvncgi
===================================================================
--- csvn-ui-0.1.5/csvncgi	(nonexistent)
+++ csvn-ui-0.1.5/csvncgi	(revision 12)

Property changes on: csvn-ui-0.1.5/csvncgi
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/defs.h
===================================================================
--- csvn-ui-0.1.5/defs.h	(nonexistent)
+++ csvn-ui-0.1.5/defs.h	(revision 12)
@@ -0,0 +1,32 @@
+
+#ifndef    __DEFS_H
+#define    __DEFS_H
+
+
+#ifndef TRUE
+#define TRUE 1
+#endif
+#ifndef FALSE
+#define FALSE 0
+#endif
+
+#ifndef PATH_MAX
+#define PATH_MAX 4096
+#endif
+
+#ifndef PATH_SEP
+#define PATH_SEP ':'
+#endif
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif  /* __DEFS_H */
Index: csvn-ui-0.1.5/doc/build-packages/archlinux/PKGBUILD
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/archlinux/PKGBUILD	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/archlinux/PKGBUILD	(revision 12)
@@ -0,0 +1,38 @@
+#
+# Maintainer: Andrey V.Kosteltsev <kx@radix.pro>
+#
+pkgname=csvn-ui
+pkgver=0.1.5
+pkgrel=2
+pkgdesc='cSvn-ui CGI Script is a web interface for Subversion Repositories'
+arch=('x86_64')
+url='https://csvn.radix.pro'
+license=('custom')
+depends=('file' 'pcre2' 'libxml2' 'md4c')
+source=("https://ftp.radix.pro/pub/csvn-ui/${pkgname}-${pkgver}.tar.xz")
+md5sums=('..Check MD5 sum before Building Package..')
+
+build() {
+  cd ${pkgname}-${pkgver}
+
+  CFLAGS="-O2 -fPIC -Wno-unused-result" \
+  ./configure \
+    --prefix=/usr \
+    --sysconfdir=/etc \
+    --with-scriptdir=/usr/share/nginx/csvn
+
+  make
+}
+
+package() {
+  cd ${pkgname}-${pkgver}
+
+  make install DESTDIR="${pkgdir}"
+
+  # Gzip man pages:
+  gzip -9 ${pkgdir}/usr/share/man/man5/csvn-ui.rc.5
+
+  # Install documentation:
+  install -d ${pkgdir}/usr/share/doc/${pkgname}-${pkgver}
+  cp -a ChangeLog LICENSE README README.md doc/ ${pkgdir}/usr/share/doc/${pkgname}-${pkgver}
+}
Index: csvn-ui-0.1.5/doc/build-packages/archlinux/README
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/archlinux/README	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/archlinux/README	(revision 12)
@@ -0,0 +1,23 @@
+
+Sytem requires:
+  fakeroot, logrotate, nginx, uwsgi
+
+Build time requires:
+  make, binutils, gcc, bison, autoconf, automake, pkgconfig,
+  file (libmagic), pcre2, libxml2, md4c
+
+Runtime requires:
+  libmagic, pcre2, libxml2, md4c
+
+As non-privileged user:
+
+  $ mkdir build
+  $ cp PKGBUILD build/
+  $ cd build/
+  $ makepkg
+
+As root:
+
+  # pacman -U ./csvn-ui-0.1.5-2-x86_64.pkg.tar.zst
+
+After install you have to configure uWsgi and Nginx servers (see: README.md).
Index: csvn-ui-0.1.5/doc/build-packages/archlinux
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/archlinux	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/archlinux	(revision 12)

Property changes on: csvn-ui-0.1.5/doc/build-packages/archlinux
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/doc/build-packages/rpms/README
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/rpms/README	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/rpms/README	(revision 12)
@@ -0,0 +1,17 @@
+
+To build RPM packages we have to copy source package downloaded
+from https://ftp.radix.pro/pub/csvn-ui directory to /usr/src/packages/SOURSES/
+directory. And also copy the csvn-ui.spec file into /usr/src/packages/SPECS/
+directory. Then edit the package version in the csvn-ui.spec file according
+to source package version.
+
+Dependencies: file-devel, pcre2-devel, libxml2-devel, md4c-devel, md4c-html-devel.
+
+RPMs can be built by following command:
+
+ $ rpmbuild --define "_topdir /usr/src/packages" -ba /usr/src/packages/SPECS/csvn-ui.spec
+
+Resulting RPMs will be saved in /usr/src/packages/SRPMS/ and
+/usr/src/packages/RPMS/`uname -m`/ directories.
+
+After install you have to configure uWsgi and Nginx servers (see: README.md).
Index: csvn-ui-0.1.5/doc/build-packages/rpms/csvn-ui.spec
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/rpms/csvn-ui.spec	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/rpms/csvn-ui.spec	(revision 12)
@@ -0,0 +1,42 @@
+
+Name:       csvn-ui
+Version:    0.1.5
+Release:    2
+Summary:    cSvn-ui a web interface for Subversion repositories
+License:    RADIX-1.0
+Group:      System/base
+Source:     https://ftp.radix.pro/pub/csvn-ui/csvn-ui-0.1.5.tar.xz
+Url:        https://csvn.radix/pro/csvn-ui/
+
+
+%define _sysconfdir /etc
+%define _scriptdir  /srv/www/htdocs/csvn
+
+
+%description
+cSvn-ui CGI Script - is a web interface for Subversion Repositories
+
+%prep
+%setup -q
+
+%build
+./configure \
+  --prefix=/usr \
+  --sysconfdir=%{_sysconfdir} \
+  --with-scriptdir=%{_scriptdir}
+
+%install
+make install DESTDIR=%{buildroot}
+
+%clean
+%{?buildroot:%__rm -rf "%{buildroot}"}
+
+%files
+%defattr(-,root,root)
+%{_datadir}/*
+%doc LICENSE README README.md doc/
+%attr(755,root,root) %{_scriptdir}/csvn-ui.cgi
+%attr(644,root,root) %{_scriptdir}/favicon.ico
+%attr(644,root,root) %{_scriptdir}/robots.txt
+%{_scriptdir}/.csvn/
+
Index: csvn-ui-0.1.5/doc/build-packages/rpms
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/rpms	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/rpms	(revision 12)

Property changes on: csvn-ui-0.1.5/doc/build-packages/rpms
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/doc/build-packages/slackware/README
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/slackware/README	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/slackware/README	(revision 12)
@@ -0,0 +1,7 @@
+
+csvn-ui (a web interface for Subversion repositories)
+
+cSvn-ui CGI Script is a web interface for browsing Subversion
+repositories.
+
+Homepage: https://csvn.radix.pro
Index: csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.SlackBuild
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.SlackBuild	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.SlackBuild	(revision 12)
@@ -0,0 +1,92 @@
+#!/bin/bash
+
+cd $(dirname $0) ; CWD=$(pwd)
+
+PKGNAM=csvn-ui
+VERSION=${VERSION:-$(echo csvn-ui-*.tar.?z* | rev | cut -f 3- -d . | cut -f 1 -d - | rev)}
+BUILD=${BUILD:-2}
+
+# Automatically determine the architecture we're building on:
+if [ -z "$ARCH" ]; then
+  case "$( uname -m )" in
+    i?86) export ARCH=i586 ;;
+    arm*) export ARCH=arm ;;
+    # Unless $ARCH is already set, use uname -m for all other archs:
+       *) export ARCH=$( uname -m ) ;;
+  esac
+fi
+
+if [ "$ARCH" = "i586" ]; then
+  SLKCFLAGS="-O2 -march=i586 -mtune=i686"
+  LIBDIRSUFFIX=""
+elif [ "$ARCH" = "s390" ]; then
+  SLKCFLAGS="-O2"
+  LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+  SLKCFLAGS="-O2 -fPIC"
+  LIBDIRSUFFIX="64"
+else
+  SLKCFLAGS="-O2"
+  LIBDIRSUFFIX=""
+fi
+
+TMP=${TMP:-/tmp}
+PKG=$TMP/package-$PKGNAM
+
+rm -rf $PKG
+mkdir -p $TMP $PKG
+
+cd $TMP
+rm -rf $PKGNAM-$VERSION
+tar xvf $CWD/$PKGNAM-$VERSION.tar.?z* || exit 1
+cd $PKGNAM-$VERSION || exit 1
+
+chown -R root:root .
+find . \
+ \( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
+ -exec chmod 755 {} \+ -o \
+ \( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
+ -exec chmod 644 {} \+
+
+CFLAGS="$SLKCFLAGS" \
+./configure \
+  --prefix=/usr \
+  --sysconfdir=/etc \
+  --libdir=/usr/lib${LIBDIRSUFFIX} \
+  --with-scriptdir=/srv/www/htdocs/csvn \
+  --build=$ARCH-slackware-linux || exit 1
+
+
+make || exit 1
+make install DESTDIR=$PKG || exit 1
+
+find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \
+  | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null
+
+mv $PKG/usr/share/man $PKG/usr/
+gzip -9 $PKG/usr/man/man?/*
+rmdir $PKG/usr/share/man
+
+find $PKG/usr/man -type f -exec gzip -9 {} \;
+
+mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION
+cp -a \
+  ChangeLog LICENSE README README.md doc \
+  $PKG/usr/doc/$PKGNAM-$VERSION
+
+cp -a $CWD/$PKGNAM.info        $PKG/usr/doc/$PKGNAM-$VERSION
+cp -a $CWD/$PKGNAM.SlackBuild  $PKG/usr/doc/$PKGNAM-$VERSION
+
+# If there's a ChangeLog file, installing at least part of the recent history
+# is useful, but don't let it get totally out of control:
+if [ -r ChangeLog ]; then
+  DOCSDIR=$(echo $PKG/usr/doc/*-$VERSION)
+  cat ChangeLog | head -n 1000 > $DOCSDIR/ChangeLog
+  touch -r ChangeLog $DOCSDIR/ChangeLog
+fi
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+
+cd $PKG
+/sbin/makepkg -l y -c n $TMP/$PKGNAM-$VERSION-$ARCH-$BUILD.txz
Index: csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.info
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.info	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/slackware/csvn-ui.info	(revision 12)
@@ -0,0 +1,10 @@
+PRGNAM="csvn-ui"
+VERSION="0.1.5"
+HOMEPAGE="http://csvn.radix.pro"
+DOWNLOAD="https://ftp.radix.pro/pub/csvn-ui/csvn-ui-0.1.5.tar.xz"
+MD5SUM="..Check MD5 sum before Building Package.."
+DOWNLOAD_x86_64=""
+MD5SUM_x86_64=""
+REQUIRES="cscm md4c libpcre2-8 libpcre2-32 libxml2"
+MAINTAINER="Andrey V.Kosteltsev"
+EMAIL="kx@radix.pro"
Index: csvn-ui-0.1.5/doc/build-packages/slackware/slack-desc
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/slackware/slack-desc	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/slackware/slack-desc	(revision 12)
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|' on
+# the right side marks the last column you can put a character in. You must make
+# exactly 11 lines for the formatting to be correct. It's also customary to
+# leave one space after the ':'.
+
+       |-----handy-ruler------------------------------------------------------|
+csvn-ui: csvn-ui (a web interface for Subversion repositories)
+csvn-ui:
+csvn-ui: cSvn-ui CGI Script is a web interface for browsing Subversion
+csvn-ui: repositories.
+csvn-ui:
+csvn-ui:
+csvn-ui: Homepage: https://csvn.radix.pro
+csvn-ui:
+csvn-ui:
+csvn-ui:
+csvn-ui:
Index: csvn-ui-0.1.5/doc/build-packages/slackware
===================================================================
--- csvn-ui-0.1.5/doc/build-packages/slackware	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages/slackware	(revision 12)

Property changes on: csvn-ui-0.1.5/doc/build-packages/slackware
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/doc/build-packages
===================================================================
--- csvn-ui-0.1.5/doc/build-packages	(nonexistent)
+++ csvn-ui-0.1.5/doc/build-packages	(revision 12)

Property changes on: csvn-ui-0.1.5/doc/build-packages
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/doc/csvn-ui.rc.5.md
===================================================================
--- csvn-ui-0.1.5/doc/csvn-ui.rc.5.md	(nonexistent)
+++ csvn-ui-0.1.5/doc/csvn-ui.rc.5.md	(revision 12)
@@ -0,0 +1,609 @@
+
+# [csvn-ui.rc(5) Config File](https://csvn.radix.pro/csvn-ui/trunk/doc/csvn-ui.rc.5.md)
+
+**/etc/csvn-ui.rc** &#8211; **cSvn-ui** CGI Script configuration file describes the Subversion&#8482;
+repositories that should be displayed on the client side.
+
+
+## Table of Contents
+
+* [File Format](#file-format)
+    * [Data Types](#data-types)
+    * [Reserved Variables](#reserved-variables)
+    * [Repository Declaration](#repository-declaration)
+* [Working Example](#working-example)
+* [See Also](#see-also)
+
+
+## File Format
+
+**/etc/csvn-ui.rc** is a regular text file created by user to present Subversion repositories. This file
+reads by [**cscnd(8)**](https://csvn.radix.pro/cscm/trunk/doc/cscmd.8.md) daemon and converts to binary
+form for **cSvn-ui** CGI script. Binary format allows to minimize the time needed for complete HTTP
+responses.
+
+The configuration file consists of a set of variable or repository declarations also configuration
+file can contains section of repository descriptions. The C/C++ comments are available:
+
+```dts
+/****************************
+  Apache's SVN repositories:
+ */
+home-page = "https://svn.apache.org/";
+
+repo 'subversion' {
+  owner = "Apache";
+  description = "Source repository of the Subversion.";
+  checkout-prefix-readonly = 'https://svn.apache.org/repos/asf';
+}
+
+section "Other Repositories" {
+  repo 'other-repository' {
+    . . .
+  }
+  . . .
+}
+```
+
+
+### Data Types
+
+Configuration file assumes three types of variables.
+
+> **int** &#8211; integer constants. Example declaration:
+
+>> ```dts
+>> true = 1;
+>> ```
+
+
+> **string** &#8211; string constants. Example declaration:
+
+>> ```dts
+>> name = "Apache Subversion";
+>> ```
+
+
+> **path** &#8211; path constants. Example declaration:
+
+>> ```dts
+>> path = '/etc/csvn-ui.rc';
+>> ```
+
+
+### Reserved Variables
+
+There is a set of variable names used by **cSvn-ui** CGI Script.
+
+
+#### svn-utc-offset
+
+The integer or string value of UTC offset on the SVN server where repositories are published.
+For example:
+
+```dts
+svn-utc-offset = +0300; /* Europe/Moscow time zone */
+```
+
+
+#### repo-root
+
+The name of directory where some repository is placed related to **svn repositories root** directory.
+For example:
+
+```dts
+repo-root = 'tools';
+```
+
+
+#### checkout-prefix-readonly
+
+The checkout prefix for readonly access to the repository. The value of this variable should
+has **path** type without leadinfg dir-separator. Example declaration:
+
+```dts
+checkout-prefix-readonly = 'svn://example.com';
+checkout-prefix-readonly = 'https://svn.example.com/svn';
+```
+
+Please note that **svn** protocol works match quickly.
+
+
+#### checkout-prefix
+
+The checkout prefix for readwrite access to the repository. The value of this variable should
+has **path** type without leadinfg dir-separator. Example declaration:
+
+```dts
+checkout-prefix = 'svn+ssh://svn@example.com';
+```
+
+This means the access on behalf **svn** system user.
+
+
+#### branches
+
+The name of directory where branches is places. Default value is *'branches'*.
+
+#### trunk
+
+The name of the *trunk* directory. Default value is *'trunks'*.
+
+#### tags
+
+The name of directory where tags are saved. Default value is *'tags'*.
+Example declarations of directory names:
+
+```dts
+branches = 'branches';
+trunk    = 'trunk';
+tags     = 'tags';
+```
+
+
+#### snapshots
+
+The extension of snapshot tarballs. Default value: *'tar.xz'*. Example declaration:
+
+```dts
+snapshots = 'tar.xz';
+```
+
+Currently snapshot variable is not used by **cSvn-ui** CGI Script.
+
+
+#### css
+
+The full name of the CSS style sheet relative to the directory where **cSvn-ui** CGI Sctipt is installed.
+Example declaration:
+
+```dts
+css = '/.csvn/css/csvn.css';
+```
+
+
+#### logo
+
+Url which specifies the source of an image which will be used as a logo (i.e right banner)
+on **cSvn-ui** pages. Default value: *'/.csvn/pixmaps/csvn-banner-280x280.png'*. The path to the
+**logo** also should be set relative to the directory where **cSvn-ui** CGI Script is installed.
+Example declaration:
+
+```dts
+logo = '/.csvn/pixmaps/csvn-banner-280x280.png';
+```
+
+
+#### logo-alt
+
+The string used in HTML as a 'alt' property of the right banner &lt;img&gt; tag.
+Default value: *"Example.org"*. Example declaration:
+
+```dts
+logo-alt = "Example.org";
+```
+
+
+#### logo-link
+
+The string used in HTML as a 'href' property of the right banner image link &lt;a&gt; tag.
+Default value: *"https://example.org"*. Example declaration:
+
+```dts
+logo-link = "https://example.org";
+```
+
+
+#### main-menu-logo
+
+Url which specifies the source of an image which will be used as a logo of the main menu item
+on **cSvn-ui** pages. Default value: *'/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg'*. The path
+to the *main-menu-logo* also should be set relative to the directory where **cSvn-ui** CGI Script
+is installed. Example declaration:
+
+```dts
+main-menu-logo = '/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg';
+```
+
+
+#### favicon-path
+
+The directory name of the *favicon.ico* file without leadind dir-separator.
+Default value: *'/.csvn/pixmaps/favicon'*. Example declaration:
+
+```dts
+favicon-path = '/.csvn/pixmaps/favicon';
+```
+
+This directory name used for finding additional images declared in the HTML **header** of all
+**cSvn-ui** pages.
+
+
+#### syntax-highlight-css
+
+The base name of the CSS style sheet file used for syntax highlighting.
+Default value: *'_csvn.css'*. Example declaration:
+
+```dts
+syntax-highlight-css = '_csvn.css';
+```
+
+**cSvn-ui** CGI Script uses [highlight.js](https://highlightjs.org/) installed into
+`/.csvn/.engines/highlight/${hljs-version}/{css,js}` directories where the default
+*_csvn.css* file is palced too.
+
+
+#### header
+
+The content of the file specified with this option will be included verbatim at the top of all pages.
+Default value: *'/.csvn/html/header.html'*.
+
+
+#### footer
+
+The content of the file specified with this option will be included verbatim at the bottom of all pages.
+Default value: *'/.csvn/html/footer.html'*. Examle of the **header** and the **footer** declarations:
+
+```dts
+header = '/.csvn/html/header.html';
+footer = '/.csvn/html/footer.html';
+```
+
+The **header** and the **footer** files used as template where **cSvn-ui** CGI Script substitute
+placeholders such as `${variable-name}` by their values. For example the `${css}` placeholder
+will be replaced by the value of **css** variable declared in the **/etc/csvn-ui.rc** config file.
+
+
+#### page-size
+
+The **string** or **int** variable which set the length of the repositories list or logs that shown
+in one page by the **cSvn-ui** CGI Script. Default value: 200. Example declaration:
+
+```dts
+page-size = 50; /* 10 ... 200 may be string or integer. Default value is page-size = 200 */
+```
+
+
+#### owner
+
+The **string** variable used in the HTML header of all **cSvn-ui** pages and also in the *Owner* colon
+of the repository list. Default value: *"Andrey V.Kosteltsev"*.
+
+
+#### author
+
+The **string** variable used in the HTML header of all **cSvn-ui** pages. Default value: *"Andrey V.Kosteltsev"*.
+Example declarations of the **owner** and the **author** variables:
+
+```dts
+owner  = "John Smith";
+author = "John Smith";
+```
+
+
+#### title
+
+The **string** variable used in the HTML header of all **cSvn-ui** pages as a page title.
+Default value: *"SVN Repositories"*. Example declaration:
+
+```dts
+title  = "Example.org SVN Repositories";
+```
+
+
+#### description
+
+The **string** variable used in the HTML header of all **cSvn-ui** pages as a page description.
+Default value: *"Subversion repositories hosted at Solar System, Earth"*.
+Example declaration:
+
+```dts
+description  = "Subversion repositories hosted at example.org (St.-Petersburg)";
+```
+
+For a long description the value of this **string** variable can be splitted in the C-style
+by following way:
+
+```dts
+description  = "Subversion repositories"
+               " hosted at example.org "
+               "(St.-Petersburg)";
+```
+
+
+#### keywords
+
+The **string** variable contains space separated keywords used in the HTML header of all **cSvn-ui**
+pages as a page keywords. Default value: *"cSvn repositories"*. Example declaration:
+
+```dts
+keywords = "cSvn-ui cSvn UI CGI Subversion Repositories scm SVN";
+```
+
+
+#### copyright-notice
+
+The **string** variable used in the HTML footer of all **cSvn-ui** pages as a *Copyright Notice*.
+Default value: *"By using any website materials you agree to indicate source."*.
+Example declaration:
+
+```dts
+copyright-notice = "By using any materials you agree with ...";
+```
+
+
+#### copyright
+
+The **string** variable used in the HTML footer of all **cSvn-ui** pages as a *Copyright*.
+Default value: *"&#169; 2020 Andrey V.Kosteltsev. All Rights Reserved."*.
+Example declaration:
+
+```dts
+copyright = "&#169; John Smith (explorer), 1580 - 1631.";
+```
+
+
+#### home-page
+
+The URL of the home page of the project. Default value: *"https://example.org"*.
+Example declaration:
+
+```dts
+home-page = "https://main-site-of-the-project.org";
+```
+
+
+### Analytics variables:
+
+
+#### analytic-links
+
+The path to the file which contains meta tags with site ownership verificaton codes for engines such as *Google Search Console* or
+*Yandex Webmaster*. **cSvn-ui** CGI Script reads the file **analytic-links** in RAW format and includes it into &lt;HEAD&gt; tag of each HTML page.
+Example declaration:
+
+```dts
+analytic-links = '/analytics/links';
+```
+
+Where the file */analytics/links* may contains HTML tags like follow:
+
+```html
+<meta name="google-site-verification" content="..." />
+```
+
+The file name should be defined relative of the path where **cSvn-ui** CGI Script is installed. For example, if **cSvn-ui** CGI Script installed
+into */srv/www/htdocs/csvn* directory and file name declared as */analytics/links* then **cSvn-ui** CGI Script will try to read the
+file */srv/www/htdocs/csvn/analytics/links*.
+
+
+#### analytic-scripts
+
+The path to the file which contains *JavaScripts* for engines such as *Google Search Console* or
+*Yandex Webmaster*. **cSvn-ui** CGI Script reads the file **analytic-scripts** in RAW format and includes it at the end of &lt;HEAD&gt; tag before
+&lt;/HEAD&gt; entry of each HTML page. Example declaration:
+
+```dts
+analytic-scripts = '/analytics/scripts';
+```
+
+Where the file */analytics/scripts* may contains code like follow:
+
+```html
+<!-- Global site tag (gtag.js) - Google Analytics -->
+<script async src="https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX"></script>
+<script>
+  window.dataLayer = window.dataLayer || [];
+  function gtag(){dataLayer.push(arguments);}
+  gtag('js', new Date());
+
+  gtag('config', 'G-XXXXXXXXXX');
+</script>
+```
+
+Please note that the *&lt;script&gt;* tags should be present in the */analytics/scripts* because **cSvn-ui** CGI Script reads this file
+in RAW format and includes it as is.
+
+The variables **analytic-links** and **analytic-scripts** should be declared on the global level of the **/etc/csvn-ui.rc**
+configuration file and cannot be overriden in a repository declaration.
+
+
+### Donation variables:
+
+The **cSvn-ui** CGI Script provides the ability to create a custom donation dialogue. To do this, you need to create a set of three files:
+**CSS**, **HTML**, and **JavaScript** file for automation. You can add a donation dialogue for each repository separately, as well as for the
+entire list of repositories. To enable donation dialogue you have to set the value of **donate** variable to **donate = 1**:
+
+
+#### donate
+
+The integer variable used to enable or disable donation dialogue. Example declaration:
+
+```dts
+donate = 1;
+```
+
+#### donate-css
+
+The name of file contains the stylesheet for donation modal dialogue. Example declaration:
+
+```dts
+donate-css = '/donations/donate.css';
+```
+
+#### donate-html
+
+The name of file contains the HTML code of donation modal dialogue. Example declaration:
+
+```dts
+donate-html = '/donations/donate.html';
+```
+
+#### donate-js
+
+The name of file contains the javascript code for donation modal dialogue automation. Example declaration:
+
+```dts
+donate-js = '/donations/donate.js';
+```
+
+**cSvn-ui** CGI Script includes these files at end of &lt;BODY&gt; tag just before the closing &lt;/BODY&gt; tag. Unlike the others,
+the **donate-html** file should be no more than 8192 bytes in size due to the fact that this file is a template
+and the values of the following two variables are substituted into its body using placeholders *${donate-header}*
+and *${donate-purpose}*:
+
+
+#### donate-header
+
+The title of the donation modal dialogue defined in the **donate-html** file. Example declaration:
+
+```dts
+donate-header = "Donations";
+```
+
+#### donate-purpose
+
+The donation purpose used as value of &lt;input value="..."&gt; tag property in payment form of systems such as **PayPal** or **Yandex.Money**.
+Also this value can be used as a header of modal dialogue content. Example declaration:
+
+```dts
+donate-purpose = "Support for our projects";
+```
+
+Donation dialogue can be defined for each repository separately or defined on global level. In the last case
+the dialogue header and payment purpose may be overriden in the body of a repository declaration like follow:
+
+```dts
+true  = 1;
+false = 0;
+
+donate         = true;
+donate-css     = '/donations/donate.css';
+donate-html    = '/donations/donate.html';
+donate-js      = '/donations/donate.js';
+donate-header  = "Donation";
+donate-purpose = "Support our activities";
+
+section "Tools" {
+  repo 'repo-path' {
+    . . .
+    donate-header  = "Project Donation";
+    donate-purpose = "Support our Project";
+    . . .
+  }
+}
+```
+
+To show the modal dialogue in javascript code **donate-js** the selector **'a.donate'** should be used. For examle, like this:
+
+```php
+var show = document.querySelector( "a.donate" );
+
+/**************
+  Open Dialog:
+ */
+show.onclick = function() {
+  dialog.style.display = "block";
+}
+```
+
+Where the variable *dialog* points to modal dialogue defined in the **donate-html** file.
+
+
+
+### Repository Declaration
+
+The **/etc/csvn-ui.rc** config file should contains at least one repository declaration to be shown
+by the **cSvn-ui** CGI Script. When all expected variables declared in the global section
+the config file the repository declaration can be very simple:
+
+```dts
+repo 'tools' {
+  owner = "John Smith";
+  description = "John Smith's tools source code repository.";
+}
+```
+
+The list of repositories can be splitted in several sections. The section has a name and can
+contains repository declarations only.
+
+```dts
+section "John Smith sources" {
+  repo 'tools' {
+    owner = "John Smith";
+    description = "John Smith's tools source code repository.";
+  }
+  repo 'examples' {
+    owner = "John Smith";
+    description = "John Smith's examples source code.";
+  }
+}
+```
+
+Please note, repositories, unlike sections, do not have a name, but have a **path** to repository.
+So if your repositories in the file system are stored in the `/var/scm/svn` directory, and the
+`tools` repository is located in the `/var/scm/svn/tools` directory, then the path to the repository
+is set relative to the `/var/scm/svn` directory as follows:
+
+```dts
+repo 'tools' {
+  owner = "John Smith";
+  description = "John Smith's tools source code repository.";
+}
+```
+
+
+## Working Example
+
+As an example, we will give a working configuration file in which the **cSvn-ui** repository is presented.
+
+```dts
+svn-utc-offset = +0300;
+
+checkout-prefix-readonly = 'svn://radix.pro';
+checkout-prefix          = 'svn+ssh://svn@radix.pro';
+
+branches = 'branches';
+trunk    = 'trunk';
+tags     = 'tags';
+
+snapshots = 'tar.xz';
+
+css = '/.csvn/css/csvn.css';
+logo = '/.csvn/pixmaps/csvn-banner-280x280.png';
+logo-alt = "Radix.pro";
+logo-link = "https://radix.pro";
+main-menu-logo = '/.csvn/pixmaps/logo/SVN-logo-white-744x744.svg';
+favicon-path = '/.csvn/pixmaps/favicon';
+syntax-highlight-css = '_csvn.css';
+header = '/.csvn/html/header.html';
+footer = '/.csvn/html/footer.html';
+page-size = 200;
+
+owner = "Andrey V.Kosteltsev";
+author = "Andrey V.Kosteltsev";
+title = "Radix.pro SVN Repositories";
+description = "Subversion repositories hosted at radix.pro (St.-Petersburg)";
+keywords = "cSvn repositories";
+copyright = "&#169; Andrey V. Kosteltsev, 2019 &#8211; 2020.";
+copyright-notice = "Where any material of this site is being reproduced, published or issued to others the reference to the source is obligatory.";
+
+home-page = "https://radix.pro/";
+
+section "Tools" {
+  repo 'csvn-ui' {
+    owner = "Andrey V.Kosteltsev";
+    title = "cSvn-ui for SVN Repositories";
+    description = "cSvn-ui &#8211; is a web interface for Subversion&#8482; Repositories written in C";
+    home-page = "https://radix.pro/";
+  }
+}
+
+```
+
+
+## See Also
+
+> [**README**](https://csvn.radix.pro/csvn/trunk/README.md),
+> [**cscmd(8)**](https://csvn.radix.pro/cscm/trunk/doc/cscmd.8.md)
+
Index: csvn-ui-0.1.5/doc
===================================================================
--- csvn-ui-0.1.5/doc	(nonexistent)
+++ csvn-ui-0.1.5/doc	(revision 12)

Property changes on: csvn-ui-0.1.5/doc
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/gettext.h
===================================================================
--- csvn-ui-0.1.5/gettext.h	(nonexistent)
+++ csvn-ui-0.1.5/gettext.h	(revision 12)
@@ -0,0 +1,292 @@
+/* Convenience header for conditional use of GNU <libintl.h>.
+   Copyright (C) 1995-1998, 2000-2002, 2004-2006, 2009-2016 Free Software
+   Foundation, Inc.
+
+   This program is free software: you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+#ifndef _LIBGETTEXT_H
+#define _LIBGETTEXT_H 1
+
+/* NLS can be disabled through the configure --disable-nls option.  */
+#if ENABLE_NLS
+
+/* Get declarations of GNU message catalog functions.  */
+# include <libintl.h>
+
+/* You can set the DEFAULT_TEXT_DOMAIN macro to specify the domain used by
+   the gettext() and ngettext() macros.  This is an alternative to calling
+   textdomain(), and is useful for libraries.  */
+# ifdef DEFAULT_TEXT_DOMAIN
+#  undef gettext
+#  define gettext(Msgid) \
+     dgettext (DEFAULT_TEXT_DOMAIN, Msgid)
+#  undef ngettext
+#  define ngettext(Msgid1, Msgid2, N) \
+     dngettext (DEFAULT_TEXT_DOMAIN, Msgid1, Msgid2, N)
+# endif
+
+#else
+
+/* Solaris /usr/include/locale.h includes /usr/include/libintl.h, which
+   chokes if dcgettext is defined as a macro.  So include it now, to make
+   later inclusions of <locale.h> a NOP.  We don't include <libintl.h>
+   as well because people using "gettext.h" will not include <libintl.h>,
+   and also including <libintl.h> would fail on SunOS 4, whereas <locale.h>
+   is OK.  */
+#if defined(__sun)
+# include <locale.h>
+#endif
+
+/* Many header files from the libstdc++ coming with g++ 3.3 or newer include
+   <libintl.h>, which chokes if dcgettext is defined as a macro.  So include
+   it now, to make later inclusions of <libintl.h> a NOP.  */
+#if defined(__cplusplus) && defined(__GNUG__) && (__GNUC__ >= 3)
+# include <cstdlib>
+# if (__GLIBC__ >= 2 && !defined __UCLIBC__) || _GLIBCXX_HAVE_LIBINTL_H
+#  include <libintl.h>
+# endif
+#endif
+
+/* Disabled NLS.
+   The casts to 'const char *' serve the purpose of producing warnings
+   for invalid uses of the value returned from these functions.
+   On pre-ANSI systems without 'const', the config.h file is supposed to
+   contain "#define const".  */
+# undef gettext
+# define gettext(Msgid) ((const char *) (Msgid))
+# undef dgettext
+# define dgettext(Domainname, Msgid) ((void) (Domainname), gettext (Msgid))
+# undef dcgettext
+# define dcgettext(Domainname, Msgid, Category) \
+    ((void) (Category), dgettext (Domainname, Msgid))
+# undef ngettext
+# define ngettext(Msgid1, Msgid2, N) \
+    ((N) == 1 \
+     ? ((void) (Msgid2), (const char *) (Msgid1)) \
+     : ((void) (Msgid1), (const char *) (Msgid2)))
+# undef dngettext
+# define dngettext(Domainname, Msgid1, Msgid2, N) \
+    ((void) (Domainname), ngettext (Msgid1, Msgid2, N))
+# undef dcngettext
+# define dcngettext(Domainname, Msgid1, Msgid2, N, Category) \
+    ((void) (Category), dngettext (Domainname, Msgid1, Msgid2, N))
+# undef textdomain
+# define textdomain(Domainname) ((const char *) (Domainname))
+# undef bindtextdomain
+# define bindtextdomain(Domainname, Dirname) \
+    ((void) (Domainname), (const char *) (Dirname))
+# undef bind_textdomain_codeset
+# define bind_textdomain_codeset(Domainname, Codeset) \
+    ((void) (Domainname), (const char *) (Codeset))
+
+#endif
+
+/* Prefer gnulib's setlocale override over libintl's setlocale override.  */
+#ifdef GNULIB_defined_setlocale
+# undef setlocale
+# define setlocale rpl_setlocale
+#endif
+
+/* A pseudo function call that serves as a marker for the automated
+   extraction of messages, but does not call gettext().  The run-time
+   translation is done at a different place in the code.
+   The argument, String, should be a literal string.  Concatenated strings
+   and other string expressions won't work.
+   The macro's expansion is not parenthesized, so that it is suitable as
+   initializer for static 'char[]' or 'const char[]' variables.  */
+#define gettext_noop(String) String
+
+/* The separator between msgctxt and msgid in a .mo file.  */
+#define GETTEXT_CONTEXT_GLUE "\004"
+
+/* Pseudo function calls, taking a MSGCTXT and a MSGID instead of just a
+   MSGID.  MSGCTXT and MSGID must be string literals.  MSGCTXT should be
+   short and rarely need to change.
+   The letter 'p' stands for 'particular' or 'special'.  */
+#ifdef DEFAULT_TEXT_DOMAIN
+# define pgettext(Msgctxt, Msgid) \
+   pgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
+#else
+# define pgettext(Msgctxt, Msgid) \
+   pgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
+#endif
+#define dpgettext(Domainname, Msgctxt, Msgid) \
+  pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES)
+#define dcpgettext(Domainname, Msgctxt, Msgid, Category) \
+  pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, Category)
+#ifdef DEFAULT_TEXT_DOMAIN
+# define npgettext(Msgctxt, Msgid, MsgidPlural, N) \
+   npgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
+#else
+# define npgettext(Msgctxt, Msgid, MsgidPlural, N) \
+   npgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
+#endif
+#define dnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N) \
+  npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES)
+#define dcnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N, Category) \
+  npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, Category)
+
+#ifdef __GNUC__
+__inline
+#else
+#ifdef __cplusplus
+inline
+#endif
+#endif
+static const char *
+pgettext_aux (const char *domain,
+              const char *msg_ctxt_id, const char *msgid,
+              int category)
+{
+  const char *translation = dcgettext (domain, msg_ctxt_id, category);
+  if (translation == msg_ctxt_id)
+    return msgid;
+  else
+    return translation;
+}
+
+#ifdef __GNUC__
+__inline
+#else
+#ifdef __cplusplus
+inline
+#endif
+#endif
+static const char *
+npgettext_aux (const char *domain,
+               const char *msg_ctxt_id, const char *msgid,
+               const char *msgid_plural, unsigned long int n,
+               int category)
+{
+  const char *translation =
+    dcngettext (domain, msg_ctxt_id, msgid_plural, n, category);
+  if (translation == msg_ctxt_id || translation == msgid_plural)
+    return (n == 1 ? msgid : msgid_plural);
+  else
+    return translation;
+}
+
+/* The same thing extended for non-constant arguments.  Here MSGCTXT and MSGID
+   can be arbitrary expressions.  But for string literals these macros are
+   less efficient than those above.  */
+
+#include <string.h>
+
+#if (((__GNUC__ >= 3 || __GNUG__ >= 2) && !defined __STRICT_ANSI__) \
+     /* || __STDC_VERSION__ >= 199901L */ )
+# define _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS 1
+#else
+# define _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS 0
+#endif
+
+#if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS
+#include <stdlib.h>
+#endif
+
+#define pgettext_expr(Msgctxt, Msgid) \
+  dcpgettext_expr (NULL, Msgctxt, Msgid, LC_MESSAGES)
+#define dpgettext_expr(Domainname, Msgctxt, Msgid) \
+  dcpgettext_expr (Domainname, Msgctxt, Msgid, LC_MESSAGES)
+
+#ifdef __GNUC__
+__inline
+#else
+#ifdef __cplusplus
+inline
+#endif
+#endif
+static const char *
+dcpgettext_expr (const char *domain,
+                 const char *msgctxt, const char *msgid,
+                 int category)
+{
+  size_t msgctxt_len = strlen (msgctxt) + 1;
+  size_t msgid_len = strlen (msgid) + 1;
+  const char *translation;
+#if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS
+  char msg_ctxt_id[msgctxt_len + msgid_len];
+#else
+  char buf[1024];
+  char *msg_ctxt_id =
+    (msgctxt_len + msgid_len <= sizeof (buf)
+     ? buf
+     : (char *) malloc (msgctxt_len + msgid_len));
+  if (msg_ctxt_id != NULL)
+#endif
+    {
+      int found_translation;
+      memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1);
+      msg_ctxt_id[msgctxt_len - 1] = '\004';
+      memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len);
+      translation = dcgettext (domain, msg_ctxt_id, category);
+      found_translation = (translation != msg_ctxt_id);
+#if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS
+      if (msg_ctxt_id != buf)
+        free (msg_ctxt_id);
+#endif
+      if (found_translation)
+        return translation;
+    }
+  return msgid;
+}
+
+#define npgettext_expr(Msgctxt, Msgid, MsgidPlural, N) \
+  dcnpgettext_expr (NULL, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES)
+#define dnpgettext_expr(Domainname, Msgctxt, Msgid, MsgidPlural, N) \
+  dcnpgettext_expr (Domainname, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES)
+
+#ifdef __GNUC__
+__inline
+#else
+#ifdef __cplusplus
+inline
+#endif
+#endif
+static const char *
+dcnpgettext_expr (const char *domain,
+                  const char *msgctxt, const char *msgid,
+                  const char *msgid_plural, unsigned long int n,
+                  int category)
+{
+  size_t msgctxt_len = strlen (msgctxt) + 1;
+  size_t msgid_len = strlen (msgid) + 1;
+  const char *translation;
+#if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS
+  char msg_ctxt_id[msgctxt_len + msgid_len];
+#else
+  char buf[1024];
+  char *msg_ctxt_id =
+    (msgctxt_len + msgid_len <= sizeof (buf)
+     ? buf
+     : (char *) malloc (msgctxt_len + msgid_len));
+  if (msg_ctxt_id != NULL)
+#endif
+    {
+      int found_translation;
+      memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1);
+      msg_ctxt_id[msgctxt_len - 1] = '\004';
+      memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len);
+      translation = dcngettext (domain, msg_ctxt_id, msgid_plural, n, category);
+      found_translation = !(translation == msg_ctxt_id || translation == msgid_plural);
+#if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS
+      if (msg_ctxt_id != buf)
+        free (msg_ctxt_id);
+#endif
+      if (found_translation)
+        return translation;
+    }
+  return (n == 1 ? msgid : msgid_plural);
+}
+
+#endif /* _LIBGETTEXT_H */
Index: csvn-ui-0.1.5/l10n/README
===================================================================
--- csvn-ui-0.1.5/l10n/README	(nonexistent)
+++ csvn-ui-0.1.5/l10n/README	(revision 12)
@@ -0,0 +1,314 @@
+
+First run:
+=========
+
+До первого запуска gettextize --force каталог po/ не должен существовать!
+При первом запуске gettextize --force создаются каталоги m4, po
+  m4
+  ├── ChangeLog
+  ├── gettext.m4
+  ├── iconv.m4
+  ├── lib-ld.m4
+  ├── lib-link.m4
+  ├── lib-prefix.m4
+  ├── nls.m4
+  ├── po.m4
+  └── progtest.m4
+
+  po
+  ├── ChangeLog
+  ├── Makefile.in.in
+  ├── Makevars.template
+  ├── POTFILES.in
+  ├── Rules-quot
+  ├── boldquot.sed
+  ├── en@boldquot.header
+  ├── en@quot.header
+  ├── insert-header.sin
+  ├── quot.sed
+  └── remove-potcdate.sin
+
+скрипт ./update-gettext копирует файл po/Makevars.template в po/Makevars,
+если po/Makevars не существовал, а также перезаписывает gettext.h. Кроме
+того gettextize добавляет файл config.rpath, и редактирует файлы:
+
+Makefile.am:
+
+--- Makefile.am~	2020-10-09 02:57:21.678843280 +0300
++++ Makefile.am	2020-10-09 03:05:09.010316710 +0300
+@@ -5,9 +5,9 @@
+ # In build order:
+ # ==============
+ #
+-SUBDIRS = csvncgi
++SUBDIRS = po csvncgi
+ 
+-EXTRA_DIST = \
++EXTRA_DIST = config.rpath m4/ChangeLog  \
+              doc l10n LICENSE README.md acsite.m4 bootstrap
+
+configure.ac:
+
+--- configure.ac~	2020-10-09 02:16:40.812940376 +0300
++++ configure.ac	2020-10-09 03:05:09.022316594 +0300
+@@ -267,7 +267,7 @@
+ dnl ============================================================
+ AC_MSG_CFG_PART(OUTPUT)
+ 
+-AC_CONFIG_FILES([
++AC_CONFIG_FILES([ po/Makefile.in
+ csvncgi/Makefile
+ Makefile
+
+После первого запуска update-gettext необходимо отдать следующие файлы
+под версионный контроль:
+
+  m4
+  ├── ChangeLog
+  ├── gettext.m4
+  ├── iconv.m4
+  ├── lib-ld.m4
+  ├── lib-link.m4
+  ├── lib-prefix.m4
+  ├── nls.m4
+  ├── po.m4
+  └── progtest.m4
+
+  po
+  ├── ChangeLog
+  ├── Makefile.in.in
+  ├── Makevars
+  ├── POTFILES.in
+  ├── Rules-quot
+  ├── boldquot.sed
+  ├── en@boldquot.header
+  ├── en@quot.header
+  ├── insert-header.sin
+  ├── quot.sed
+  └── remove-potcdate.sin
+
+  ABOUT-NLS
+  ChangeLog
+  Makefile.am
+  config.rpath
+  configure.ac
+  gettext.h
+
+При последующих запусках update-gettext будут обновляться файлы входящие в поставку
+gettext и, при необходимости, добавляться записи в ChangeLog файлы. Как правило,
+ChangeLog файлы будут обновляться только тогда, когда будет инсталлироваться новая
+версия gettext.
+
+
+Далее можно будет держать в каталоге po/ или копировать в каталог po/ с помощью
+скрипта bootstrap файлы LINGUAS, csvn-ui.pot, ru_RU.utf8.po, а также обновлять
+содержимое файла po/POTFILES.in.
+
+Для корректной работы команд make, make dist необходимо наличие файлов po/LINGUAS,
+po/csvn-ui.pot, po/ru_RU.utf8.po, кроме того время последнего изменения данных файлов
+должно удовлетворять зависимостям описанным в Make-файлах. То есть, если мы хотим
+обновить po/POTFILES.in по окончании процедуры bootstrap, то перед конфигурированием
+и сборкой необходимо обновить дату:
+
+  $ cd po
+  $ touch --touch --reference=Makefile.in.in LINGUAS POTFILES.in ru_RU.utf8.po
+
+Далее мы опишем все процедуры по созданию и обновлению файлов в каталоге po/
+для успешной локализации продукта.
+
+
+Makevars
+========
+
+Прежде всего, необходимо отредактировать файл Makevars для того, чтобы при создании
+source distribution с помощью команды:
+
+  $ make dist
+
+обновление csvn-ui.pot файла, а также файлов *.po и *.gmo происходило корректно 
+
+
+Значения переменных:
+-------------------
+
+XGETTEXT_OPTIONS = --keyword=N_ --keyword=_ --keyword=Q_:1,2 \
+                   --language=C --add-comments --sort-output --no-wrap
+
+COPYRIGHT_HOLDER = Andrey V.Kosteltsev.
+
+PACKAGE_GNU = no
+
+MSGID_BUGS_ADDRESS = <support@radix.pro>
+
+MSGMERGE_OPTIONS = --update --no-wrap --sort-output --backup=simple
+
+MSGINIT_OPTIONS = --no-wrap
+
+
+
+Локализация:
+===========
+
+Если первый запуск gettextize состоялся и все необходимые файлы были отданы
+под версионный контроль, то последующие запуски update-gettext можно осуществлять
+не беспокоясь о том, что файлы будут испорчены. Делать это нужно до вызова bootstrap
+и configure.
+
+Далее, можно заняться непосредственно локализацией продукта. Первое, что необходимо
+сделать, это создать файл .pot .
+
+В файле config.h, создаваемым скриптом configure, будет определена константа
+PACKAGE, например:
+
+/* Name of package */
+#define PACKAGE "csvn-ui"
+
+и в данном случае, доменом по умолчанию следует считать имя 'csvn-ui'. Файл csvn-ui.pot
+можно создать следующим образом:
+
+  $ xgettext --keyword=N_ --keyword=_ --keyword=Q_:1,2 \
+             --language=C --add-comments --sort-output --no-wrap  \
+             --copyright-holder="Andrey V.Kosteltsev." \
+             --msgid-bugs-address="<support@radix.pro>" \
+             --default-domain=csvn-ui --output=po/csvn-ui.pot \
+             `find -type f -name "*.c"`
+
+для удобства мы создали скрипт gen-pot-file, который выполняет команду xgettext
+с нужными параметрами. Его следует запускать сразу после обновления исходных
+кодов программы, откуда xgettext извлекает строки для последующего перевода.
+
+Ключевые слова N_, _, Q_:1,2 означают следующее:
+
+  N_     - извлекаются строки типа N_("string"), которые будут присутствовать в csvn-ui.pot
+           файле, но переводиться не будут.
+
+  _      - извлекаются строки типа _("string"), которые будут переводиться на другие языки.
+
+  Q_:1,2 - извлекается первая и вторая строка из конструкций типа:
+
+             Q_("%u byte", "%u bytes", (unsigned)bytes)
+
+           и в файле csvn-ui.pot будут создаваться записи подобные следующей:
+
+             #. TRANSLATORS: IEC 80000-13:2008 byte
+             #: csvncgi/strbuf.c:558
+             #, c-format
+             msgid "%u byte"
+             msgid_plural "%u bytes"
+             msgstr[0] ""
+             msgstr[1] ""
+
+           Таким образом с помощью ngettext() можно добиться корректного перевода числительных,
+           например, 1 байт, 10 байтов, 21 байт .
+
+Справка по --keywords здесь: https://www.gnu.org/software/gettext/manual/html_node/Default-Keywords.html
+
+Далее необходимо обновить файл POTFILES.in, записав в него список исходных файлов, в которых
+существуют строки для перевода. Сделать это можно вручную следующим образом:
+
+# List of source files which contain translatable strings.
+
+# cSvn CGI source files
+csvncgi/fatal.c
+csvncgi/strbuf.c
+. . .
+
+Напомним, что po/POTFILES.in находится под версионным контролем.
+
+Кроме того, под версионным контролем должен находиться файл po/LINGUAS, например,
+следующего содержания:
+
+# Set of available languages.
+
+ru_RU.utf8
+
+Поскольку в файле LINGUAS присутствует сторока 'ru_RU.utf8', в каталоге, po/
+должен находиться файл po/ru_RU.utf8.po, начальное состояние которого можно
+получить с помощью утилиты msginit:
+
+  $ cd po/
+  $ msginit --no-wrap --locale=ru_RU.utf8 --input=csvn-ui.pot --output=ru_RU.utf8.po
+
+Утилита msginit запросит подтверждение почтового адреса:
+=======================================================
+The new message catalog should contain your email address, so that users can
+give you feedback about the translations, and so that maintainers can contact
+you in case of unexpected technical problems.
+
+Is the following your email address?
+  kx@cardhu.radix.pro
+Please confirm by pressing Return, or enter your email address.
+kx@radix.pro
+Retrieving http://translationproject.org/team/index.html... done.
+A translation team for your language (ru) does not exist yet.
+If you want to create a new translation team for ru, please visit
+  http://www.iro.umontreal.ca/contrib/po/HTML/teams.html
+  http://www.iro.umontreal.ca/contrib/po/HTML/leaders.html
+  http://www.iro.umontreal.ca/contrib/po/HTML/index.html
+
+Created ru_RU.utf8.po.
+
+Создание файла ru_RU.utf8.po с помощью команды
+
+  $ msginit --no-wrap --locale=ru_RU.utf8 --input=csvn-ui.pot --output=ru_RU.utf8.po
+
+лучше выполнять после конфигурирования исходников для того, чтобы в заголовочном коментарии
+файла ru_RU.utf8.po имя пакета было задано корректно. То есть csvn-ui по имени PACKAGE.
+
+
+Правила перевода числительных записывается на языке С и, для русского языка:
+
+  "Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2);\n"
+
+дает:
+
+  [0] строка
+  [1] строки
+  [2] строк
+
+
+В дальнейшем, так как файл ru_RU.utf8.po находится под версионным контролем,
+его надо будет только обновлять.
+
+Допустим в исходные файлы на языке С были добавлены строки, подлежащие переводу, и надо обновить
+файл ru_RU.utf8.po, чтобы в него попали новые строки. Для обновления файла ru_RU.utf8.po, сначала
+нужно обновить файл po/csvn-ui.pot с помощью скрипта gen-pot-file:
+
+  $ l10n/gen-pot-file
+
+и затем, обновить файл po/ru_RU.utf8.po:
+
+  $ cd po/
+  $ msgmerge --update --no-wrap --sort-output --backup=simple ru_RU.utf8.po csvn-ui.pot
+
+Cтарый файл будет сохранен с именем po/ru_RU.utf8.po~
+
+
+Таким образом для обновления как самой утилиты gettext, так и файлов локализации, следует
+(в корне исходного пакета программ) вызывать процедуры обновления в следующем порядке:
+
+  $ ./l10n/update-gettext
+  $ ./l10n/gen-pot-file
+  $ ./l10n/merge-ru_RU.utf8-messages
+
+Остается только не забывать добавлять новые файлы в po/POTFILES.in, а при добавлении новых
+языков (локалей), дополнять файл po/LINGUAS. И наконец еще одно замечание. В файлах *.po,
+при обновлении номера версии продукта, строку:
+
+"Project-Id-Version: csvn-ui 0.0.6\n"
+
+надо обновлять вручную (разумеется если .po файл уже существует под версионным контролем,
+а не создается вновь с помощью утилиты msginit).
+
+
+Файл nls.h обеспечивает исходный код макроопределениями на случай использования gettext,
+а также без использования GNU gettext, когда при конфигурировании выбирается опция:
+
+  $ ./configure --disable-nls
+
+Более подробную информацию об утилитах GNU gettext можно получить по адресу:
+
+  https://www.gnu.org/software/gettext/manual/gettext.html
+
+
+Enjoy.
Index: csvn-ui-0.1.5/l10n/gen-pot-file
===================================================================
--- csvn-ui-0.1.5/l10n/gen-pot-file	(nonexistent)
+++ csvn-ui-0.1.5/l10n/gen-pot-file	(revision 12)
@@ -0,0 +1,19 @@
+#!/bin/bash
+
+CWD=`pwd`
+
+SCRIPT_DIR=`cd $(dirname ${BASH_SOURCE[0]}) >/dev/null 2>&1 && pwd`
+program=`basename $0`
+
+cd ${SCRIPT_DIR}/..
+
+POTFILE=po/csvn-ui.pot
+
+cp -a ${POTFILE} ${POTFILE}~
+
+xgettext --keyword=N_ --keyword=_ --keyword=Q_:1,2  \
+         --language=C --add-comments --sort-output --no-wrap \
+         --copyright-holder="Andrey V.Kosteltsev." \
+         --msgid-bugs-address="<support@radix.pro>" \
+         --default-domain=csvn-ui --output=${POTFILE} \
+         `find -type f -name "*.c"`

Property changes on: csvn-ui-0.1.5/l10n/gen-pot-file
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/l10n/merge-ru_RU.utf8-messages
===================================================================
--- csvn-ui-0.1.5/l10n/merge-ru_RU.utf8-messages	(nonexistent)
+++ csvn-ui-0.1.5/l10n/merge-ru_RU.utf8-messages	(revision 12)
@@ -0,0 +1,13 @@
+#!/bin/bash
+
+CWD=`pwd`
+
+SCRIPT_DIR=`cd $(dirname ${BASH_SOURCE[0]}) >/dev/null 2>&1 && pwd`
+program=`basename $0`
+
+cd ${SCRIPT_DIR}/../po
+
+POFILE=ru_RU.utf8.po
+POTFILE=csvn-ui.pot
+
+msgmerge --update --no-wrap --sort-output --backup=simple ${POFILE} ${POTFILE}

Property changes on: csvn-ui-0.1.5/l10n/merge-ru_RU.utf8-messages
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/l10n/update-gettext
===================================================================
--- csvn-ui-0.1.5/l10n/update-gettext	(nonexistent)
+++ csvn-ui-0.1.5/l10n/update-gettext	(revision 12)
@@ -0,0 +1,84 @@
+#!/bin/bash
+
+CWD=`pwd`
+
+SCRIPT_DIR=`cd $(dirname ${BASH_SOURCE[0]}) >/dev/null 2>&1 && pwd`
+program=`basename $0`
+
+cd ${SCRIPT_DIR}/..
+
+
+################################################################
+# Gettext:
+#
+gettextize --force
+
+#
+# Patch for po/Makefile.in.in
+#
+file=po/Makefile.in.in
+
+if ! `cat $file | grep -q '^top_builddir'` ; then
+  line="`cat $file | grep -n '^top_srcdir' | cut -f2 -d':'`"
+  lnum="`cat $file | grep -n '^top_srcdir' | cut -f1 -d':'`"
+  echo "Finding the line for 'top_builddir = @top_builddir@' declaration"
+  if [ ! -z "$line" ] ; then
+    echo "   FOUND: $file: $lnum: $line"
+    sed -i "$lnum a\
+top_builddir = @top_builddir@" $file
+  fi
+fi
+echo ""
+
+#
+# gettextize output:
+# =================
+#
+# -------------------------------------------------------------------------------
+# Creating m4/ChangeLog
+# Updating Makefile.am (backup is in Makefile.am~)
+# Updating configure.ac (backup is in configure.ac~)
+# Adding an entry to ChangeLog (backup is in ChangeLog~)
+#
+# Please create po/Makevars from the template in po/Makevars.template.
+# You can then remove po/Makevars.template.
+#
+# Please fill po/POTFILES.in as described in the documentation.
+#
+# Please run 'aclocal' to regenerate the aclocal.m4 file.
+# You need aclocal from GNU automake 1.9 (or newer) to do this.
+# Then run 'autoconf' to regenerate the configure file.
+#
+# You will also need config.guess and config.sub, which you can get from the CVS
+# of the 'config' project at http://savannah.gnu.org/. The commands to fetch
+# them
+# are
+# $ wget
+# 'http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.guess'
+# $ wget
+# 'http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.sub'
+#
+# You might also want to copy the convenience header file gettext.h
+# from the /usr/share/gettext directory into your package.
+# It is a wrapper around <libintl.h> that implements the configure --disable-nls
+# option.
+#
+# Press Return to acknowledge the previous five paragraphs.
+# -------------------------------------------------------------------------------
+#
+# NOTE:
+# ====
+#   Собственные исходники, там где надо использовать <libintl.h>,
+#   должны включать "gettext.h" тогда можно будет использовать опцию
+#   конфигурирования --disable-nls .
+#
+if [ ! -f "po/Makevars" ] ; then
+  mv po/Makevars.template po/Makevars
+else
+  mv po/Makevars.template po/Makevars
+fi
+cp -a gettext.h gettext.h~
+cp /usr/share/gettext/gettext.h .
+#
+# End of Gettext.
+################################################################

Property changes on: csvn-ui-0.1.5/l10n/update-gettext
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: csvn-ui-0.1.5/l10n
===================================================================
--- csvn-ui-0.1.5/l10n	(nonexistent)
+++ csvn-ui-0.1.5/l10n	(revision 12)

Property changes on: csvn-ui-0.1.5/l10n
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/m4/ChangeLog
===================================================================
--- csvn-ui-0.1.5/m4/ChangeLog	(nonexistent)
+++ csvn-ui-0.1.5/m4/ChangeLog	(revision 12)
@@ -0,0 +1,11 @@
+2020-10-09  gettextize  <bug-gnu-gettext@gnu.org>
+
+	* gettext.m4: New file, from gettext-0.19.8.1.
+	* iconv.m4: New file, from gettext-0.19.8.1.
+	* lib-ld.m4: New file, from gettext-0.19.8.1.
+	* lib-link.m4: New file, from gettext-0.19.8.1.
+	* lib-prefix.m4: New file, from gettext-0.19.8.1.
+	* nls.m4: New file, from gettext-0.19.8.1.
+	* po.m4: New file, from gettext-0.19.8.1.
+	* progtest.m4: New file, from gettext-0.19.8.1.
+
Index: csvn-ui-0.1.5/m4/gettext.m4
===================================================================
--- csvn-ui-0.1.5/m4/gettext.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/gettext.m4	(revision 12)
@@ -0,0 +1,420 @@
+# gettext.m4 serial 68 (gettext-0.19.8)
+dnl Copyright (C) 1995-2014, 2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+dnl
+dnl This file can be used in projects which are not available under
+dnl the GNU General Public License or the GNU Library General Public
+dnl License but which still want to provide support for the GNU gettext
+dnl functionality.
+dnl Please note that the actual code of the GNU gettext library is covered
+dnl by the GNU Library General Public License, and the rest of the GNU
+dnl gettext package is covered by the GNU General Public License.
+dnl They are *not* in the public domain.
+
+dnl Authors:
+dnl   Ulrich Drepper <drepper@cygnus.com>, 1995-2000.
+dnl   Bruno Haible <haible@clisp.cons.org>, 2000-2006, 2008-2010.
+
+dnl Macro to add for using GNU gettext.
+
+dnl Usage: AM_GNU_GETTEXT([INTLSYMBOL], [NEEDSYMBOL], [INTLDIR]).
+dnl INTLSYMBOL can be one of 'external', 'no-libtool', 'use-libtool'. The
+dnl    default (if it is not specified or empty) is 'no-libtool'.
+dnl    INTLSYMBOL should be 'external' for packages with no intl directory,
+dnl    and 'no-libtool' or 'use-libtool' for packages with an intl directory.
+dnl    If INTLSYMBOL is 'use-libtool', then a libtool library
+dnl    $(top_builddir)/intl/libintl.la will be created (shared and/or static,
+dnl    depending on --{enable,disable}-{shared,static} and on the presence of
+dnl    AM-DISABLE-SHARED). If INTLSYMBOL is 'no-libtool', a static library
+dnl    $(top_builddir)/intl/libintl.a will be created.
+dnl If NEEDSYMBOL is specified and is 'need-ngettext', then GNU gettext
+dnl    implementations (in libc or libintl) without the ngettext() function
+dnl    will be ignored.  If NEEDSYMBOL is specified and is
+dnl    'need-formatstring-macros', then GNU gettext implementations that don't
+dnl    support the ISO C 99 <inttypes.h> formatstring macros will be ignored.
+dnl INTLDIR is used to find the intl libraries.  If empty,
+dnl    the value '$(top_builddir)/intl/' is used.
+dnl
+dnl The result of the configuration is one of three cases:
+dnl 1) GNU gettext, as included in the intl subdirectory, will be compiled
+dnl    and used.
+dnl    Catalog format: GNU --> install in $(datadir)
+dnl    Catalog extension: .mo after installation, .gmo in source tree
+dnl 2) GNU gettext has been found in the system's C library.
+dnl    Catalog format: GNU --> install in $(datadir)
+dnl    Catalog extension: .mo after installation, .gmo in source tree
+dnl 3) No internationalization, always use English msgid.
+dnl    Catalog format: none
+dnl    Catalog extension: none
+dnl If INTLSYMBOL is 'external', only cases 2 and 3 can occur.
+dnl The use of .gmo is historical (it was needed to avoid overwriting the
+dnl GNU format catalogs when building on a platform with an X/Open gettext),
+dnl but we keep it in order not to force irrelevant filename changes on the
+dnl maintainers.
+dnl
+AC_DEFUN([AM_GNU_GETTEXT],
+[
+  dnl Argument checking.
+  ifelse([$1], [], , [ifelse([$1], [external], , [ifelse([$1], [no-libtool], , [ifelse([$1], [use-libtool], ,
+    [errprint([ERROR: invalid first argument to AM_GNU_GETTEXT
+])])])])])
+  ifelse(ifelse([$1], [], [old])[]ifelse([$1], [no-libtool], [old]), [old],
+    [AC_DIAGNOSE([obsolete], [Use of AM_GNU_GETTEXT without [external] argument is deprecated.])])
+  ifelse([$2], [], , [ifelse([$2], [need-ngettext], , [ifelse([$2], [need-formatstring-macros], ,
+    [errprint([ERROR: invalid second argument to AM_GNU_GETTEXT
+])])])])
+  define([gt_included_intl],
+    ifelse([$1], [external],
+      ifdef([AM_GNU_GETTEXT_][INTL_SUBDIR], [yes], [no]),
+      [yes]))
+  define([gt_libtool_suffix_prefix], ifelse([$1], [use-libtool], [l], []))
+  gt_NEEDS_INIT
+  AM_GNU_GETTEXT_NEED([$2])
+
+  AC_REQUIRE([AM_PO_SUBDIRS])dnl
+  ifelse(gt_included_intl, yes, [
+    AC_REQUIRE([AM_INTL_SUBDIR])dnl
+  ])
+
+  dnl Prerequisites of AC_LIB_LINKFLAGS_BODY.
+  AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
+  AC_REQUIRE([AC_LIB_RPATH])
+
+  dnl Sometimes libintl requires libiconv, so first search for libiconv.
+  dnl Ideally we would do this search only after the
+  dnl      if test "$USE_NLS" = "yes"; then
+  dnl        if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then
+  dnl tests. But if configure.in invokes AM_ICONV after AM_GNU_GETTEXT
+  dnl the configure script would need to contain the same shell code
+  dnl again, outside any 'if'. There are two solutions:
+  dnl - Invoke AM_ICONV_LINKFLAGS_BODY here, outside any 'if'.
+  dnl - Control the expansions in more detail using AC_PROVIDE_IFELSE.
+  dnl Since AC_PROVIDE_IFELSE is only in autoconf >= 2.52 and not
+  dnl documented, we avoid it.
+  ifelse(gt_included_intl, yes, , [
+    AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY])
+  ])
+
+  dnl Sometimes, on Mac OS X, libintl requires linking with CoreFoundation.
+  gt_INTL_MACOSX
+
+  dnl Set USE_NLS.
+  AC_REQUIRE([AM_NLS])
+
+  ifelse(gt_included_intl, yes, [
+    BUILD_INCLUDED_LIBINTL=no
+    USE_INCLUDED_LIBINTL=no
+  ])
+  LIBINTL=
+  LTLIBINTL=
+  POSUB=
+
+  dnl Add a version number to the cache macros.
+  case " $gt_needs " in
+    *" need-formatstring-macros "*) gt_api_version=3 ;;
+    *" need-ngettext "*) gt_api_version=2 ;;
+    *) gt_api_version=1 ;;
+  esac
+  gt_func_gnugettext_libc="gt_cv_func_gnugettext${gt_api_version}_libc"
+  gt_func_gnugettext_libintl="gt_cv_func_gnugettext${gt_api_version}_libintl"
+
+  dnl If we use NLS figure out what method
+  if test "$USE_NLS" = "yes"; then
+    gt_use_preinstalled_gnugettext=no
+    ifelse(gt_included_intl, yes, [
+      AC_MSG_CHECKING([whether included gettext is requested])
+      AC_ARG_WITH([included-gettext],
+        [  --with-included-gettext use the GNU gettext library included here],
+        nls_cv_force_use_gnu_gettext=$withval,
+        nls_cv_force_use_gnu_gettext=no)
+      AC_MSG_RESULT([$nls_cv_force_use_gnu_gettext])
+
+      nls_cv_use_gnu_gettext="$nls_cv_force_use_gnu_gettext"
+      if test "$nls_cv_force_use_gnu_gettext" != "yes"; then
+    ])
+        dnl User does not insist on using GNU NLS library.  Figure out what
+        dnl to use.  If GNU gettext is available we use this.  Else we have
+        dnl to fall back to GNU NLS library.
+
+        if test $gt_api_version -ge 3; then
+          gt_revision_test_code='
+#ifndef __GNU_GETTEXT_SUPPORTED_REVISION
+#define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1)
+#endif
+changequote(,)dnl
+typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1];
+changequote([,])dnl
+'
+        else
+          gt_revision_test_code=
+        fi
+        if test $gt_api_version -ge 2; then
+          gt_expression_test_code=' + * ngettext ("", "", 0)'
+        else
+          gt_expression_test_code=
+        fi
+
+        AC_CACHE_CHECK([for GNU gettext in libc], [$gt_func_gnugettext_libc],
+         [AC_LINK_IFELSE(
+            [AC_LANG_PROGRAM(
+               [[
+#include <libintl.h>
+#ifndef __GNU_GETTEXT_SUPPORTED_REVISION
+extern int _nl_msg_cat_cntr;
+extern int *_nl_domain_bindings;
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_domain_bindings)
+#else
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION 0
+#endif
+$gt_revision_test_code
+               ]],
+               [[
+bindtextdomain ("", "");
+return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION
+               ]])],
+            [eval "$gt_func_gnugettext_libc=yes"],
+            [eval "$gt_func_gnugettext_libc=no"])])
+
+        if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then
+          dnl Sometimes libintl requires libiconv, so first search for libiconv.
+          ifelse(gt_included_intl, yes, , [
+            AM_ICONV_LINK
+          ])
+          dnl Search for libintl and define LIBINTL, LTLIBINTL and INCINTL
+          dnl accordingly. Don't use AC_LIB_LINKFLAGS_BODY([intl],[iconv])
+          dnl because that would add "-liconv" to LIBINTL and LTLIBINTL
+          dnl even if libiconv doesn't exist.
+          AC_LIB_LINKFLAGS_BODY([intl])
+          AC_CACHE_CHECK([for GNU gettext in libintl],
+            [$gt_func_gnugettext_libintl],
+           [gt_save_CPPFLAGS="$CPPFLAGS"
+            CPPFLAGS="$CPPFLAGS $INCINTL"
+            gt_save_LIBS="$LIBS"
+            LIBS="$LIBS $LIBINTL"
+            dnl Now see whether libintl exists and does not depend on libiconv.
+            AC_LINK_IFELSE(
+              [AC_LANG_PROGRAM(
+                 [[
+#include <libintl.h>
+#ifndef __GNU_GETTEXT_SUPPORTED_REVISION
+extern int _nl_msg_cat_cntr;
+extern
+#ifdef __cplusplus
+"C"
+#endif
+const char *_nl_expand_alias (const char *);
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias (""))
+#else
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION 0
+#endif
+$gt_revision_test_code
+                 ]],
+                 [[
+bindtextdomain ("", "");
+return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION
+                 ]])],
+              [eval "$gt_func_gnugettext_libintl=yes"],
+              [eval "$gt_func_gnugettext_libintl=no"])
+            dnl Now see whether libintl exists and depends on libiconv.
+            if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" != yes; } && test -n "$LIBICONV"; then
+              LIBS="$LIBS $LIBICONV"
+              AC_LINK_IFELSE(
+                [AC_LANG_PROGRAM(
+                   [[
+#include <libintl.h>
+#ifndef __GNU_GETTEXT_SUPPORTED_REVISION
+extern int _nl_msg_cat_cntr;
+extern
+#ifdef __cplusplus
+"C"
+#endif
+const char *_nl_expand_alias (const char *);
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias (""))
+#else
+#define __GNU_GETTEXT_SYMBOL_EXPRESSION 0
+#endif
+$gt_revision_test_code
+                   ]],
+                   [[
+bindtextdomain ("", "");
+return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION
+                   ]])],
+                [LIBINTL="$LIBINTL $LIBICONV"
+                 LTLIBINTL="$LTLIBINTL $LTLIBICONV"
+                 eval "$gt_func_gnugettext_libintl=yes"
+                ])
+            fi
+            CPPFLAGS="$gt_save_CPPFLAGS"
+            LIBS="$gt_save_LIBS"])
+        fi
+
+        dnl If an already present or preinstalled GNU gettext() is found,
+        dnl use it.  But if this macro is used in GNU gettext, and GNU
+        dnl gettext is already preinstalled in libintl, we update this
+        dnl libintl.  (Cf. the install rule in intl/Makefile.in.)
+        if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" = "yes"; } \
+           || { { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; } \
+                && test "$PACKAGE" != gettext-runtime \
+                && test "$PACKAGE" != gettext-tools; }; then
+          gt_use_preinstalled_gnugettext=yes
+        else
+          dnl Reset the values set by searching for libintl.
+          LIBINTL=
+          LTLIBINTL=
+          INCINTL=
+        fi
+
+    ifelse(gt_included_intl, yes, [
+        if test "$gt_use_preinstalled_gnugettext" != "yes"; then
+          dnl GNU gettext is not found in the C library.
+          dnl Fall back on included GNU gettext library.
+          nls_cv_use_gnu_gettext=yes
+        fi
+      fi
+
+      if test "$nls_cv_use_gnu_gettext" = "yes"; then
+        dnl Mark actions used to generate GNU NLS library.
+        BUILD_INCLUDED_LIBINTL=yes
+        USE_INCLUDED_LIBINTL=yes
+        LIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LIBICONV $LIBTHREAD"
+        LTLIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LTLIBICONV $LTLIBTHREAD"
+        LIBS=`echo " $LIBS " | sed -e 's/ -lintl / /' -e 's/^ //' -e 's/ $//'`
+      fi
+
+      CATOBJEXT=
+      if test "$gt_use_preinstalled_gnugettext" = "yes" \
+         || test "$nls_cv_use_gnu_gettext" = "yes"; then
+        dnl Mark actions to use GNU gettext tools.
+        CATOBJEXT=.gmo
+      fi
+    ])
+
+    if test -n "$INTL_MACOSX_LIBS"; then
+      if test "$gt_use_preinstalled_gnugettext" = "yes" \
+         || test "$nls_cv_use_gnu_gettext" = "yes"; then
+        dnl Some extra flags are needed during linking.
+        LIBINTL="$LIBINTL $INTL_MACOSX_LIBS"
+        LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS"
+      fi
+    fi
+
+    if test "$gt_use_preinstalled_gnugettext" = "yes" \
+       || test "$nls_cv_use_gnu_gettext" = "yes"; then
+      AC_DEFINE([ENABLE_NLS], [1],
+        [Define to 1 if translation of program messages to the user's native language
+   is requested.])
+    else
+      USE_NLS=no
+    fi
+  fi
+
+  AC_MSG_CHECKING([whether to use NLS])
+  AC_MSG_RESULT([$USE_NLS])
+  if test "$USE_NLS" = "yes"; then
+    AC_MSG_CHECKING([where the gettext function comes from])
+    if test "$gt_use_preinstalled_gnugettext" = "yes"; then
+      if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then
+        gt_source="external libintl"
+      else
+        gt_source="libc"
+      fi
+    else
+      gt_source="included intl directory"
+    fi
+    AC_MSG_RESULT([$gt_source])
+  fi
+
+  if test "$USE_NLS" = "yes"; then
+
+    if test "$gt_use_preinstalled_gnugettext" = "yes"; then
+      if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then
+        AC_MSG_CHECKING([how to link with libintl])
+        AC_MSG_RESULT([$LIBINTL])
+        AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCINTL])
+      fi
+
+      dnl For backward compatibility. Some packages may be using this.
+      AC_DEFINE([HAVE_GETTEXT], [1],
+       [Define if the GNU gettext() function is already present or preinstalled.])
+      AC_DEFINE([HAVE_DCGETTEXT], [1],
+       [Define if the GNU dcgettext() function is already present or preinstalled.])
+    fi
+
+    dnl We need to process the po/ directory.
+    POSUB=po
+  fi
+
+  ifelse(gt_included_intl, yes, [
+    dnl If this is used in GNU gettext we have to set BUILD_INCLUDED_LIBINTL
+    dnl to 'yes' because some of the testsuite requires it.
+    if test "$PACKAGE" = gettext-runtime || test "$PACKAGE" = gettext-tools; then
+      BUILD_INCLUDED_LIBINTL=yes
+    fi
+
+    dnl Make all variables we use known to autoconf.
+    AC_SUBST([BUILD_INCLUDED_LIBINTL])
+    AC_SUBST([USE_INCLUDED_LIBINTL])
+    AC_SUBST([CATOBJEXT])
+
+    dnl For backward compatibility. Some configure.ins may be using this.
+    nls_cv_header_intl=
+    nls_cv_header_libgt=
+
+    dnl For backward compatibility. Some Makefiles may be using this.
+    DATADIRNAME=share
+    AC_SUBST([DATADIRNAME])
+
+    dnl For backward compatibility. Some Makefiles may be using this.
+    INSTOBJEXT=.mo
+    AC_SUBST([INSTOBJEXT])
+
+    dnl For backward compatibility. Some Makefiles may be using this.
+    GENCAT=gencat
+    AC_SUBST([GENCAT])
+
+    dnl For backward compatibility. Some Makefiles may be using this.
+    INTLOBJS=
+    if test "$USE_INCLUDED_LIBINTL" = yes; then
+      INTLOBJS="\$(GETTOBJS)"
+    fi
+    AC_SUBST([INTLOBJS])
+
+    dnl Enable libtool support if the surrounding package wishes it.
+    INTL_LIBTOOL_SUFFIX_PREFIX=gt_libtool_suffix_prefix
+    AC_SUBST([INTL_LIBTOOL_SUFFIX_PREFIX])
+  ])
+
+  dnl For backward compatibility. Some Makefiles may be using this.
+  INTLLIBS="$LIBINTL"
+  AC_SUBST([INTLLIBS])
+
+  dnl Make all documented variables known to autoconf.
+  AC_SUBST([LIBINTL])
+  AC_SUBST([LTLIBINTL])
+  AC_SUBST([POSUB])
+])
+
+
+dnl gt_NEEDS_INIT ensures that the gt_needs variable is initialized.
+m4_define([gt_NEEDS_INIT],
+[
+  m4_divert_text([DEFAULTS], [gt_needs=])
+  m4_define([gt_NEEDS_INIT], [])
+])
+
+
+dnl Usage: AM_GNU_GETTEXT_NEED([NEEDSYMBOL])
+AC_DEFUN([AM_GNU_GETTEXT_NEED],
+[
+  m4_divert_text([INIT_PREPARE], [gt_needs="$gt_needs $1"])
+])
+
+
+dnl Usage: AM_GNU_GETTEXT_VERSION([gettext-version])
+AC_DEFUN([AM_GNU_GETTEXT_VERSION], [])
+
+
+dnl Usage: AM_GNU_GETTEXT_REQUIRE_VERSION([gettext-version])
+AC_DEFUN([AM_GNU_GETTEXT_REQUIRE_VERSION], [])
Index: csvn-ui-0.1.5/m4/iconv.m4
===================================================================
--- csvn-ui-0.1.5/m4/iconv.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/iconv.m4	(revision 12)
@@ -0,0 +1,271 @@
+# iconv.m4 serial 19 (gettext-0.18.2)
+dnl Copyright (C) 2000-2002, 2007-2014, 2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+dnl From Bruno Haible.
+
+AC_DEFUN([AM_ICONV_LINKFLAGS_BODY],
+[
+  dnl Prerequisites of AC_LIB_LINKFLAGS_BODY.
+  AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
+  AC_REQUIRE([AC_LIB_RPATH])
+
+  dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV
+  dnl accordingly.
+  AC_LIB_LINKFLAGS_BODY([iconv])
+])
+
+AC_DEFUN([AM_ICONV_LINK],
+[
+  dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and
+  dnl those with the standalone portable GNU libiconv installed).
+  AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles
+
+  dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV
+  dnl accordingly.
+  AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY])
+
+  dnl Add $INCICONV to CPPFLAGS before performing the following checks,
+  dnl because if the user has installed libiconv and not disabled its use
+  dnl via --without-libiconv-prefix, he wants to use it. The first
+  dnl AC_LINK_IFELSE will then fail, the second AC_LINK_IFELSE will succeed.
+  am_save_CPPFLAGS="$CPPFLAGS"
+  AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCICONV])
+
+  AC_CACHE_CHECK([for iconv], [am_cv_func_iconv], [
+    am_cv_func_iconv="no, consider installing GNU libiconv"
+    am_cv_lib_iconv=no
+    AC_LINK_IFELSE(
+      [AC_LANG_PROGRAM(
+         [[
+#include <stdlib.h>
+#include <iconv.h>
+         ]],
+         [[iconv_t cd = iconv_open("","");
+           iconv(cd,NULL,NULL,NULL,NULL);
+           iconv_close(cd);]])],
+      [am_cv_func_iconv=yes])
+    if test "$am_cv_func_iconv" != yes; then
+      am_save_LIBS="$LIBS"
+      LIBS="$LIBS $LIBICONV"
+      AC_LINK_IFELSE(
+        [AC_LANG_PROGRAM(
+           [[
+#include <stdlib.h>
+#include <iconv.h>
+           ]],
+           [[iconv_t cd = iconv_open("","");
+             iconv(cd,NULL,NULL,NULL,NULL);
+             iconv_close(cd);]])],
+        [am_cv_lib_iconv=yes]
+        [am_cv_func_iconv=yes])
+      LIBS="$am_save_LIBS"
+    fi
+  ])
+  if test "$am_cv_func_iconv" = yes; then
+    AC_CACHE_CHECK([for working iconv], [am_cv_func_iconv_works], [
+      dnl This tests against bugs in AIX 5.1, AIX 6.1..7.1, HP-UX 11.11,
+      dnl Solaris 10.
+      am_save_LIBS="$LIBS"
+      if test $am_cv_lib_iconv = yes; then
+        LIBS="$LIBS $LIBICONV"
+      fi
+      am_cv_func_iconv_works=no
+      for ac_iconv_const in '' 'const'; do
+        AC_RUN_IFELSE(
+          [AC_LANG_PROGRAM(
+             [[
+#include <iconv.h>
+#include <string.h>
+
+#ifndef ICONV_CONST
+# define ICONV_CONST $ac_iconv_const
+#endif
+             ]],
+             [[int result = 0;
+  /* Test against AIX 5.1 bug: Failures are not distinguishable from successful
+     returns.  */
+  {
+    iconv_t cd_utf8_to_88591 = iconv_open ("ISO8859-1", "UTF-8");
+    if (cd_utf8_to_88591 != (iconv_t)(-1))
+      {
+        static ICONV_CONST char input[] = "\342\202\254"; /* EURO SIGN */
+        char buf[10];
+        ICONV_CONST char *inptr = input;
+        size_t inbytesleft = strlen (input);
+        char *outptr = buf;
+        size_t outbytesleft = sizeof (buf);
+        size_t res = iconv (cd_utf8_to_88591,
+                            &inptr, &inbytesleft,
+                            &outptr, &outbytesleft);
+        if (res == 0)
+          result |= 1;
+        iconv_close (cd_utf8_to_88591);
+      }
+  }
+  /* Test against Solaris 10 bug: Failures are not distinguishable from
+     successful returns.  */
+  {
+    iconv_t cd_ascii_to_88591 = iconv_open ("ISO8859-1", "646");
+    if (cd_ascii_to_88591 != (iconv_t)(-1))
+      {
+        static ICONV_CONST char input[] = "\263";
+        char buf[10];
+        ICONV_CONST char *inptr = input;
+        size_t inbytesleft = strlen (input);
+        char *outptr = buf;
+        size_t outbytesleft = sizeof (buf);
+        size_t res = iconv (cd_ascii_to_88591,
+                            &inptr, &inbytesleft,
+                            &outptr, &outbytesleft);
+        if (res == 0)
+          result |= 2;
+        iconv_close (cd_ascii_to_88591);
+      }
+  }
+  /* Test against AIX 6.1..7.1 bug: Buffer overrun.  */
+  {
+    iconv_t cd_88591_to_utf8 = iconv_open ("UTF-8", "ISO-8859-1");
+    if (cd_88591_to_utf8 != (iconv_t)(-1))
+      {
+        static ICONV_CONST char input[] = "\304";
+        static char buf[2] = { (char)0xDE, (char)0xAD };
+        ICONV_CONST char *inptr = input;
+        size_t inbytesleft = 1;
+        char *outptr = buf;
+        size_t outbytesleft = 1;
+        size_t res = iconv (cd_88591_to_utf8,
+                            &inptr, &inbytesleft,
+                            &outptr, &outbytesleft);
+        if (res != (size_t)(-1) || outptr - buf > 1 || buf[1] != (char)0xAD)
+          result |= 4;
+        iconv_close (cd_88591_to_utf8);
+      }
+  }
+#if 0 /* This bug could be worked around by the caller.  */
+  /* Test against HP-UX 11.11 bug: Positive return value instead of 0.  */
+  {
+    iconv_t cd_88591_to_utf8 = iconv_open ("utf8", "iso88591");
+    if (cd_88591_to_utf8 != (iconv_t)(-1))
+      {
+        static ICONV_CONST char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
+        char buf[50];
+        ICONV_CONST char *inptr = input;
+        size_t inbytesleft = strlen (input);
+        char *outptr = buf;
+        size_t outbytesleft = sizeof (buf);
+        size_t res = iconv (cd_88591_to_utf8,
+                            &inptr, &inbytesleft,
+                            &outptr, &outbytesleft);
+        if ((int)res > 0)
+          result |= 8;
+        iconv_close (cd_88591_to_utf8);
+      }
+  }
+#endif
+  /* Test against HP-UX 11.11 bug: No converter from EUC-JP to UTF-8 is
+     provided.  */
+  if (/* Try standardized names.  */
+      iconv_open ("UTF-8", "EUC-JP") == (iconv_t)(-1)
+      /* Try IRIX, OSF/1 names.  */
+      && iconv_open ("UTF-8", "eucJP") == (iconv_t)(-1)
+      /* Try AIX names.  */
+      && iconv_open ("UTF-8", "IBM-eucJP") == (iconv_t)(-1)
+      /* Try HP-UX names.  */
+      && iconv_open ("utf8", "eucJP") == (iconv_t)(-1))
+    result |= 16;
+  return result;
+]])],
+          [am_cv_func_iconv_works=yes], ,
+          [case "$host_os" in
+             aix* | hpux*) am_cv_func_iconv_works="guessing no" ;;
+             *)            am_cv_func_iconv_works="guessing yes" ;;
+           esac])
+        test "$am_cv_func_iconv_works" = no || break
+      done
+      LIBS="$am_save_LIBS"
+    ])
+    case "$am_cv_func_iconv_works" in
+      *no) am_func_iconv=no am_cv_lib_iconv=no ;;
+      *)   am_func_iconv=yes ;;
+    esac
+  else
+    am_func_iconv=no am_cv_lib_iconv=no
+  fi
+  if test "$am_func_iconv" = yes; then
+    AC_DEFINE([HAVE_ICONV], [1],
+      [Define if you have the iconv() function and it works.])
+  fi
+  if test "$am_cv_lib_iconv" = yes; then
+    AC_MSG_CHECKING([how to link with libiconv])
+    AC_MSG_RESULT([$LIBICONV])
+  else
+    dnl If $LIBICONV didn't lead to a usable library, we don't need $INCICONV
+    dnl either.
+    CPPFLAGS="$am_save_CPPFLAGS"
+    LIBICONV=
+    LTLIBICONV=
+  fi
+  AC_SUBST([LIBICONV])
+  AC_SUBST([LTLIBICONV])
+])
+
+dnl Define AM_ICONV using AC_DEFUN_ONCE for Autoconf >= 2.64, in order to
+dnl avoid warnings like
+dnl "warning: AC_REQUIRE: `AM_ICONV' was expanded before it was required".
+dnl This is tricky because of the way 'aclocal' is implemented:
+dnl - It requires defining an auxiliary macro whose name ends in AC_DEFUN.
+dnl   Otherwise aclocal's initial scan pass would miss the macro definition.
+dnl - It requires a line break inside the AC_DEFUN_ONCE and AC_DEFUN expansions.
+dnl   Otherwise aclocal would emit many "Use of uninitialized value $1"
+dnl   warnings.
+m4_define([gl_iconv_AC_DEFUN],
+  m4_version_prereq([2.64],
+    [[AC_DEFUN_ONCE(
+        [$1], [$2])]],
+    [m4_ifdef([gl_00GNULIB],
+       [[AC_DEFUN_ONCE(
+           [$1], [$2])]],
+       [[AC_DEFUN(
+           [$1], [$2])]])]))
+gl_iconv_AC_DEFUN([AM_ICONV],
+[
+  AM_ICONV_LINK
+  if test "$am_cv_func_iconv" = yes; then
+    AC_MSG_CHECKING([for iconv declaration])
+    AC_CACHE_VAL([am_cv_proto_iconv], [
+      AC_COMPILE_IFELSE(
+        [AC_LANG_PROGRAM(
+           [[
+#include <stdlib.h>
+#include <iconv.h>
+extern
+#ifdef __cplusplus
+"C"
+#endif
+#if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus)
+size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);
+#else
+size_t iconv();
+#endif
+           ]],
+           [[]])],
+        [am_cv_proto_iconv_arg1=""],
+        [am_cv_proto_iconv_arg1="const"])
+      am_cv_proto_iconv="extern size_t iconv (iconv_t cd, $am_cv_proto_iconv_arg1 char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);"])
+    am_cv_proto_iconv=`echo "[$]am_cv_proto_iconv" | tr -s ' ' | sed -e 's/( /(/'`
+    AC_MSG_RESULT([
+         $am_cv_proto_iconv])
+    AC_DEFINE_UNQUOTED([ICONV_CONST], [$am_cv_proto_iconv_arg1],
+      [Define as const if the declaration of iconv() needs const.])
+    dnl Also substitute ICONV_CONST in the gnulib generated <iconv.h>.
+    m4_ifdef([gl_ICONV_H_DEFAULTS],
+      [AC_REQUIRE([gl_ICONV_H_DEFAULTS])
+       if test -n "$am_cv_proto_iconv_arg1"; then
+         ICONV_CONST="const"
+       fi
+      ])
+  fi
+])
Index: csvn-ui-0.1.5/m4/lib-ld.m4
===================================================================
--- csvn-ui-0.1.5/m4/lib-ld.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/lib-ld.m4	(revision 12)
@@ -0,0 +1,119 @@
+# lib-ld.m4 serial 6
+dnl Copyright (C) 1996-2003, 2009-2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+dnl Subroutines of libtool.m4,
+dnl with replacements s/_*LT_PATH/AC_LIB_PROG/ and s/lt_/acl_/ to avoid
+dnl collision with libtool.m4.
+
+dnl From libtool-2.4. Sets the variable with_gnu_ld to yes or no.
+AC_DEFUN([AC_LIB_PROG_LD_GNU],
+[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], [acl_cv_prog_gnu_ld],
+[# I'd rather use --version here, but apparently some GNU lds only accept -v.
+case `$LD -v 2>&1 </dev/null` in
+*GNU* | *'with BFD'*)
+  acl_cv_prog_gnu_ld=yes
+  ;;
+*)
+  acl_cv_prog_gnu_ld=no
+  ;;
+esac])
+with_gnu_ld=$acl_cv_prog_gnu_ld
+])
+
+dnl From libtool-2.4. Sets the variable LD.
+AC_DEFUN([AC_LIB_PROG_LD],
+[AC_REQUIRE([AC_PROG_CC])dnl
+AC_REQUIRE([AC_CANONICAL_HOST])dnl
+
+AC_ARG_WITH([gnu-ld],
+    [AS_HELP_STRING([--with-gnu-ld],
+        [assume the C compiler uses GNU ld [default=no]])],
+    [test "$withval" = no || with_gnu_ld=yes],
+    [with_gnu_ld=no])dnl
+
+# Prepare PATH_SEPARATOR.
+# The user is always right.
+if test "${PATH_SEPARATOR+set}" != set; then
+  # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which
+  # contains only /bin. Note that ksh looks also at the FPATH variable,
+  # so we have to set that as well for the test.
+  PATH_SEPARATOR=:
+  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
+    && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
+           || PATH_SEPARATOR=';'
+       }
+fi
+
+ac_prog=ld
+if test "$GCC" = yes; then
+  # Check if gcc -print-prog-name=ld gives a path.
+  AC_MSG_CHECKING([for ld used by $CC])
+  case $host in
+  *-*-mingw*)
+    # gcc leaves a trailing carriage return which upsets mingw
+    ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
+  *)
+    ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
+  esac
+  case $ac_prog in
+    # Accept absolute paths.
+    [[\\/]]* | ?:[[\\/]]*)
+      re_direlt='/[[^/]][[^/]]*/\.\./'
+      # Canonicalize the pathname of ld
+      ac_prog=`echo "$ac_prog"| sed 's%\\\\%/%g'`
+      while echo "$ac_prog" | grep "$re_direlt" > /dev/null 2>&1; do
+        ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"`
+      done
+      test -z "$LD" && LD="$ac_prog"
+      ;;
+  "")
+    # If it fails, then pretend we aren't using GCC.
+    ac_prog=ld
+    ;;
+  *)
+    # If it is relative, then search for the first ld in PATH.
+    with_gnu_ld=unknown
+    ;;
+  esac
+elif test "$with_gnu_ld" = yes; then
+  AC_MSG_CHECKING([for GNU ld])
+else
+  AC_MSG_CHECKING([for non-GNU ld])
+fi
+AC_CACHE_VAL([acl_cv_path_LD],
+[if test -z "$LD"; then
+  acl_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  for ac_dir in $PATH; do
+    IFS="$acl_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
+      acl_cv_path_LD="$ac_dir/$ac_prog"
+      # Check to see if the program is GNU ld.  I'd rather use --version,
+      # but apparently some variants of GNU ld only accept -v.
+      # Break only if it was the GNU/non-GNU ld that we prefer.
+      case `"$acl_cv_path_LD" -v 2>&1 </dev/null` in
+      *GNU* | *'with BFD'*)
+        test "$with_gnu_ld" != no && break
+        ;;
+      *)
+        test "$with_gnu_ld" != yes && break
+        ;;
+      esac
+    fi
+  done
+  IFS="$acl_save_ifs"
+else
+  acl_cv_path_LD="$LD" # Let the user override the test with a path.
+fi])
+LD="$acl_cv_path_LD"
+if test -n "$LD"; then
+  AC_MSG_RESULT([$LD])
+else
+  AC_MSG_RESULT([no])
+fi
+test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH])
+AC_LIB_PROG_LD_GNU
+])
Index: csvn-ui-0.1.5/m4/lib-link.m4
===================================================================
--- csvn-ui-0.1.5/m4/lib-link.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/lib-link.m4	(revision 12)
@@ -0,0 +1,777 @@
+# lib-link.m4 serial 26 (gettext-0.18.2)
+dnl Copyright (C) 2001-2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+dnl From Bruno Haible.
+
+AC_PREREQ([2.54])
+
+dnl AC_LIB_LINKFLAGS(name [, dependencies]) searches for libname and
+dnl the libraries corresponding to explicit and implicit dependencies.
+dnl Sets and AC_SUBSTs the LIB${NAME} and LTLIB${NAME} variables and
+dnl augments the CPPFLAGS variable.
+dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname
+dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
+AC_DEFUN([AC_LIB_LINKFLAGS],
+[
+  AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
+  AC_REQUIRE([AC_LIB_RPATH])
+  pushdef([Name],[m4_translit([$1],[./+-], [____])])
+  pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-],
+                                   [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+  AC_CACHE_CHECK([how to link with lib[]$1], [ac_cv_lib[]Name[]_libs], [
+    AC_LIB_LINKFLAGS_BODY([$1], [$2])
+    ac_cv_lib[]Name[]_libs="$LIB[]NAME"
+    ac_cv_lib[]Name[]_ltlibs="$LTLIB[]NAME"
+    ac_cv_lib[]Name[]_cppflags="$INC[]NAME"
+    ac_cv_lib[]Name[]_prefix="$LIB[]NAME[]_PREFIX"
+  ])
+  LIB[]NAME="$ac_cv_lib[]Name[]_libs"
+  LTLIB[]NAME="$ac_cv_lib[]Name[]_ltlibs"
+  INC[]NAME="$ac_cv_lib[]Name[]_cppflags"
+  LIB[]NAME[]_PREFIX="$ac_cv_lib[]Name[]_prefix"
+  AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME)
+  AC_SUBST([LIB]NAME)
+  AC_SUBST([LTLIB]NAME)
+  AC_SUBST([LIB]NAME[_PREFIX])
+  dnl Also set HAVE_LIB[]NAME so that AC_LIB_HAVE_LINKFLAGS can reuse the
+  dnl results of this search when this library appears as a dependency.
+  HAVE_LIB[]NAME=yes
+  popdef([NAME])
+  popdef([Name])
+])
+
+dnl AC_LIB_HAVE_LINKFLAGS(name, dependencies, includes, testcode, [missing-message])
+dnl searches for libname and the libraries corresponding to explicit and
+dnl implicit dependencies, together with the specified include files and
+dnl the ability to compile and link the specified testcode. The missing-message
+dnl defaults to 'no' and may contain additional hints for the user.
+dnl If found, it sets and AC_SUBSTs HAVE_LIB${NAME}=yes and the LIB${NAME}
+dnl and LTLIB${NAME} variables and augments the CPPFLAGS variable, and
+dnl #defines HAVE_LIB${NAME} to 1. Otherwise, it sets and AC_SUBSTs
+dnl HAVE_LIB${NAME}=no and LIB${NAME} and LTLIB${NAME} to empty.
+dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname
+dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
+AC_DEFUN([AC_LIB_HAVE_LINKFLAGS],
+[
+  AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
+  AC_REQUIRE([AC_LIB_RPATH])
+  pushdef([Name],[m4_translit([$1],[./+-], [____])])
+  pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-],
+                                   [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+
+  dnl Search for lib[]Name and define LIB[]NAME, LTLIB[]NAME and INC[]NAME
+  dnl accordingly.
+  AC_LIB_LINKFLAGS_BODY([$1], [$2])
+
+  dnl Add $INC[]NAME to CPPFLAGS before performing the following checks,
+  dnl because if the user has installed lib[]Name and not disabled its use
+  dnl via --without-lib[]Name-prefix, he wants to use it.
+  ac_save_CPPFLAGS="$CPPFLAGS"
+  AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME)
+
+  AC_CACHE_CHECK([for lib[]$1], [ac_cv_lib[]Name], [
+    ac_save_LIBS="$LIBS"
+    dnl If $LIB[]NAME contains some -l options, add it to the end of LIBS,
+    dnl because these -l options might require -L options that are present in
+    dnl LIBS. -l options benefit only from the -L options listed before it.
+    dnl Otherwise, add it to the front of LIBS, because it may be a static
+    dnl library that depends on another static library that is present in LIBS.
+    dnl Static libraries benefit only from the static libraries listed after
+    dnl it.
+    case " $LIB[]NAME" in
+      *" -l"*) LIBS="$LIBS $LIB[]NAME" ;;
+      *)       LIBS="$LIB[]NAME $LIBS" ;;
+    esac
+    AC_LINK_IFELSE(
+      [AC_LANG_PROGRAM([[$3]], [[$4]])],
+      [ac_cv_lib[]Name=yes],
+      [ac_cv_lib[]Name='m4_if([$5], [], [no], [[$5]])'])
+    LIBS="$ac_save_LIBS"
+  ])
+  if test "$ac_cv_lib[]Name" = yes; then
+    HAVE_LIB[]NAME=yes
+    AC_DEFINE([HAVE_LIB]NAME, 1, [Define if you have the lib][$1 library.])
+    AC_MSG_CHECKING([how to link with lib[]$1])
+    AC_MSG_RESULT([$LIB[]NAME])
+  else
+    HAVE_LIB[]NAME=no
+    dnl If $LIB[]NAME didn't lead to a usable library, we don't need
+    dnl $INC[]NAME either.
+    CPPFLAGS="$ac_save_CPPFLAGS"
+    LIB[]NAME=
+    LTLIB[]NAME=
+    LIB[]NAME[]_PREFIX=
+  fi
+  AC_SUBST([HAVE_LIB]NAME)
+  AC_SUBST([LIB]NAME)
+  AC_SUBST([LTLIB]NAME)
+  AC_SUBST([LIB]NAME[_PREFIX])
+  popdef([NAME])
+  popdef([Name])
+])
+
+dnl Determine the platform dependent parameters needed to use rpath:
+dnl   acl_libext,
+dnl   acl_shlibext,
+dnl   acl_libname_spec,
+dnl   acl_library_names_spec,
+dnl   acl_hardcode_libdir_flag_spec,
+dnl   acl_hardcode_libdir_separator,
+dnl   acl_hardcode_direct,
+dnl   acl_hardcode_minus_L.
+AC_DEFUN([AC_LIB_RPATH],
+[
+  dnl Tell automake >= 1.10 to complain if config.rpath is missing.
+  m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([config.rpath])])
+  AC_REQUIRE([AC_PROG_CC])                dnl we use $CC, $GCC, $LDFLAGS
+  AC_REQUIRE([AC_LIB_PROG_LD])            dnl we use $LD, $with_gnu_ld
+  AC_REQUIRE([AC_CANONICAL_HOST])         dnl we use $host
+  AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT]) dnl we use $ac_aux_dir
+  AC_CACHE_CHECK([for shared library run path origin], [acl_cv_rpath], [
+    CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \
+    ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh
+    . ./conftest.sh
+    rm -f ./conftest.sh
+    acl_cv_rpath=done
+  ])
+  wl="$acl_cv_wl"
+  acl_libext="$acl_cv_libext"
+  acl_shlibext="$acl_cv_shlibext"
+  acl_libname_spec="$acl_cv_libname_spec"
+  acl_library_names_spec="$acl_cv_library_names_spec"
+  acl_hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec"
+  acl_hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator"
+  acl_hardcode_direct="$acl_cv_hardcode_direct"
+  acl_hardcode_minus_L="$acl_cv_hardcode_minus_L"
+  dnl Determine whether the user wants rpath handling at all.
+  AC_ARG_ENABLE([rpath],
+    [  --disable-rpath         do not hardcode runtime library paths],
+    :, enable_rpath=yes)
+])
+
+dnl AC_LIB_FROMPACKAGE(name, package)
+dnl declares that libname comes from the given package. The configure file
+dnl will then not have a --with-libname-prefix option but a
+dnl --with-package-prefix option. Several libraries can come from the same
+dnl package. This declaration must occur before an AC_LIB_LINKFLAGS or similar
+dnl macro call that searches for libname.
+AC_DEFUN([AC_LIB_FROMPACKAGE],
+[
+  pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-],
+                                   [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+  define([acl_frompackage_]NAME, [$2])
+  popdef([NAME])
+  pushdef([PACK],[$2])
+  pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-],
+                                     [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+  define([acl_libsinpackage_]PACKUP,
+    m4_ifdef([acl_libsinpackage_]PACKUP, [m4_defn([acl_libsinpackage_]PACKUP)[, ]],)[lib$1])
+  popdef([PACKUP])
+  popdef([PACK])
+])
+
+dnl AC_LIB_LINKFLAGS_BODY(name [, dependencies]) searches for libname and
+dnl the libraries corresponding to explicit and implicit dependencies.
+dnl Sets the LIB${NAME}, LTLIB${NAME} and INC${NAME} variables.
+dnl Also, sets the LIB${NAME}_PREFIX variable to nonempty if libname was found
+dnl in ${LIB${NAME}_PREFIX}/$acl_libdirstem.
+AC_DEFUN([AC_LIB_LINKFLAGS_BODY],
+[
+  AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
+  pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-],
+                                   [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+  pushdef([PACK],[m4_ifdef([acl_frompackage_]NAME, [acl_frompackage_]NAME, lib[$1])])
+  pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-],
+                                     [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])])
+  pushdef([PACKLIBS],[m4_ifdef([acl_frompackage_]NAME, [acl_libsinpackage_]PACKUP, lib[$1])])
+  dnl Autoconf >= 2.61 supports dots in --with options.
+  pushdef([P_A_C_K],[m4_if(m4_version_compare(m4_defn([m4_PACKAGE_VERSION]),[2.61]),[-1],[m4_translit(PACK,[.],[_])],PACK)])
+  dnl By default, look in $includedir and $libdir.
+  use_additional=yes
+  AC_LIB_WITH_FINAL_PREFIX([
+    eval additional_includedir=\"$includedir\"
+    eval additional_libdir=\"$libdir\"
+  ])
+  AC_ARG_WITH(P_A_C_K[-prefix],
+[[  --with-]]P_A_C_K[[-prefix[=DIR]  search for ]PACKLIBS[ in DIR/include and DIR/lib
+  --without-]]P_A_C_K[[-prefix     don't search for ]PACKLIBS[ in includedir and libdir]],
+[
+    if test "X$withval" = "Xno"; then
+      use_additional=no
+    else
+      if test "X$withval" = "X"; then
+        AC_LIB_WITH_FINAL_PREFIX([
+          eval additional_includedir=\"$includedir\"
+          eval additional_libdir=\"$libdir\"
+        ])
+      else
+        additional_includedir="$withval/include"
+        additional_libdir="$withval/$acl_libdirstem"
+        if test "$acl_libdirstem2" != "$acl_libdirstem" \
+           && ! test -d "$withval/$acl_libdirstem"; then
+          additional_libdir="$withval/$acl_libdirstem2"
+        fi
+      fi
+    fi
+])
+  dnl Search the library and its dependencies in $additional_libdir and
+  dnl $LDFLAGS. Using breadth-first-seach.
+  LIB[]NAME=
+  LTLIB[]NAME=
+  INC[]NAME=
+  LIB[]NAME[]_PREFIX=
+  dnl HAVE_LIB${NAME} is an indicator that LIB${NAME}, LTLIB${NAME} have been
+  dnl computed. So it has to be reset here.
+  HAVE_LIB[]NAME=
+  rpathdirs=
+  ltrpathdirs=
+  names_already_handled=
+  names_next_round='$1 $2'
+  while test -n "$names_next_round"; do
+    names_this_round="$names_next_round"
+    names_next_round=
+    for name in $names_this_round; do
+      already_handled=
+      for n in $names_already_handled; do
+        if test "$n" = "$name"; then
+          already_handled=yes
+          break
+        fi
+      done
+      if test -z "$already_handled"; then
+        names_already_handled="$names_already_handled $name"
+        dnl See if it was already located by an earlier AC_LIB_LINKFLAGS
+        dnl or AC_LIB_HAVE_LINKFLAGS call.
+        uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./+-|ABCDEFGHIJKLMNOPQRSTUVWXYZ____|'`
+        eval value=\"\$HAVE_LIB$uppername\"
+        if test -n "$value"; then
+          if test "$value" = yes; then
+            eval value=\"\$LIB$uppername\"
+            test -z "$value" || LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$value"
+            eval value=\"\$LTLIB$uppername\"
+            test -z "$value" || LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$value"
+          else
+            dnl An earlier call to AC_LIB_HAVE_LINKFLAGS has determined
+            dnl that this library doesn't exist. So just drop it.
+            :
+          fi
+        else
+          dnl Search the library lib$name in $additional_libdir and $LDFLAGS
+          dnl and the already constructed $LIBNAME/$LTLIBNAME.
+          found_dir=
+          found_la=
+          found_so=
+          found_a=
+          eval libname=\"$acl_libname_spec\"    # typically: libname=lib$name
+          if test -n "$acl_shlibext"; then
+            shrext=".$acl_shlibext"             # typically: shrext=.so
+          else
+            shrext=
+          fi
+          if test $use_additional = yes; then
+            dir="$additional_libdir"
+            dnl The same code as in the loop below:
+            dnl First look for a shared library.
+            if test -n "$acl_shlibext"; then
+              if test -f "$dir/$libname$shrext"; then
+                found_dir="$dir"
+                found_so="$dir/$libname$shrext"
+              else
+                if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then
+                  ver=`(cd "$dir" && \
+                        for f in "$libname$shrext".*; do echo "$f"; done \
+                        | sed -e "s,^$libname$shrext\\\\.,," \
+                        | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \
+                        | sed 1q ) 2>/dev/null`
+                  if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then
+                    found_dir="$dir"
+                    found_so="$dir/$libname$shrext.$ver"
+                  fi
+                else
+                  eval library_names=\"$acl_library_names_spec\"
+                  for f in $library_names; do
+                    if test -f "$dir/$f"; then
+                      found_dir="$dir"
+                      found_so="$dir/$f"
+                      break
+                    fi
+                  done
+                fi
+              fi
+            fi
+            dnl Then look for a static library.
+            if test "X$found_dir" = "X"; then
+              if test -f "$dir/$libname.$acl_libext"; then
+                found_dir="$dir"
+                found_a="$dir/$libname.$acl_libext"
+              fi
+            fi
+            if test "X$found_dir" != "X"; then
+              if test -f "$dir/$libname.la"; then
+                found_la="$dir/$libname.la"
+              fi
+            fi
+          fi
+          if test "X$found_dir" = "X"; then
+            for x in $LDFLAGS $LTLIB[]NAME; do
+              AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+              case "$x" in
+                -L*)
+                  dir=`echo "X$x" | sed -e 's/^X-L//'`
+                  dnl First look for a shared library.
+                  if test -n "$acl_shlibext"; then
+                    if test -f "$dir/$libname$shrext"; then
+                      found_dir="$dir"
+                      found_so="$dir/$libname$shrext"
+                    else
+                      if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then
+                        ver=`(cd "$dir" && \
+                              for f in "$libname$shrext".*; do echo "$f"; done \
+                              | sed -e "s,^$libname$shrext\\\\.,," \
+                              | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \
+                              | sed 1q ) 2>/dev/null`
+                        if test -n "$ver" && test -f "$dir/$libname$shrext.$ver"; then
+                          found_dir="$dir"
+                          found_so="$dir/$libname$shrext.$ver"
+                        fi
+                      else
+                        eval library_names=\"$acl_library_names_spec\"
+                        for f in $library_names; do
+                          if test -f "$dir/$f"; then
+                            found_dir="$dir"
+                            found_so="$dir/$f"
+                            break
+                          fi
+                        done
+                      fi
+                    fi
+                  fi
+                  dnl Then look for a static library.
+                  if test "X$found_dir" = "X"; then
+                    if test -f "$dir/$libname.$acl_libext"; then
+                      found_dir="$dir"
+                      found_a="$dir/$libname.$acl_libext"
+                    fi
+                  fi
+                  if test "X$found_dir" != "X"; then
+                    if test -f "$dir/$libname.la"; then
+                      found_la="$dir/$libname.la"
+                    fi
+                  fi
+                  ;;
+              esac
+              if test "X$found_dir" != "X"; then
+                break
+              fi
+            done
+          fi
+          if test "X$found_dir" != "X"; then
+            dnl Found the library.
+            LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$found_dir -l$name"
+            if test "X$found_so" != "X"; then
+              dnl Linking with a shared library. We attempt to hardcode its
+              dnl directory into the executable's runpath, unless it's the
+              dnl standard /usr/lib.
+              if test "$enable_rpath" = no \
+                 || test "X$found_dir" = "X/usr/$acl_libdirstem" \
+                 || test "X$found_dir" = "X/usr/$acl_libdirstem2"; then
+                dnl No hardcoding is needed.
+                LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
+              else
+                dnl Use an explicit option to hardcode DIR into the resulting
+                dnl binary.
+                dnl Potentially add DIR to ltrpathdirs.
+                dnl The ltrpathdirs will be appended to $LTLIBNAME at the end.
+                haveit=
+                for x in $ltrpathdirs; do
+                  if test "X$x" = "X$found_dir"; then
+                    haveit=yes
+                    break
+                  fi
+                done
+                if test -z "$haveit"; then
+                  ltrpathdirs="$ltrpathdirs $found_dir"
+                fi
+                dnl The hardcoding into $LIBNAME is system dependent.
+                if test "$acl_hardcode_direct" = yes; then
+                  dnl Using DIR/libNAME.so during linking hardcodes DIR into the
+                  dnl resulting binary.
+                  LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
+                else
+                  if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then
+                    dnl Use an explicit option to hardcode DIR into the resulting
+                    dnl binary.
+                    LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
+                    dnl Potentially add DIR to rpathdirs.
+                    dnl The rpathdirs will be appended to $LIBNAME at the end.
+                    haveit=
+                    for x in $rpathdirs; do
+                      if test "X$x" = "X$found_dir"; then
+                        haveit=yes
+                        break
+                      fi
+                    done
+                    if test -z "$haveit"; then
+                      rpathdirs="$rpathdirs $found_dir"
+                    fi
+                  else
+                    dnl Rely on "-L$found_dir".
+                    dnl But don't add it if it's already contained in the LDFLAGS
+                    dnl or the already constructed $LIBNAME
+                    haveit=
+                    for x in $LDFLAGS $LIB[]NAME; do
+                      AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+                      if test "X$x" = "X-L$found_dir"; then
+                        haveit=yes
+                        break
+                      fi
+                    done
+                    if test -z "$haveit"; then
+                      LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir"
+                    fi
+                    if test "$acl_hardcode_minus_L" != no; then
+                      dnl FIXME: Not sure whether we should use
+                      dnl "-L$found_dir -l$name" or "-L$found_dir $found_so"
+                      dnl here.
+                      LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so"
+                    else
+                      dnl We cannot use $acl_hardcode_runpath_var and LD_RUN_PATH
+                      dnl here, because this doesn't fit in flags passed to the
+                      dnl compiler. So give up. No hardcoding. This affects only
+                      dnl very old systems.
+                      dnl FIXME: Not sure whether we should use
+                      dnl "-L$found_dir -l$name" or "-L$found_dir $found_so"
+                      dnl here.
+                      LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name"
+                    fi
+                  fi
+                fi
+              fi
+            else
+              if test "X$found_a" != "X"; then
+                dnl Linking with a static library.
+                LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_a"
+              else
+                dnl We shouldn't come here, but anyway it's good to have a
+                dnl fallback.
+                LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir -l$name"
+              fi
+            fi
+            dnl Assume the include files are nearby.
+            additional_includedir=
+            case "$found_dir" in
+              */$acl_libdirstem | */$acl_libdirstem/)
+                basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'`
+                if test "$name" = '$1'; then
+                  LIB[]NAME[]_PREFIX="$basedir"
+                fi
+                additional_includedir="$basedir/include"
+                ;;
+              */$acl_libdirstem2 | */$acl_libdirstem2/)
+                basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem2/"'*$,,'`
+                if test "$name" = '$1'; then
+                  LIB[]NAME[]_PREFIX="$basedir"
+                fi
+                additional_includedir="$basedir/include"
+                ;;
+            esac
+            if test "X$additional_includedir" != "X"; then
+              dnl Potentially add $additional_includedir to $INCNAME.
+              dnl But don't add it
+              dnl   1. if it's the standard /usr/include,
+              dnl   2. if it's /usr/local/include and we are using GCC on Linux,
+              dnl   3. if it's already present in $CPPFLAGS or the already
+              dnl      constructed $INCNAME,
+              dnl   4. if it doesn't exist as a directory.
+              if test "X$additional_includedir" != "X/usr/include"; then
+                haveit=
+                if test "X$additional_includedir" = "X/usr/local/include"; then
+                  if test -n "$GCC"; then
+                    case $host_os in
+                      linux* | gnu* | k*bsd*-gnu) haveit=yes;;
+                    esac
+                  fi
+                fi
+                if test -z "$haveit"; then
+                  for x in $CPPFLAGS $INC[]NAME; do
+                    AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+                    if test "X$x" = "X-I$additional_includedir"; then
+                      haveit=yes
+                      break
+                    fi
+                  done
+                  if test -z "$haveit"; then
+                    if test -d "$additional_includedir"; then
+                      dnl Really add $additional_includedir to $INCNAME.
+                      INC[]NAME="${INC[]NAME}${INC[]NAME:+ }-I$additional_includedir"
+                    fi
+                  fi
+                fi
+              fi
+            fi
+            dnl Look for dependencies.
+            if test -n "$found_la"; then
+              dnl Read the .la file. It defines the variables
+              dnl dlname, library_names, old_library, dependency_libs, current,
+              dnl age, revision, installed, dlopen, dlpreopen, libdir.
+              save_libdir="$libdir"
+              case "$found_la" in
+                */* | *\\*) . "$found_la" ;;
+                *) . "./$found_la" ;;
+              esac
+              libdir="$save_libdir"
+              dnl We use only dependency_libs.
+              for dep in $dependency_libs; do
+                case "$dep" in
+                  -L*)
+                    additional_libdir=`echo "X$dep" | sed -e 's/^X-L//'`
+                    dnl Potentially add $additional_libdir to $LIBNAME and $LTLIBNAME.
+                    dnl But don't add it
+                    dnl   1. if it's the standard /usr/lib,
+                    dnl   2. if it's /usr/local/lib and we are using GCC on Linux,
+                    dnl   3. if it's already present in $LDFLAGS or the already
+                    dnl      constructed $LIBNAME,
+                    dnl   4. if it doesn't exist as a directory.
+                    if test "X$additional_libdir" != "X/usr/$acl_libdirstem" \
+                       && test "X$additional_libdir" != "X/usr/$acl_libdirstem2"; then
+                      haveit=
+                      if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem" \
+                         || test "X$additional_libdir" = "X/usr/local/$acl_libdirstem2"; then
+                        if test -n "$GCC"; then
+                          case $host_os in
+                            linux* | gnu* | k*bsd*-gnu) haveit=yes;;
+                          esac
+                        fi
+                      fi
+                      if test -z "$haveit"; then
+                        haveit=
+                        for x in $LDFLAGS $LIB[]NAME; do
+                          AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+                          if test "X$x" = "X-L$additional_libdir"; then
+                            haveit=yes
+                            break
+                          fi
+                        done
+                        if test -z "$haveit"; then
+                          if test -d "$additional_libdir"; then
+                            dnl Really add $additional_libdir to $LIBNAME.
+                            LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$additional_libdir"
+                          fi
+                        fi
+                        haveit=
+                        for x in $LDFLAGS $LTLIB[]NAME; do
+                          AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+                          if test "X$x" = "X-L$additional_libdir"; then
+                            haveit=yes
+                            break
+                          fi
+                        done
+                        if test -z "$haveit"; then
+                          if test -d "$additional_libdir"; then
+                            dnl Really add $additional_libdir to $LTLIBNAME.
+                            LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$additional_libdir"
+                          fi
+                        fi
+                      fi
+                    fi
+                    ;;
+                  -R*)
+                    dir=`echo "X$dep" | sed -e 's/^X-R//'`
+                    if test "$enable_rpath" != no; then
+                      dnl Potentially add DIR to rpathdirs.
+                      dnl The rpathdirs will be appended to $LIBNAME at the end.
+                      haveit=
+                      for x in $rpathdirs; do
+                        if test "X$x" = "X$dir"; then
+                          haveit=yes
+                          break
+                        fi
+                      done
+                      if test -z "$haveit"; then
+                        rpathdirs="$rpathdirs $dir"
+                      fi
+                      dnl Potentially add DIR to ltrpathdirs.
+                      dnl The ltrpathdirs will be appended to $LTLIBNAME at the end.
+                      haveit=
+                      for x in $ltrpathdirs; do
+                        if test "X$x" = "X$dir"; then
+                          haveit=yes
+                          break
+                        fi
+                      done
+                      if test -z "$haveit"; then
+                        ltrpathdirs="$ltrpathdirs $dir"
+                      fi
+                    fi
+                    ;;
+                  -l*)
+                    dnl Handle this in the next round.
+                    names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'`
+                    ;;
+                  *.la)
+                    dnl Handle this in the next round. Throw away the .la's
+                    dnl directory; it is already contained in a preceding -L
+                    dnl option.
+                    names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'`
+                    ;;
+                  *)
+                    dnl Most likely an immediate library name.
+                    LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$dep"
+                    LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$dep"
+                    ;;
+                esac
+              done
+            fi
+          else
+            dnl Didn't find the library; assume it is in the system directories
+            dnl known to the linker and runtime loader. (All the system
+            dnl directories known to the linker should also be known to the
+            dnl runtime loader, otherwise the system is severely misconfigured.)
+            LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name"
+            LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-l$name"
+          fi
+        fi
+      fi
+    done
+  done
+  if test "X$rpathdirs" != "X"; then
+    if test -n "$acl_hardcode_libdir_separator"; then
+      dnl Weird platform: only the last -rpath option counts, the user must
+      dnl pass all path elements in one option. We can arrange that for a
+      dnl single library, but not when more than one $LIBNAMEs are used.
+      alldirs=
+      for found_dir in $rpathdirs; do
+        alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir"
+      done
+      dnl Note: acl_hardcode_libdir_flag_spec uses $libdir and $wl.
+      acl_save_libdir="$libdir"
+      libdir="$alldirs"
+      eval flag=\"$acl_hardcode_libdir_flag_spec\"
+      libdir="$acl_save_libdir"
+      LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag"
+    else
+      dnl The -rpath options are cumulative.
+      for found_dir in $rpathdirs; do
+        acl_save_libdir="$libdir"
+        libdir="$found_dir"
+        eval flag=\"$acl_hardcode_libdir_flag_spec\"
+        libdir="$acl_save_libdir"
+        LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag"
+      done
+    fi
+  fi
+  if test "X$ltrpathdirs" != "X"; then
+    dnl When using libtool, the option that works for both libraries and
+    dnl executables is -R. The -R options are cumulative.
+    for found_dir in $ltrpathdirs; do
+      LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-R$found_dir"
+    done
+  fi
+  popdef([P_A_C_K])
+  popdef([PACKLIBS])
+  popdef([PACKUP])
+  popdef([PACK])
+  popdef([NAME])
+])
+
+dnl AC_LIB_APPENDTOVAR(VAR, CONTENTS) appends the elements of CONTENTS to VAR,
+dnl unless already present in VAR.
+dnl Works only for CPPFLAGS, not for LIB* variables because that sometimes
+dnl contains two or three consecutive elements that belong together.
+AC_DEFUN([AC_LIB_APPENDTOVAR],
+[
+  for element in [$2]; do
+    haveit=
+    for x in $[$1]; do
+      AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+      if test "X$x" = "X$element"; then
+        haveit=yes
+        break
+      fi
+    done
+    if test -z "$haveit"; then
+      [$1]="${[$1]}${[$1]:+ }$element"
+    fi
+  done
+])
+
+dnl For those cases where a variable contains several -L and -l options
+dnl referring to unknown libraries and directories, this macro determines the
+dnl necessary additional linker options for the runtime path.
+dnl AC_LIB_LINKFLAGS_FROM_LIBS([LDADDVAR], [LIBSVALUE], [USE-LIBTOOL])
+dnl sets LDADDVAR to linker options needed together with LIBSVALUE.
+dnl If USE-LIBTOOL evaluates to non-empty, linking with libtool is assumed,
+dnl otherwise linking without libtool is assumed.
+AC_DEFUN([AC_LIB_LINKFLAGS_FROM_LIBS],
+[
+  AC_REQUIRE([AC_LIB_RPATH])
+  AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
+  $1=
+  if test "$enable_rpath" != no; then
+    if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then
+      dnl Use an explicit option to hardcode directories into the resulting
+      dnl binary.
+      rpathdirs=
+      next=
+      for opt in $2; do
+        if test -n "$next"; then
+          dir="$next"
+          dnl No need to hardcode the standard /usr/lib.
+          if test "X$dir" != "X/usr/$acl_libdirstem" \
+             && test "X$dir" != "X/usr/$acl_libdirstem2"; then
+            rpathdirs="$rpathdirs $dir"
+          fi
+          next=
+        else
+          case $opt in
+            -L) next=yes ;;
+            -L*) dir=`echo "X$opt" | sed -e 's,^X-L,,'`
+                 dnl No need to hardcode the standard /usr/lib.
+                 if test "X$dir" != "X/usr/$acl_libdirstem" \
+                    && test "X$dir" != "X/usr/$acl_libdirstem2"; then
+                   rpathdirs="$rpathdirs $dir"
+                 fi
+                 next= ;;
+            *) next= ;;
+          esac
+        fi
+      done
+      if test "X$rpathdirs" != "X"; then
+        if test -n ""$3""; then
+          dnl libtool is used for linking. Use -R options.
+          for dir in $rpathdirs; do
+            $1="${$1}${$1:+ }-R$dir"
+          done
+        else
+          dnl The linker is used for linking directly.
+          if test -n "$acl_hardcode_libdir_separator"; then
+            dnl Weird platform: only the last -rpath option counts, the user
+            dnl must pass all path elements in one option.
+            alldirs=
+            for dir in $rpathdirs; do
+              alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$dir"
+            done
+            acl_save_libdir="$libdir"
+            libdir="$alldirs"
+            eval flag=\"$acl_hardcode_libdir_flag_spec\"
+            libdir="$acl_save_libdir"
+            $1="$flag"
+          else
+            dnl The -rpath options are cumulative.
+            for dir in $rpathdirs; do
+              acl_save_libdir="$libdir"
+              libdir="$dir"
+              eval flag=\"$acl_hardcode_libdir_flag_spec\"
+              libdir="$acl_save_libdir"
+              $1="${$1}${$1:+ }$flag"
+            done
+          fi
+        fi
+      fi
+    fi
+  fi
+  AC_SUBST([$1])
+])
Index: csvn-ui-0.1.5/m4/lib-prefix.m4
===================================================================
--- csvn-ui-0.1.5/m4/lib-prefix.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/lib-prefix.m4	(revision 12)
@@ -0,0 +1,224 @@
+# lib-prefix.m4 serial 7 (gettext-0.18)
+dnl Copyright (C) 2001-2005, 2008-2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+
+dnl From Bruno Haible.
+
+dnl AC_LIB_ARG_WITH is synonymous to AC_ARG_WITH in autoconf-2.13, and
+dnl similar to AC_ARG_WITH in autoconf 2.52...2.57 except that is doesn't
+dnl require excessive bracketing.
+ifdef([AC_HELP_STRING],
+[AC_DEFUN([AC_LIB_ARG_WITH], [AC_ARG_WITH([$1],[[$2]],[$3],[$4])])],
+[AC_DEFUN([AC_][LIB_ARG_WITH], [AC_ARG_WITH([$1],[$2],[$3],[$4])])])
+
+dnl AC_LIB_PREFIX adds to the CPPFLAGS and LDFLAGS the flags that are needed
+dnl to access previously installed libraries. The basic assumption is that
+dnl a user will want packages to use other packages he previously installed
+dnl with the same --prefix option.
+dnl This macro is not needed if only AC_LIB_LINKFLAGS is used to locate
+dnl libraries, but is otherwise very convenient.
+AC_DEFUN([AC_LIB_PREFIX],
+[
+  AC_BEFORE([$0], [AC_LIB_LINKFLAGS])
+  AC_REQUIRE([AC_PROG_CC])
+  AC_REQUIRE([AC_CANONICAL_HOST])
+  AC_REQUIRE([AC_LIB_PREPARE_MULTILIB])
+  AC_REQUIRE([AC_LIB_PREPARE_PREFIX])
+  dnl By default, look in $includedir and $libdir.
+  use_additional=yes
+  AC_LIB_WITH_FINAL_PREFIX([
+    eval additional_includedir=\"$includedir\"
+    eval additional_libdir=\"$libdir\"
+  ])
+  AC_LIB_ARG_WITH([lib-prefix],
+[  --with-lib-prefix[=DIR] search for libraries in DIR/include and DIR/lib
+  --without-lib-prefix    don't search for libraries in includedir and libdir],
+[
+    if test "X$withval" = "Xno"; then
+      use_additional=no
+    else
+      if test "X$withval" = "X"; then
+        AC_LIB_WITH_FINAL_PREFIX([
+          eval additional_includedir=\"$includedir\"
+          eval additional_libdir=\"$libdir\"
+        ])
+      else
+        additional_includedir="$withval/include"
+        additional_libdir="$withval/$acl_libdirstem"
+      fi
+    fi
+])
+  if test $use_additional = yes; then
+    dnl Potentially add $additional_includedir to $CPPFLAGS.
+    dnl But don't add it
+    dnl   1. if it's the standard /usr/include,
+    dnl   2. if it's already present in $CPPFLAGS,
+    dnl   3. if it's /usr/local/include and we are using GCC on Linux,
+    dnl   4. if it doesn't exist as a directory.
+    if test "X$additional_includedir" != "X/usr/include"; then
+      haveit=
+      for x in $CPPFLAGS; do
+        AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+        if test "X$x" = "X-I$additional_includedir"; then
+          haveit=yes
+          break
+        fi
+      done
+      if test -z "$haveit"; then
+        if test "X$additional_includedir" = "X/usr/local/include"; then
+          if test -n "$GCC"; then
+            case $host_os in
+              linux* | gnu* | k*bsd*-gnu) haveit=yes;;
+            esac
+          fi
+        fi
+        if test -z "$haveit"; then
+          if test -d "$additional_includedir"; then
+            dnl Really add $additional_includedir to $CPPFLAGS.
+            CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-I$additional_includedir"
+          fi
+        fi
+      fi
+    fi
+    dnl Potentially add $additional_libdir to $LDFLAGS.
+    dnl But don't add it
+    dnl   1. if it's the standard /usr/lib,
+    dnl   2. if it's already present in $LDFLAGS,
+    dnl   3. if it's /usr/local/lib and we are using GCC on Linux,
+    dnl   4. if it doesn't exist as a directory.
+    if test "X$additional_libdir" != "X/usr/$acl_libdirstem"; then
+      haveit=
+      for x in $LDFLAGS; do
+        AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"])
+        if test "X$x" = "X-L$additional_libdir"; then
+          haveit=yes
+          break
+        fi
+      done
+      if test -z "$haveit"; then
+        if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem"; then
+          if test -n "$GCC"; then
+            case $host_os in
+              linux*) haveit=yes;;
+            esac
+          fi
+        fi
+        if test -z "$haveit"; then
+          if test -d "$additional_libdir"; then
+            dnl Really add $additional_libdir to $LDFLAGS.
+            LDFLAGS="${LDFLAGS}${LDFLAGS:+ }-L$additional_libdir"
+          fi
+        fi
+      fi
+    fi
+  fi
+])
+
+dnl AC_LIB_PREPARE_PREFIX creates variables acl_final_prefix,
+dnl acl_final_exec_prefix, containing the values to which $prefix and
+dnl $exec_prefix will expand at the end of the configure script.
+AC_DEFUN([AC_LIB_PREPARE_PREFIX],
+[
+  dnl Unfortunately, prefix and exec_prefix get only finally determined
+  dnl at the end of configure.
+  if test "X$prefix" = "XNONE"; then
+    acl_final_prefix="$ac_default_prefix"
+  else
+    acl_final_prefix="$prefix"
+  fi
+  if test "X$exec_prefix" = "XNONE"; then
+    acl_final_exec_prefix='${prefix}'
+  else
+    acl_final_exec_prefix="$exec_prefix"
+  fi
+  acl_save_prefix="$prefix"
+  prefix="$acl_final_prefix"
+  eval acl_final_exec_prefix=\"$acl_final_exec_prefix\"
+  prefix="$acl_save_prefix"
+])
+
+dnl AC_LIB_WITH_FINAL_PREFIX([statement]) evaluates statement, with the
+dnl variables prefix and exec_prefix bound to the values they will have
+dnl at the end of the configure script.
+AC_DEFUN([AC_LIB_WITH_FINAL_PREFIX],
+[
+  acl_save_prefix="$prefix"
+  prefix="$acl_final_prefix"
+  acl_save_exec_prefix="$exec_prefix"
+  exec_prefix="$acl_final_exec_prefix"
+  $1
+  exec_prefix="$acl_save_exec_prefix"
+  prefix="$acl_save_prefix"
+])
+
+dnl AC_LIB_PREPARE_MULTILIB creates
+dnl - a variable acl_libdirstem, containing the basename of the libdir, either
+dnl   "lib" or "lib64" or "lib/64",
+dnl - a variable acl_libdirstem2, as a secondary possible value for
+dnl   acl_libdirstem, either the same as acl_libdirstem or "lib/sparcv9" or
+dnl   "lib/amd64".
+AC_DEFUN([AC_LIB_PREPARE_MULTILIB],
+[
+  dnl There is no formal standard regarding lib and lib64.
+  dnl On glibc systems, the current practice is that on a system supporting
+  dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under
+  dnl $prefix/lib64 and 32-bit libraries go under $prefix/lib. We determine
+  dnl the compiler's default mode by looking at the compiler's library search
+  dnl path. If at least one of its elements ends in /lib64 or points to a
+  dnl directory whose absolute pathname ends in /lib64, we assume a 64-bit ABI.
+  dnl Otherwise we use the default, namely "lib".
+  dnl On Solaris systems, the current practice is that on a system supporting
+  dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under
+  dnl $prefix/lib/64 (which is a symlink to either $prefix/lib/sparcv9 or
+  dnl $prefix/lib/amd64) and 32-bit libraries go under $prefix/lib.
+  AC_REQUIRE([AC_CANONICAL_HOST])
+  acl_libdirstem=lib
+  acl_libdirstem2=
+  case "$host_os" in
+    solaris*)
+      dnl See Solaris 10 Software Developer Collection > Solaris 64-bit Developer's Guide > The Development Environment
+      dnl <http://docs.sun.com/app/docs/doc/816-5138/dev-env?l=en&a=view>.
+      dnl "Portable Makefiles should refer to any library directories using the 64 symbolic link."
+      dnl But we want to recognize the sparcv9 or amd64 subdirectory also if the
+      dnl symlink is missing, so we set acl_libdirstem2 too.
+      AC_CACHE_CHECK([for 64-bit host], [gl_cv_solaris_64bit],
+        [AC_EGREP_CPP([sixtyfour bits], [
+#ifdef _LP64
+sixtyfour bits
+#endif
+           ], [gl_cv_solaris_64bit=yes], [gl_cv_solaris_64bit=no])
+        ])
+      if test $gl_cv_solaris_64bit = yes; then
+        acl_libdirstem=lib/64
+        case "$host_cpu" in
+          sparc*)        acl_libdirstem2=lib/sparcv9 ;;
+          i*86 | x86_64) acl_libdirstem2=lib/amd64 ;;
+        esac
+      fi
+      ;;
+    *)
+      searchpath=`(LC_ALL=C $CC -print-search-dirs) 2>/dev/null | sed -n -e 's,^libraries: ,,p' | sed -e 's,^=,,'`
+      if test -n "$searchpath"; then
+        acl_save_IFS="${IFS= 	}"; IFS=":"
+        for searchdir in $searchpath; do
+          if test -d "$searchdir"; then
+            case "$searchdir" in
+              */lib64/ | */lib64 ) acl_libdirstem=lib64 ;;
+              */../ | */.. )
+                # Better ignore directories of this form. They are misleading.
+                ;;
+              *) searchdir=`cd "$searchdir" && pwd`
+                 case "$searchdir" in
+                   */lib64 ) acl_libdirstem=lib64 ;;
+                 esac ;;
+            esac
+          fi
+        done
+        IFS="$acl_save_IFS"
+      fi
+      ;;
+  esac
+  test -n "$acl_libdirstem2" || acl_libdirstem2="$acl_libdirstem"
+])
Index: csvn-ui-0.1.5/m4/nls.m4
===================================================================
--- csvn-ui-0.1.5/m4/nls.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/nls.m4	(revision 12)
@@ -0,0 +1,32 @@
+# nls.m4 serial 5 (gettext-0.18)
+dnl Copyright (C) 1995-2003, 2005-2006, 2008-2014, 2016 Free Software
+dnl Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+dnl
+dnl This file can be used in projects which are not available under
+dnl the GNU General Public License or the GNU Library General Public
+dnl License but which still want to provide support for the GNU gettext
+dnl functionality.
+dnl Please note that the actual code of the GNU gettext library is covered
+dnl by the GNU Library General Public License, and the rest of the GNU
+dnl gettext package is covered by the GNU General Public License.
+dnl They are *not* in the public domain.
+
+dnl Authors:
+dnl   Ulrich Drepper <drepper@cygnus.com>, 1995-2000.
+dnl   Bruno Haible <haible@clisp.cons.org>, 2000-2003.
+
+AC_PREREQ([2.50])
+
+AC_DEFUN([AM_NLS],
+[
+  AC_MSG_CHECKING([whether NLS is requested])
+  dnl Default is enabled NLS
+  AC_ARG_ENABLE([nls],
+    [  --disable-nls           do not use Native Language Support],
+    USE_NLS=$enableval, USE_NLS=yes)
+  AC_MSG_RESULT([$USE_NLS])
+  AC_SUBST([USE_NLS])
+])
Index: csvn-ui-0.1.5/m4/po.m4
===================================================================
--- csvn-ui-0.1.5/m4/po.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/po.m4	(revision 12)
@@ -0,0 +1,453 @@
+# po.m4 serial 24 (gettext-0.19)
+dnl Copyright (C) 1995-2014, 2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+dnl
+dnl This file can be used in projects which are not available under
+dnl the GNU General Public License or the GNU Library General Public
+dnl License but which still want to provide support for the GNU gettext
+dnl functionality.
+dnl Please note that the actual code of the GNU gettext library is covered
+dnl by the GNU Library General Public License, and the rest of the GNU
+dnl gettext package is covered by the GNU General Public License.
+dnl They are *not* in the public domain.
+
+dnl Authors:
+dnl   Ulrich Drepper <drepper@cygnus.com>, 1995-2000.
+dnl   Bruno Haible <haible@clisp.cons.org>, 2000-2003.
+
+AC_PREREQ([2.60])
+
+dnl Checks for all prerequisites of the po subdirectory.
+AC_DEFUN([AM_PO_SUBDIRS],
+[
+  AC_REQUIRE([AC_PROG_MAKE_SET])dnl
+  AC_REQUIRE([AC_PROG_INSTALL])dnl
+  AC_REQUIRE([AC_PROG_MKDIR_P])dnl
+  AC_REQUIRE([AC_PROG_SED])dnl
+  AC_REQUIRE([AM_NLS])dnl
+
+  dnl Release version of the gettext macros. This is used to ensure that
+  dnl the gettext macros and po/Makefile.in.in are in sync.
+  AC_SUBST([GETTEXT_MACRO_VERSION], [0.19])
+
+  dnl Perform the following tests also if --disable-nls has been given,
+  dnl because they are needed for "make dist" to work.
+
+  dnl Search for GNU msgfmt in the PATH.
+  dnl The first test excludes Solaris msgfmt and early GNU msgfmt versions.
+  dnl The second test excludes FreeBSD msgfmt.
+  AM_PATH_PROG_WITH_TEST(MSGFMT, msgfmt,
+    [$ac_dir/$ac_word --statistics /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 &&
+     (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)],
+    :)
+  AC_PATH_PROG([GMSGFMT], [gmsgfmt], [$MSGFMT])
+
+  dnl Test whether it is GNU msgfmt >= 0.15.
+changequote(,)dnl
+  case `$MSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in
+    '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) MSGFMT_015=: ;;
+    *) MSGFMT_015=$MSGFMT ;;
+  esac
+changequote([,])dnl
+  AC_SUBST([MSGFMT_015])
+changequote(,)dnl
+  case `$GMSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in
+    '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) GMSGFMT_015=: ;;
+    *) GMSGFMT_015=$GMSGFMT ;;
+  esac
+changequote([,])dnl
+  AC_SUBST([GMSGFMT_015])
+
+  dnl Search for GNU xgettext 0.12 or newer in the PATH.
+  dnl The first test excludes Solaris xgettext and early GNU xgettext versions.
+  dnl The second test excludes FreeBSD xgettext.
+  AM_PATH_PROG_WITH_TEST(XGETTEXT, xgettext,
+    [$ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 &&
+     (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)],
+    :)
+  dnl Remove leftover from FreeBSD xgettext call.
+  rm -f messages.po
+
+  dnl Test whether it is GNU xgettext >= 0.15.
+changequote(,)dnl
+  case `$XGETTEXT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in
+    '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) XGETTEXT_015=: ;;
+    *) XGETTEXT_015=$XGETTEXT ;;
+  esac
+changequote([,])dnl
+  AC_SUBST([XGETTEXT_015])
+
+  dnl Search for GNU msgmerge 0.11 or newer in the PATH.
+  AM_PATH_PROG_WITH_TEST(MSGMERGE, msgmerge,
+    [$ac_dir/$ac_word --update -q /dev/null /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1], :)
+
+  dnl Installation directories.
+  dnl Autoconf >= 2.60 defines localedir. For older versions of autoconf, we
+  dnl have to define it here, so that it can be used in po/Makefile.
+  test -n "$localedir" || localedir='${datadir}/locale'
+  AC_SUBST([localedir])
+
+  dnl Support for AM_XGETTEXT_OPTION.
+  test -n "${XGETTEXT_EXTRA_OPTIONS+set}" || XGETTEXT_EXTRA_OPTIONS=
+  AC_SUBST([XGETTEXT_EXTRA_OPTIONS])
+
+  AC_CONFIG_COMMANDS([po-directories], [[
+    for ac_file in $CONFIG_FILES; do
+      # Support "outfile[:infile[:infile...]]"
+      case "$ac_file" in
+        *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;;
+      esac
+      # PO directories have a Makefile.in generated from Makefile.in.in.
+      case "$ac_file" in */Makefile.in)
+        # Adjust a relative srcdir.
+        ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'`
+        ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'`
+        ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'`
+        # In autoconf-2.13 it is called $ac_given_srcdir.
+        # In autoconf-2.50 it is called $srcdir.
+        test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir"
+        case "$ac_given_srcdir" in
+          .)  top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;;
+          /*) top_srcdir="$ac_given_srcdir" ;;
+          *)  top_srcdir="$ac_dots$ac_given_srcdir" ;;
+        esac
+        # Treat a directory as a PO directory if and only if it has a
+        # POTFILES.in file. This allows packages to have multiple PO
+        # directories under different names or in different locations.
+        if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then
+          rm -f "$ac_dir/POTFILES"
+          test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES"
+          gt_tab=`printf '\t'`
+          cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ${gt_tab}]*\$/d" -e "s,.*,     $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES"
+          POMAKEFILEDEPS="POTFILES.in"
+          # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend
+          # on $ac_dir but don't depend on user-specified configuration
+          # parameters.
+          if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then
+            # The LINGUAS file contains the set of available languages.
+            if test -n "$OBSOLETE_ALL_LINGUAS"; then
+              test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete"
+            fi
+            ALL_LINGUAS_=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"`
+            # Hide the ALL_LINGUAS assignment from automake < 1.5.
+            eval 'ALL_LINGUAS''=$ALL_LINGUAS_'
+            POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS"
+          else
+            # The set of available languages was given in configure.in.
+            # Hide the ALL_LINGUAS assignment from automake < 1.5.
+            eval 'ALL_LINGUAS''=$OBSOLETE_ALL_LINGUAS'
+          fi
+          # Compute POFILES
+          # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po)
+          # Compute UPDATEPOFILES
+          # as      $(foreach lang, $(ALL_LINGUAS), $(lang).po-update)
+          # Compute DUMMYPOFILES
+          # as      $(foreach lang, $(ALL_LINGUAS), $(lang).nop)
+          # Compute GMOFILES
+          # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo)
+          case "$ac_given_srcdir" in
+            .) srcdirpre= ;;
+            *) srcdirpre='$(srcdir)/' ;;
+          esac
+          POFILES=
+          UPDATEPOFILES=
+          DUMMYPOFILES=
+          GMOFILES=
+          for lang in $ALL_LINGUAS; do
+            POFILES="$POFILES $srcdirpre$lang.po"
+            UPDATEPOFILES="$UPDATEPOFILES $lang.po-update"
+            DUMMYPOFILES="$DUMMYPOFILES $lang.nop"
+            GMOFILES="$GMOFILES $srcdirpre$lang.gmo"
+          done
+          # CATALOGS depends on both $ac_dir and the user's LINGUAS
+          # environment variable.
+          INST_LINGUAS=
+          if test -n "$ALL_LINGUAS"; then
+            for presentlang in $ALL_LINGUAS; do
+              useit=no
+              if test "%UNSET%" != "$LINGUAS"; then
+                desiredlanguages="$LINGUAS"
+              else
+                desiredlanguages="$ALL_LINGUAS"
+              fi
+              for desiredlang in $desiredlanguages; do
+                # Use the presentlang catalog if desiredlang is
+                #   a. equal to presentlang, or
+                #   b. a variant of presentlang (because in this case,
+                #      presentlang can be used as a fallback for messages
+                #      which are not translated in the desiredlang catalog).
+                case "$desiredlang" in
+                  "$presentlang"*) useit=yes;;
+                esac
+              done
+              if test $useit = yes; then
+                INST_LINGUAS="$INST_LINGUAS $presentlang"
+              fi
+            done
+          fi
+          CATALOGS=
+          if test -n "$INST_LINGUAS"; then
+            for lang in $INST_LINGUAS; do
+              CATALOGS="$CATALOGS $lang.gmo"
+            done
+          fi
+          test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile"
+          sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile"
+          for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do
+            if test -f "$f"; then
+              case "$f" in
+                *.orig | *.bak | *~) ;;
+                *) cat "$f" >> "$ac_dir/Makefile" ;;
+              esac
+            fi
+          done
+        fi
+        ;;
+      esac
+    done]],
+   [# Capture the value of obsolete ALL_LINGUAS because we need it to compute
+    # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. But hide it
+    # from automake < 1.5.
+    eval 'OBSOLETE_ALL_LINGUAS''="$ALL_LINGUAS"'
+    # Capture the value of LINGUAS because we need it to compute CATALOGS.
+    LINGUAS="${LINGUAS-%UNSET%}"
+   ])
+])
+
+dnl Postprocesses a Makefile in a directory containing PO files.
+AC_DEFUN([AM_POSTPROCESS_PO_MAKEFILE],
+[
+  # When this code is run, in config.status, two variables have already been
+  # set:
+  # - OBSOLETE_ALL_LINGUAS is the value of LINGUAS set in configure.in,
+  # - LINGUAS is the value of the environment variable LINGUAS at configure
+  #   time.
+
+changequote(,)dnl
+  # Adjust a relative srcdir.
+  ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'`
+  ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'`
+  ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'`
+  # In autoconf-2.13 it is called $ac_given_srcdir.
+  # In autoconf-2.50 it is called $srcdir.
+  test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir"
+  case "$ac_given_srcdir" in
+    .)  top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;;
+    /*) top_srcdir="$ac_given_srcdir" ;;
+    *)  top_srcdir="$ac_dots$ac_given_srcdir" ;;
+  esac
+
+  # Find a way to echo strings without interpreting backslash.
+  if test "X`(echo '\t') 2>/dev/null`" = 'X\t'; then
+    gt_echo='echo'
+  else
+    if test "X`(printf '%s\n' '\t') 2>/dev/null`" = 'X\t'; then
+      gt_echo='printf %s\n'
+    else
+      echo_func () {
+        cat <<EOT
+$*
+EOT
+      }
+      gt_echo='echo_func'
+    fi
+  fi
+
+  # A sed script that extracts the value of VARIABLE from a Makefile.
+  tab=`printf '\t'`
+  sed_x_variable='
+# Test if the hold space is empty.
+x
+s/P/P/
+x
+ta
+# Yes it was empty. Look if we have the expected variable definition.
+/^['"${tab}"' ]*VARIABLE['"${tab}"' ]*=/{
+  # Seen the first line of the variable definition.
+  s/^['"${tab}"' ]*VARIABLE['"${tab}"' ]*=//
+  ba
+}
+bd
+:a
+# Here we are processing a line from the variable definition.
+# Remove comment, more precisely replace it with a space.
+s/#.*$/ /
+# See if the line ends in a backslash.
+tb
+:b
+s/\\$//
+# Print the line, without the trailing backslash.
+p
+tc
+# There was no trailing backslash. The end of the variable definition is
+# reached. Clear the hold space.
+s/^.*$//
+x
+bd
+:c
+# A trailing backslash means that the variable definition continues in the
+# next line. Put a nonempty string into the hold space to indicate this.
+s/^.*$/P/
+x
+:d
+'
+changequote([,])dnl
+
+  # Set POTFILES to the value of the Makefile variable POTFILES.
+  sed_x_POTFILES=`$gt_echo "$sed_x_variable" | sed -e '/^ *#/d' -e 's/VARIABLE/POTFILES/g'`
+  POTFILES=`sed -n -e "$sed_x_POTFILES" < "$ac_file"`
+  # Compute POTFILES_DEPS as
+  #   $(foreach file, $(POTFILES), $(top_srcdir)/$(file))
+  POTFILES_DEPS=
+  for file in $POTFILES; do
+    POTFILES_DEPS="$POTFILES_DEPS "'$(top_srcdir)/'"$file"
+  done
+  POMAKEFILEDEPS=""
+
+  if test -n "$OBSOLETE_ALL_LINGUAS"; then
+    test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete"
+  fi
+  if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then
+    # The LINGUAS file contains the set of available languages.
+    ALL_LINGUAS_=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"`
+    POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS"
+  else
+    # Set ALL_LINGUAS to the value of the Makefile variable LINGUAS.
+    sed_x_LINGUAS=`$gt_echo "$sed_x_variable" | sed -e '/^ *#/d' -e 's/VARIABLE/LINGUAS/g'`
+    ALL_LINGUAS_=`sed -n -e "$sed_x_LINGUAS" < "$ac_file"`
+  fi
+  # Hide the ALL_LINGUAS assignment from automake < 1.5.
+  eval 'ALL_LINGUAS''=$ALL_LINGUAS_'
+  # Compute POFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po)
+  # Compute UPDATEPOFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(lang).po-update)
+  # Compute DUMMYPOFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(lang).nop)
+  # Compute GMOFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo)
+  # Compute PROPERTIESFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(top_srcdir)/$(DOMAIN)_$(lang).properties)
+  # Compute CLASSFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(top_srcdir)/$(DOMAIN)_$(lang).class)
+  # Compute QMFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).qm)
+  # Compute MSGFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(frob $(lang)).msg)
+  # Compute RESOURCESDLLFILES
+  # as      $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(frob $(lang))/$(DOMAIN).resources.dll)
+  case "$ac_given_srcdir" in
+    .) srcdirpre= ;;
+    *) srcdirpre='$(srcdir)/' ;;
+  esac
+  POFILES=
+  UPDATEPOFILES=
+  DUMMYPOFILES=
+  GMOFILES=
+  PROPERTIESFILES=
+  CLASSFILES=
+  QMFILES=
+  MSGFILES=
+  RESOURCESDLLFILES=
+  for lang in $ALL_LINGUAS; do
+    POFILES="$POFILES $srcdirpre$lang.po"
+    UPDATEPOFILES="$UPDATEPOFILES $lang.po-update"
+    DUMMYPOFILES="$DUMMYPOFILES $lang.nop"
+    GMOFILES="$GMOFILES $srcdirpre$lang.gmo"
+    PROPERTIESFILES="$PROPERTIESFILES \$(top_srcdir)/\$(DOMAIN)_$lang.properties"
+    CLASSFILES="$CLASSFILES \$(top_srcdir)/\$(DOMAIN)_$lang.class"
+    QMFILES="$QMFILES $srcdirpre$lang.qm"
+    frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'`
+    MSGFILES="$MSGFILES $srcdirpre$frobbedlang.msg"
+    frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'`
+    RESOURCESDLLFILES="$RESOURCESDLLFILES $srcdirpre$frobbedlang/\$(DOMAIN).resources.dll"
+  done
+  # CATALOGS depends on both $ac_dir and the user's LINGUAS
+  # environment variable.
+  INST_LINGUAS=
+  if test -n "$ALL_LINGUAS"; then
+    for presentlang in $ALL_LINGUAS; do
+      useit=no
+      if test "%UNSET%" != "$LINGUAS"; then
+        desiredlanguages="$LINGUAS"
+      else
+        desiredlanguages="$ALL_LINGUAS"
+      fi
+      for desiredlang in $desiredlanguages; do
+        # Use the presentlang catalog if desiredlang is
+        #   a. equal to presentlang, or
+        #   b. a variant of presentlang (because in this case,
+        #      presentlang can be used as a fallback for messages
+        #      which are not translated in the desiredlang catalog).
+        case "$desiredlang" in
+          "$presentlang"*) useit=yes;;
+        esac
+      done
+      if test $useit = yes; then
+        INST_LINGUAS="$INST_LINGUAS $presentlang"
+      fi
+    done
+  fi
+  CATALOGS=
+  JAVACATALOGS=
+  QTCATALOGS=
+  TCLCATALOGS=
+  CSHARPCATALOGS=
+  if test -n "$INST_LINGUAS"; then
+    for lang in $INST_LINGUAS; do
+      CATALOGS="$CATALOGS $lang.gmo"
+      JAVACATALOGS="$JAVACATALOGS \$(DOMAIN)_$lang.properties"
+      QTCATALOGS="$QTCATALOGS $lang.qm"
+      frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'`
+      TCLCATALOGS="$TCLCATALOGS $frobbedlang.msg"
+      frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'`
+      CSHARPCATALOGS="$CSHARPCATALOGS $frobbedlang/\$(DOMAIN).resources.dll"
+    done
+  fi
+
+  sed -e "s|@POTFILES_DEPS@|$POTFILES_DEPS|g" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@PROPERTIESFILES@|$PROPERTIESFILES|g" -e "s|@CLASSFILES@|$CLASSFILES|g" -e "s|@QMFILES@|$QMFILES|g" -e "s|@MSGFILES@|$MSGFILES|g" -e "s|@RESOURCESDLLFILES@|$RESOURCESDLLFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@JAVACATALOGS@|$JAVACATALOGS|g" -e "s|@QTCATALOGS@|$QTCATALOGS|g" -e "s|@TCLCATALOGS@|$TCLCATALOGS|g" -e "s|@CSHARPCATALOGS@|$CSHARPCATALOGS|g" -e 's,^#distdir:,distdir:,' < "$ac_file" > "$ac_file.tmp"
+  tab=`printf '\t'`
+  if grep -l '@TCLCATALOGS@' "$ac_file" > /dev/null; then
+    # Add dependencies that cannot be formulated as a simple suffix rule.
+    for lang in $ALL_LINGUAS; do
+      frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'`
+      cat >> "$ac_file.tmp" <<EOF
+$frobbedlang.msg: $lang.po
+${tab}@echo "\$(MSGFMT) -c --tcl -d \$(srcdir) -l $lang $srcdirpre$lang.po"; \
+${tab}\$(MSGFMT) -c --tcl -d "\$(srcdir)" -l $lang $srcdirpre$lang.po || { rm -f "\$(srcdir)/$frobbedlang.msg"; exit 1; }
+EOF
+    done
+  fi
+  if grep -l '@CSHARPCATALOGS@' "$ac_file" > /dev/null; then
+    # Add dependencies that cannot be formulated as a simple suffix rule.
+    for lang in $ALL_LINGUAS; do
+      frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'`
+      cat >> "$ac_file.tmp" <<EOF
+$frobbedlang/\$(DOMAIN).resources.dll: $lang.po
+${tab}@echo "\$(MSGFMT) -c --csharp -d \$(srcdir) -l $lang $srcdirpre$lang.po -r \$(DOMAIN)"; \
+${tab}\$(MSGFMT) -c --csharp -d "\$(srcdir)" -l $lang $srcdirpre$lang.po -r "\$(DOMAIN)" || { rm -f "\$(srcdir)/$frobbedlang.msg"; exit 1; }
+EOF
+    done
+  fi
+  if test -n "$POMAKEFILEDEPS"; then
+    cat >> "$ac_file.tmp" <<EOF
+Makefile: $POMAKEFILEDEPS
+EOF
+  fi
+  mv "$ac_file.tmp" "$ac_file"
+])
+
+dnl Initializes the accumulator used by AM_XGETTEXT_OPTION.
+AC_DEFUN([AM_XGETTEXT_OPTION_INIT],
+[
+  XGETTEXT_EXTRA_OPTIONS=
+])
+
+dnl Registers an option to be passed to xgettext in the po subdirectory.
+AC_DEFUN([AM_XGETTEXT_OPTION],
+[
+  AC_REQUIRE([AM_XGETTEXT_OPTION_INIT])
+  XGETTEXT_EXTRA_OPTIONS="$XGETTEXT_EXTRA_OPTIONS $1"
+])
Index: csvn-ui-0.1.5/m4/progtest.m4
===================================================================
--- csvn-ui-0.1.5/m4/progtest.m4	(nonexistent)
+++ csvn-ui-0.1.5/m4/progtest.m4	(revision 12)
@@ -0,0 +1,91 @@
+# progtest.m4 serial 7 (gettext-0.18.2)
+dnl Copyright (C) 1996-2003, 2005, 2008-2016 Free Software Foundation, Inc.
+dnl This file is free software; the Free Software Foundation
+dnl gives unlimited permission to copy and/or distribute it,
+dnl with or without modifications, as long as this notice is preserved.
+dnl
+dnl This file can be used in projects which are not available under
+dnl the GNU General Public License or the GNU Library General Public
+dnl License but which still want to provide support for the GNU gettext
+dnl functionality.
+dnl Please note that the actual code of the GNU gettext library is covered
+dnl by the GNU Library General Public License, and the rest of the GNU
+dnl gettext package is covered by the GNU General Public License.
+dnl They are *not* in the public domain.
+
+dnl Authors:
+dnl   Ulrich Drepper <drepper@cygnus.com>, 1996.
+
+AC_PREREQ([2.50])
+
+# Search path for a program which passes the given test.
+
+dnl AM_PATH_PROG_WITH_TEST(VARIABLE, PROG-TO-CHECK-FOR,
+dnl   TEST-PERFORMED-ON-FOUND_PROGRAM [, VALUE-IF-NOT-FOUND [, PATH]])
+AC_DEFUN([AM_PATH_PROG_WITH_TEST],
+[
+# Prepare PATH_SEPARATOR.
+# The user is always right.
+if test "${PATH_SEPARATOR+set}" != set; then
+  # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which
+  # contains only /bin. Note that ksh looks also at the FPATH variable,
+  # so we have to set that as well for the test.
+  PATH_SEPARATOR=:
+  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
+    && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
+           || PATH_SEPARATOR=';'
+       }
+fi
+
+# Find out how to test for executable files. Don't use a zero-byte file,
+# as systems may use methods other than mode bits to determine executability.
+cat >conf$$.file <<_ASEOF
+#! /bin/sh
+exit 0
+_ASEOF
+chmod +x conf$$.file
+if test -x conf$$.file >/dev/null 2>&1; then
+  ac_executable_p="test -x"
+else
+  ac_executable_p="test -f"
+fi
+rm -f conf$$.file
+
+# Extract the first word of "$2", so it can be a program name with args.
+set dummy $2; ac_word=[$]2
+AC_MSG_CHECKING([for $ac_word])
+AC_CACHE_VAL([ac_cv_path_$1],
+[case "[$]$1" in
+  [[\\/]]* | ?:[[\\/]]*)
+    ac_cv_path_$1="[$]$1" # Let the user override the test with a path.
+    ;;
+  *)
+    ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR
+    for ac_dir in ifelse([$5], , $PATH, [$5]); do
+      IFS="$ac_save_IFS"
+      test -z "$ac_dir" && ac_dir=.
+      for ac_exec_ext in '' $ac_executable_extensions; do
+        if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then
+          echo "$as_me: trying $ac_dir/$ac_word..." >&AS_MESSAGE_LOG_FD
+          if [$3]; then
+            ac_cv_path_$1="$ac_dir/$ac_word$ac_exec_ext"
+            break 2
+          fi
+        fi
+      done
+    done
+    IFS="$ac_save_IFS"
+dnl If no 4th arg is given, leave the cache variable unset,
+dnl so AC_PATH_PROGS will keep looking.
+ifelse([$4], , , [  test -z "[$]ac_cv_path_$1" && ac_cv_path_$1="$4"
+])dnl
+    ;;
+esac])dnl
+$1="$ac_cv_path_$1"
+if test ifelse([$4], , [-n "[$]$1"], ["[$]$1" != "$4"]); then
+  AC_MSG_RESULT([$][$1])
+else
+  AC_MSG_RESULT([no])
+fi
+AC_SUBST([$1])dnl
+])
Index: csvn-ui-0.1.5/m4
===================================================================
--- csvn-ui-0.1.5/m4	(nonexistent)
+++ csvn-ui-0.1.5/m4	(revision 12)

Property changes on: csvn-ui-0.1.5/m4
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5/nls.h
===================================================================
--- csvn-ui-0.1.5/nls.h	(nonexistent)
+++ csvn-ui-0.1.5/nls.h	(revision 12)
@@ -0,0 +1,32 @@
+
+#ifndef __SUPPORT_NLS__
+#define __SUPPORT_NLS__   1
+
+#if ENABLE_NLS == 1
+
+#ifndef _
+#  include <gettext.h>
+#  ifndef _
+#    define _(s)         gettext(s)
+#  endif
+#  ifdef gettext_noop
+#    define N_(s)        gettext_noop(s)
+#  else
+#    define N_(s)        (s)
+#  endif
+#  ifdef ngettext
+#    define Q_(s, p, n)  ngettext( s, p, n )
+#  else
+#    define Q_(s, p, n)  ((n==1) ? gettext(s) : gettext(p))
+#  endif
+#endif /* !_ */
+
+#else
+
+#  define _(s)           (s)
+#  define N_(s)          (s)
+#  define Q_(s, p, n)    ((n == 1) ? (s) : (p))
+
+#endif
+
+#endif /* __SUPPORT_NLS__ */
Index: csvn-ui-0.1.5/po/ChangeLog
===================================================================
--- csvn-ui-0.1.5/po/ChangeLog	(nonexistent)
+++ csvn-ui-0.1.5/po/ChangeLog	(revision 12)
@@ -0,0 +1,12 @@
+2020-10-09  gettextize  <bug-gnu-gettext@gnu.org>
+
+	* Makefile.in.in: New file, from gettext-0.19.8.1.
+	* Rules-quot: New file, from gettext-0.19.8.1.
+	* boldquot.sed: New file, from gettext-0.19.8.1.
+	* en@boldquot.header: New file, from gettext-0.19.8.1.
+	* en@quot.header: New file, from gettext-0.19.8.1.
+	* insert-header.sin: New file, from gettext-0.19.8.1.
+	* quot.sed: New file, from gettext-0.19.8.1.
+	* remove-potcdate.sin: New file, from gettext-0.19.8.1.
+	* POTFILES.in: New file.
+
Index: csvn-ui-0.1.5/po/LINGUAS
===================================================================
--- csvn-ui-0.1.5/po/LINGUAS	(nonexistent)
+++ csvn-ui-0.1.5/po/LINGUAS	(revision 12)
@@ -0,0 +1,3 @@
+# Set of available languages.
+
+ru_RU.utf8
Index: csvn-ui-0.1.5/po/Makefile.in.in
===================================================================
--- csvn-ui-0.1.5/po/Makefile.in.in	(nonexistent)
+++ csvn-ui-0.1.5/po/Makefile.in.in	(revision 12)
@@ -0,0 +1,484 @@
+# Makefile for PO directory in any package using GNU gettext.
+# Copyright (C) 1995-1997, 2000-2007, 2009-2010 by Ulrich Drepper <drepper@gnu.ai.mit.edu>
+#
+# Copying and distribution of this file, with or without modification,
+# are permitted in any medium without royalty provided the copyright
+# notice and this notice are preserved.  This file is offered as-is,
+# without any warranty.
+#
+# Origin: gettext-0.19.8
+GETTEXT_MACRO_VERSION = 0.19
+
+PACKAGE = @PACKAGE@
+VERSION = @VERSION@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+
+SED = @SED@
+SHELL = /bin/sh
+@SET_MAKE@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+top_builddir = @top_builddir@
+VPATH = @srcdir@
+
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+datarootdir = @datarootdir@
+datadir = @datadir@
+localedir = @localedir@
+gettextsrcdir = $(datadir)/gettext/po
+
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+
+# We use $(mkdir_p).
+# In automake <= 1.9.x, $(mkdir_p) is defined either as "mkdir -p --" or as
+# "$(mkinstalldirs)" or as "$(install_sh) -d". For these automake versions,
+# @install_sh@ does not start with $(SHELL), so we add it.
+# In automake >= 1.10, @mkdir_p@ is derived from ${MKDIR_P}, which is defined
+# either as "/path/to/mkdir -p" or ".../install-sh -c -d". For these automake
+# versions, $(mkinstalldirs) and $(install_sh) are unused.
+mkinstalldirs = $(SHELL) @install_sh@ -d
+install_sh = $(SHELL) @install_sh@
+MKDIR_P = @MKDIR_P@
+mkdir_p = @mkdir_p@
+
+# When building gettext-tools, we prefer to use the built programs
+# rather than installed programs.  However, we can't do that when we
+# are cross compiling.
+CROSS_COMPILING = @CROSS_COMPILING@
+
+GMSGFMT_ = @GMSGFMT@
+GMSGFMT_no = @GMSGFMT@
+GMSGFMT_yes = @GMSGFMT_015@
+GMSGFMT = $(GMSGFMT_$(USE_MSGCTXT))
+MSGFMT_ = @MSGFMT@
+MSGFMT_no = @MSGFMT@
+MSGFMT_yes = @MSGFMT_015@
+MSGFMT = $(MSGFMT_$(USE_MSGCTXT))
+XGETTEXT_ = @XGETTEXT@
+XGETTEXT_no = @XGETTEXT@
+XGETTEXT_yes = @XGETTEXT_015@
+XGETTEXT = $(XGETTEXT_$(USE_MSGCTXT))
+MSGMERGE = msgmerge
+MSGMERGE_UPDATE = @MSGMERGE@ --update
+MSGINIT = msginit
+MSGCONV = msgconv
+MSGFILTER = msgfilter
+
+POFILES = @POFILES@
+GMOFILES = @GMOFILES@
+UPDATEPOFILES = @UPDATEPOFILES@
+DUMMYPOFILES = @DUMMYPOFILES@
+DISTFILES.common = Makefile.in.in remove-potcdate.sin \
+$(DISTFILES.common.extra1) $(DISTFILES.common.extra2) $(DISTFILES.common.extra3)
+DISTFILES = $(DISTFILES.common) Makevars POTFILES.in \
+$(POFILES) $(GMOFILES) \
+$(DISTFILES.extra1) $(DISTFILES.extra2) $(DISTFILES.extra3)
+
+POTFILES = \
+
+CATALOGS = @CATALOGS@
+
+POFILESDEPS_ = $(srcdir)/$(DOMAIN).pot
+POFILESDEPS_yes = $(POFILESDEPS_)
+POFILESDEPS_no =
+POFILESDEPS = $(POFILESDEPS_$(PO_DEPENDS_ON_POT))
+
+DISTFILESDEPS_ = update-po
+DISTFILESDEPS_yes = $(DISTFILESDEPS_)
+DISTFILESDEPS_no =
+DISTFILESDEPS = $(DISTFILESDEPS_$(DIST_DEPENDS_ON_UPDATE_PO))
+
+# Makevars gets inserted here. (Don't remove this line!)
+
+.SUFFIXES:
+.SUFFIXES: .po .gmo .mo .sed .sin .nop .po-create .po-update
+
+.po.mo:
+	@echo "$(MSGFMT) -c -o $@ $<"; \
+	$(MSGFMT) -c -o t-$@ $< && mv t-$@ $@
+
+.po.gmo:
+	@lang=`echo $* | sed -e 's,.*/,,'`; \
+	test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
+	echo "$${cdcmd}rm -f $${lang}.gmo && $(GMSGFMT) -c --statistics --verbose -o $${lang}.gmo $${lang}.po"; \
+	cd $(srcdir) && rm -f $${lang}.gmo && $(GMSGFMT) -c --statistics --verbose -o t-$${lang}.gmo $${lang}.po && mv t-$${lang}.gmo $${lang}.gmo
+
+.sin.sed:
+	sed -e '/^#/d' $< > t-$@
+	mv t-$@ $@
+
+
+all: all-@USE_NLS@
+
+all-yes: stamp-po
+all-no:
+
+# Ensure that the gettext macros and this Makefile.in.in are in sync.
+CHECK_MACRO_VERSION = \
+	test "$(GETTEXT_MACRO_VERSION)" = "@GETTEXT_MACRO_VERSION@" \
+	  || { echo "*** error: gettext infrastructure mismatch: using a Makefile.in.in from gettext version $(GETTEXT_MACRO_VERSION) but the autoconf macros are from gettext version @GETTEXT_MACRO_VERSION@" 1>&2; \
+	       exit 1; \
+	     }
+
+# $(srcdir)/$(DOMAIN).pot is only created when needed. When xgettext finds no
+# internationalized messages, no $(srcdir)/$(DOMAIN).pot is created (because
+# we don't want to bother translators with empty POT files). We assume that
+# LINGUAS is empty in this case, i.e. $(POFILES) and $(GMOFILES) are empty.
+# In this case, stamp-po is a nop (i.e. a phony target).
+
+# stamp-po is a timestamp denoting the last time at which the CATALOGS have
+# been loosely updated. Its purpose is that when a developer or translator
+# checks out the package via CVS, and the $(DOMAIN).pot file is not in CVS,
+# "make" will update the $(DOMAIN).pot and the $(CATALOGS), but subsequent
+# invocations of "make" will do nothing. This timestamp would not be necessary
+# if updating the $(CATALOGS) would always touch them; however, the rule for
+# $(POFILES) has been designed to not touch files that don't need to be
+# changed.
+stamp-po: $(srcdir)/$(DOMAIN).pot
+	@$(CHECK_MACRO_VERSION)
+	test ! -f $(srcdir)/$(DOMAIN).pot || \
+	  test -z "$(GMOFILES)" || $(MAKE) $(GMOFILES)
+	@test ! -f $(srcdir)/$(DOMAIN).pot || { \
+	  echo "touch stamp-po" && \
+	  echo timestamp > stamp-poT && \
+	  mv stamp-poT stamp-po; \
+	}
+
+# Note: Target 'all' must not depend on target '$(DOMAIN).pot-update',
+# otherwise packages like GCC can not be built if only parts of the source
+# have been downloaded.
+
+# This target rebuilds $(DOMAIN).pot; it is an expensive operation.
+# Note that $(DOMAIN).pot is not touched if it doesn't need to be changed.
+# The determination of whether the package xyz is a GNU one is based on the
+# heuristic whether some file in the top level directory mentions "GNU xyz".
+# If GNU 'find' is available, we avoid grepping through monster files.
+$(DOMAIN).pot-update: $(POTFILES) $(srcdir)/POTFILES.in remove-potcdate.sed
+	package_gnu="$(PACKAGE_GNU)"; \
+	test -n "$$package_gnu" || { \
+	  if { if (LC_ALL=C find --version) 2>/dev/null | grep GNU >/dev/null; then \
+		 LC_ALL=C find -L $(top_srcdir) -maxdepth 1 -type f \
+			       -size -10000000c -exec grep 'GNU @PACKAGE@' \
+			       /dev/null '{}' ';' 2>/dev/null; \
+	       else \
+		 LC_ALL=C grep 'GNU @PACKAGE@' $(top_srcdir)/* 2>/dev/null; \
+	       fi; \
+	     } | grep -v 'libtool:' >/dev/null; then \
+	     package_gnu=yes; \
+	   else \
+	     package_gnu=no; \
+	   fi; \
+	}; \
+	if test "$$package_gnu" = "yes"; then \
+	  package_prefix='GNU '; \
+	else \
+	  package_prefix=''; \
+	fi; \
+	if test -n '$(MSGID_BUGS_ADDRESS)' || test '$(PACKAGE_BUGREPORT)' = '@'PACKAGE_BUGREPORT'@'; then \
+	  msgid_bugs_address='$(MSGID_BUGS_ADDRESS)'; \
+	else \
+	  msgid_bugs_address='$(PACKAGE_BUGREPORT)'; \
+	fi; \
+	case `$(XGETTEXT) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \
+	  '' | 0.[0-9] | 0.[0-9].* | 0.1[0-5] | 0.1[0-5].* | 0.16 | 0.16.[0-1]*) \
+	    $(XGETTEXT) --default-domain=$(DOMAIN) --directory=$(top_srcdir) \
+	      --add-comments=TRANSLATORS: $(XGETTEXT_OPTIONS) @XGETTEXT_EXTRA_OPTIONS@ \
+	      --files-from=$(srcdir)/POTFILES.in \
+	      --copyright-holder='$(COPYRIGHT_HOLDER)' \
+	      --msgid-bugs-address="$$msgid_bugs_address" \
+	    ;; \
+	  *) \
+	    $(XGETTEXT) --default-domain=$(DOMAIN) --directory=$(top_srcdir) \
+	      --add-comments=TRANSLATORS: $(XGETTEXT_OPTIONS) @XGETTEXT_EXTRA_OPTIONS@ \
+	      --files-from=$(srcdir)/POTFILES.in \
+	      --copyright-holder='$(COPYRIGHT_HOLDER)' \
+	      --package-name="$${package_prefix}@PACKAGE@" \
+	      --package-version='@VERSION@' \
+	      --msgid-bugs-address="$$msgid_bugs_address" \
+	    ;; \
+	esac
+	test ! -f $(DOMAIN).po || { \
+	  if test -f $(srcdir)/$(DOMAIN).pot-header; then \
+	    sed -e '1,/^#$$/d' < $(DOMAIN).po > $(DOMAIN).1po && \
+	    cat $(srcdir)/$(DOMAIN).pot-header $(DOMAIN).1po > $(DOMAIN).po; \
+	    rm -f $(DOMAIN).1po; \
+	  fi; \
+	  if test -f $(srcdir)/$(DOMAIN).pot; then \
+	    sed -f remove-potcdate.sed < $(srcdir)/$(DOMAIN).pot > $(DOMAIN).1po && \
+	    sed -f remove-potcdate.sed < $(DOMAIN).po > $(DOMAIN).2po && \
+	    if cmp $(DOMAIN).1po $(DOMAIN).2po >/dev/null 2>&1; then \
+	      rm -f $(DOMAIN).1po $(DOMAIN).2po $(DOMAIN).po; \
+	    else \
+	      rm -f $(DOMAIN).1po $(DOMAIN).2po $(srcdir)/$(DOMAIN).pot && \
+	      mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \
+	    fi; \
+	  else \
+	    mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \
+	  fi; \
+	}
+
+# This rule has no dependencies: we don't need to update $(DOMAIN).pot at
+# every "make" invocation, only create it when it is missing.
+# Only "make $(DOMAIN).pot-update" or "make dist" will force an update.
+$(srcdir)/$(DOMAIN).pot:
+	$(MAKE) $(DOMAIN).pot-update
+
+# This target rebuilds a PO file if $(DOMAIN).pot has changed.
+# Note that a PO file is not touched if it doesn't need to be changed.
+$(POFILES): $(POFILESDEPS)
+	@lang=`echo $@ | sed -e 's,.*/,,' -e 's/\.po$$//'`; \
+	if test -f "$(srcdir)/$${lang}.po"; then \
+	  test -f $(srcdir)/$(DOMAIN).pot || $(MAKE) $(srcdir)/$(DOMAIN).pot; \
+	  test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
+	  echo "$${cdcmd}$(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) --lang=$${lang} $${lang}.po $(DOMAIN).pot"; \
+	  cd $(srcdir) \
+	    && { case `$(MSGMERGE) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \
+	           '' | 0.[0-9] | 0.[0-9].* | 0.1[0-7] | 0.1[0-7].*) \
+	             $(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) $${lang}.po $(DOMAIN).pot;; \
+	           *) \
+	             $(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) --lang=$${lang} $${lang}.po $(DOMAIN).pot;; \
+	         esac; \
+	       }; \
+	else \
+	  $(MAKE) $${lang}.po-create; \
+	fi
+
+
+install: install-exec install-data
+install-exec:
+install-data: install-data-@USE_NLS@
+	if test "$(PACKAGE)" = "gettext-tools"; then \
+	  $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
+	  for file in $(DISTFILES.common) Makevars.template; do \
+	    $(INSTALL_DATA) $(srcdir)/$$file \
+			    $(DESTDIR)$(gettextsrcdir)/$$file; \
+	  done; \
+	  for file in Makevars; do \
+	    rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
+	  done; \
+	else \
+	  : ; \
+	fi
+install-data-no: all
+install-data-yes: all
+	@catalogs='$(CATALOGS)'; \
+	for cat in $$catalogs; do \
+	  cat=`basename $$cat`; \
+	  lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
+	  dir=$(localedir)/$$lang/LC_MESSAGES; \
+	  $(mkdir_p) $(DESTDIR)$$dir; \
+	  if test -r $$cat; then realcat=$$cat; else realcat=$(srcdir)/$$cat; fi; \
+	  $(INSTALL_DATA) $$realcat $(DESTDIR)$$dir/$(DOMAIN).mo; \
+	  echo "installing $$realcat as $(DESTDIR)$$dir/$(DOMAIN).mo"; \
+	  for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \
+	    if test -n "$$lc"; then \
+	      if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \
+	        link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \
+	        mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
+	        mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	        (cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \
+	         for file in *; do \
+	           if test -f $$file; then \
+	             ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \
+	           fi; \
+	         done); \
+	        rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
+	      else \
+	        if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \
+	          :; \
+	        else \
+	          rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	          mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	        fi; \
+	      fi; \
+	      rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
+	      ln -s ../LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \
+	      ln $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \
+	      cp -p $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
+	      echo "installing $$realcat link as $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo"; \
+	    fi; \
+	  done; \
+	done
+
+install-strip: install
+
+installdirs: installdirs-exec installdirs-data
+installdirs-exec:
+installdirs-data: installdirs-data-@USE_NLS@
+	if test "$(PACKAGE)" = "gettext-tools"; then \
+	  $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
+	else \
+	  : ; \
+	fi
+installdirs-data-no:
+installdirs-data-yes:
+	@catalogs='$(CATALOGS)'; \
+	for cat in $$catalogs; do \
+	  cat=`basename $$cat`; \
+	  lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
+	  dir=$(localedir)/$$lang/LC_MESSAGES; \
+	  $(mkdir_p) $(DESTDIR)$$dir; \
+	  for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \
+	    if test -n "$$lc"; then \
+	      if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \
+	        link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \
+	        mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
+	        mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	        (cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \
+	         for file in *; do \
+	           if test -f $$file; then \
+	             ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \
+	           fi; \
+	         done); \
+	        rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \
+	      else \
+	        if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \
+	          :; \
+	        else \
+	          rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	          mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \
+	        fi; \
+	      fi; \
+	    fi; \
+	  done; \
+	done
+
+# Define this as empty until I found a useful application.
+installcheck:
+
+uninstall: uninstall-exec uninstall-data
+uninstall-exec:
+uninstall-data: uninstall-data-@USE_NLS@
+	if test "$(PACKAGE)" = "gettext-tools"; then \
+	  for file in $(DISTFILES.common) Makevars.template; do \
+	    rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
+	  done; \
+	else \
+	  : ; \
+	fi
+uninstall-data-no:
+uninstall-data-yes:
+	catalogs='$(CATALOGS)'; \
+	for cat in $$catalogs; do \
+	  cat=`basename $$cat`; \
+	  lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \
+	  for lc in LC_MESSAGES $(EXTRA_LOCALE_CATEGORIES); do \
+	    rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \
+	  done; \
+	done
+
+check: all
+
+info dvi ps pdf html tags TAGS ctags CTAGS ID:
+
+mostlyclean:
+	rm -f remove-potcdate.sed
+	rm -f stamp-poT
+	rm -f core core.* $(DOMAIN).po $(DOMAIN).1po $(DOMAIN).2po *.new.po
+	rm -fr *.o
+
+clean: mostlyclean
+
+distclean: clean
+	rm -f Makefile Makefile.in POTFILES *.mo
+
+maintainer-clean: distclean
+	@echo "This command is intended for maintainers to use;"
+	@echo "it deletes files that may require special tools to rebuild."
+	rm -f stamp-po $(GMOFILES)
+
+distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir)
+dist distdir:
+	test -z "$(DISTFILESDEPS)" || $(MAKE) $(DISTFILESDEPS)
+	@$(MAKE) dist2
+# This is a separate target because 'update-po' must be executed before.
+dist2: stamp-po $(DISTFILES)
+	dists="$(DISTFILES)"; \
+	if test "$(PACKAGE)" = "gettext-tools"; then \
+	  dists="$$dists Makevars.template"; \
+	fi; \
+	if test -f $(srcdir)/$(DOMAIN).pot; then \
+	  dists="$$dists $(DOMAIN).pot stamp-po"; \
+	fi; \
+	if test -f $(srcdir)/ChangeLog; then \
+	  dists="$$dists ChangeLog"; \
+	fi; \
+	for i in 0 1 2 3 4 5 6 7 8 9; do \
+	  if test -f $(srcdir)/ChangeLog.$$i; then \
+	    dists="$$dists ChangeLog.$$i"; \
+	  fi; \
+	done; \
+	if test -f $(srcdir)/LINGUAS; then dists="$$dists LINGUAS"; fi; \
+	for file in $$dists; do \
+	  if test -f $$file; then \
+	    cp -p $$file $(distdir) || exit 1; \
+	  else \
+	    cp -p $(srcdir)/$$file $(distdir) || exit 1; \
+	  fi; \
+	done
+
+update-po: Makefile
+	$(MAKE) $(DOMAIN).pot-update
+	test -z "$(UPDATEPOFILES)" || $(MAKE) $(UPDATEPOFILES)
+	$(MAKE) update-gmo
+
+# General rule for creating PO files.
+
+.nop.po-create:
+	@lang=`echo $@ | sed -e 's/\.po-create$$//'`; \
+	echo "File $$lang.po does not exist. If you are a translator, you can create it through 'msginit'." 1>&2; \
+	exit 1
+
+# General rule for updating PO files.
+
+.nop.po-update:
+	@lang=`echo $@ | sed -e 's/\.po-update$$//'`; \
+	if test "$(PACKAGE)" = "gettext-tools" && test "$(CROSS_COMPILING)" != "yes"; then PATH=`pwd`/../src:$$PATH; fi; \
+	tmpdir=`pwd`; \
+	echo "$$lang:"; \
+	test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \
+	echo "$${cdcmd}$(MSGMERGE) $(MSGMERGE_OPTIONS) --lang=$$lang $$lang.po $(DOMAIN).pot -o $$lang.new.po"; \
+	cd $(srcdir); \
+	if { case `$(MSGMERGE) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \
+	       '' | 0.[0-9] | 0.[0-9].* | 0.1[0-7] | 0.1[0-7].*) \
+	         $(MSGMERGE) $(MSGMERGE_OPTIONS) -o $$tmpdir/$$lang.new.po $$lang.po $(DOMAIN).pot;; \
+	       *) \
+	         $(MSGMERGE) $(MSGMERGE_OPTIONS) --lang=$$lang -o $$tmpdir/$$lang.new.po $$lang.po $(DOMAIN).pot;; \
+	     esac; \
+	   }; then \
+	  if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \
+	    rm -f $$tmpdir/$$lang.new.po; \
+	  else \
+	    if mv -f $$tmpdir/$$lang.new.po $$lang.po; then \
+	      :; \
+	    else \
+	      echo "msgmerge for $$lang.po failed: cannot move $$tmpdir/$$lang.new.po to $$lang.po" 1>&2; \
+	      exit 1; \
+	    fi; \
+	  fi; \
+	else \
+	  echo "msgmerge for $$lang.po failed!" 1>&2; \
+	  rm -f $$tmpdir/$$lang.new.po; \
+	fi
+
+$(DUMMYPOFILES):
+
+update-gmo: Makefile $(GMOFILES)
+	@:
+
+# Recreate Makefile by invoking config.status. Explicitly invoke the shell,
+# because execution permission bits may not work on the current file system.
+# Use @SHELL@, which is the shell determined by autoconf for the use by its
+# scripts, not $(SHELL) which is hardwired to /bin/sh and may be deficient.
+Makefile: Makefile.in.in Makevars $(top_builddir)/config.status @POMAKEFILEDEPS@
+	cd $(top_builddir) \
+	  && @SHELL@ ./config.status $(subdir)/$@.in po-directories
+
+force:
+
+# Tell versions [3.59,3.63) of GNU make not to export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
Index: csvn-ui-0.1.5/po/Makevars
===================================================================
--- csvn-ui-0.1.5/po/Makevars	(nonexistent)
+++ csvn-ui-0.1.5/po/Makevars	(revision 12)
@@ -0,0 +1,79 @@
+# Makefile variables for PO directory in any package using GNU gettext.
+
+# Usually the message domain is the same as the package name.
+DOMAIN = $(PACKAGE)
+
+# These two variables depend on the location of this directory.
+subdir = po
+top_builddir = ..
+
+# These options get passed to xgettext.
+XGETTEXT_OPTIONS = --keyword=N_ --keyword=_ --keyword=Q_:1,2 \
+                   --language=C --add-comments --sort-output --no-wrap
+
+# This is the copyright holder that gets inserted into the header of the
+# $(DOMAIN).pot file.  Set this to the copyright holder of the surrounding
+# package.  (Note that the msgstr strings, extracted from the package's
+# sources, belong to the copyright holder of the package.)  Translators are
+# expected to transfer the copyright for their translations to this person
+# or entity, or to disclaim their copyright.  The empty string stands for
+# the public domain; in this case the translators are expected to disclaim
+# their copyright.
+COPYRIGHT_HOLDER = Andrey V.Kosteltsev.
+
+# This tells whether or not to prepend "GNU " prefix to the package
+# name that gets inserted into the header of the $(DOMAIN).pot file.
+# Possible values are "yes", "no", or empty.  If it is empty, try to
+# detect it automatically by scanning the files in $(top_srcdir) for
+# "GNU packagename" string.
+PACKAGE_GNU = no
+
+# This is the email address or URL to which the translators shall report
+# bugs in the untranslated strings:
+# - Strings which are not entire sentences, see the maintainer guidelines
+#   in the GNU gettext documentation, section 'Preparing Strings'.
+# - Strings which use unclear terms or require additional context to be
+#   understood.
+# - Strings which make invalid assumptions about notation of date, time or
+#   money.
+# - Pluralisation problems.
+# - Incorrect English spelling.
+# - Incorrect formatting.
+# It can be your email address, or a mailing list address where translators
+# can write to without being subscribed, or the URL of a web page through
+# which the translators can contact you.
+MSGID_BUGS_ADDRESS = <support@radix.pro>
+
+# This is the list of locale categories, beyond LC_MESSAGES, for which the
+# message catalogs shall be used.  It is usually empty.
+EXTRA_LOCALE_CATEGORIES =
+
+# This tells whether the $(DOMAIN).pot file contains messages with an 'msgctxt'
+# context.  Possible values are "yes" and "no".  Set this to yes if the
+# package uses functions taking also a message context, like pgettext(), or
+# if in $(XGETTEXT_OPTIONS) you define keywords with a context argument.
+USE_MSGCTXT = no
+
+# These options get passed to msgmerge.
+# Useful options are in particular:
+#   --previous            to keep previous msgids of translated messages,
+#   --quiet               to reduce the verbosity.
+MSGMERGE_OPTIONS = --update --no-wrap --sort-output --backup=simple
+
+# These options get passed to msginit.
+# If you want to disable line wrapping when writing PO files, add
+# --no-wrap to MSGMERGE_OPTIONS, XGETTEXT_OPTIONS, and
+# MSGINIT_OPTIONS.
+MSGINIT_OPTIONS = --no-wrap
+
+# This tells whether or not to regenerate a PO file when $(DOMAIN).pot
+# has changed.  Possible values are "yes" and "no".  Set this to no if
+# the POT file is checked in the repository and the version control
+# program ignores timestamps.
+PO_DEPENDS_ON_POT = yes
+
+# This tells whether or not to forcibly update $(DOMAIN).pot and
+# regenerate PO files on "make dist".  Possible values are "yes" and
+# "no".  Set this to no if the POT file and PO files are maintained
+# externally.
+DIST_DEPENDS_ON_UPDATE_PO = yes
Index: csvn-ui-0.1.5/po/POTFILES.in
===================================================================
--- csvn-ui-0.1.5/po/POTFILES.in	(nonexistent)
+++ csvn-ui-0.1.5/po/POTFILES.in	(revision 12)
@@ -0,0 +1,7 @@
+# List of source files which contain translatable strings.
+
+# cSvn-ui CGI source files
+csvncgi/ctx.c
+csvncgi/date.c
+csvncgi/strbuf.c
+csvncgi/ui-shared.c
Index: csvn-ui-0.1.5/po/Rules-quot
===================================================================
--- csvn-ui-0.1.5/po/Rules-quot	(nonexistent)
+++ csvn-ui-0.1.5/po/Rules-quot	(revision 12)
@@ -0,0 +1,58 @@
+# This file, Rules-quot, can be copied and used freely without restrictions.
+# Special Makefile rules for English message catalogs with quotation marks.
+
+DISTFILES.common.extra1 = quot.sed boldquot.sed en@quot.header en@boldquot.header insert-header.sin Rules-quot
+
+.SUFFIXES: .insert-header .po-update-en
+
+en@quot.po-create:
+	$(MAKE) en@quot.po-update
+en@boldquot.po-create:
+	$(MAKE) en@boldquot.po-update
+
+en@quot.po-update: en@quot.po-update-en
+en@boldquot.po-update: en@boldquot.po-update-en
+
+.insert-header.po-update-en:
+	@lang=`echo $@ | sed -e 's/\.po-update-en$$//'`; \
+	if test "$(PACKAGE)" = "gettext-tools" && test "$(CROSS_COMPILING)" != "yes"; then PATH=`pwd`/../src:$$PATH; GETTEXTLIBDIR=`cd $(top_srcdir)/src && pwd`; export GETTEXTLIBDIR; fi; \
+	tmpdir=`pwd`; \
+	echo "$$lang:"; \
+	ll=`echo $$lang | sed -e 's/@.*//'`; \
+	LC_ALL=C; export LC_ALL; \
+	cd $(srcdir); \
+	if $(MSGINIT) $(MSGINIT_OPTIONS) -i $(DOMAIN).pot --no-translator -l $$lang -o - 2>/dev/null \
+	   | $(SED) -f $$tmpdir/$$lang.insert-header | $(MSGCONV) -t UTF-8 | \
+	   { case `$(MSGFILTER) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \
+	     '' | 0.[0-9] | 0.[0-9].* | 0.1[0-8] | 0.1[0-8].*) \
+	       $(MSGFILTER) $(SED) -f `echo $$lang | sed -e 's/.*@//'`.sed \
+	       ;; \
+	     *) \
+	       $(MSGFILTER) `echo $$lang | sed -e 's/.*@//'` \
+	       ;; \
+	     esac } 2>/dev/null > $$tmpdir/$$lang.new.po \
+	     ; then \
+	  if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \
+	    rm -f $$tmpdir/$$lang.new.po; \
+	  else \
+	    if mv -f $$tmpdir/$$lang.new.po $$lang.po; then \
+	      :; \
+	    else \
+	      echo "creation of $$lang.po failed: cannot move $$tmpdir/$$lang.new.po to $$lang.po" 1>&2; \
+	      exit 1; \
+	    fi; \
+	  fi; \
+	else \
+	  echo "creation of $$lang.po failed!" 1>&2; \
+	  rm -f $$tmpdir/$$lang.new.po; \
+	fi
+
+en@quot.insert-header: insert-header.sin
+	sed -e '/^#/d' -e 's/HEADER/en@quot.header/g' $(srcdir)/insert-header.sin > en@quot.insert-header
+
+en@boldquot.insert-header: insert-header.sin
+	sed -e '/^#/d' -e 's/HEADER/en@boldquot.header/g' $(srcdir)/insert-header.sin > en@boldquot.insert-header
+
+mostlyclean: mostlyclean-quot
+mostlyclean-quot:
+	rm -f *.insert-header
Index: csvn-ui-0.1.5/po/boldquot.sed
===================================================================
--- csvn-ui-0.1.5/po/boldquot.sed	(nonexistent)
+++ csvn-ui-0.1.5/po/boldquot.sed	(revision 12)
@@ -0,0 +1,10 @@
+s/"\([^"]*\)"/“\1”/g
+s/`\([^`']*\)'/‘\1’/g
+s/ '\([^`']*\)' / ‘\1’ /g
+s/ '\([^`']*\)'$/ ‘\1’/g
+s/^'\([^`']*\)' /‘\1’ /g
+s/“”/""/g
+s/“/“/g
+s/”/”/g
+s/‘/‘/g
+s/’/’/g
Index: csvn-ui-0.1.5/po/csvn-ui.pot
===================================================================
--- csvn-ui-0.1.5/po/csvn-ui.pot	(nonexistent)
+++ csvn-ui-0.1.5/po/csvn-ui.pot	(revision 12)
@@ -0,0 +1,203 @@
+# SOME DESCRIPTIVE TITLE.
+# Copyright (C) YEAR Andrey V.Kosteltsev.
+# This file is distributed under the same license as the csvn-ui package.
+# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: csvn-ui 0.1.5\n"
+"Report-Msgid-Bugs-To: <support@radix.pro>\n"
+"POT-Creation-Date: 2020-12-10 04:30+0300\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"Language: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=CHARSET\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: nplurals=INTEGER; plural=EXPRESSION;\n"
+
+#: csvncgi/ui-shared.c:162
+#, c-format
+msgid "%<PRIdMAX> day"
+msgid_plural "%<PRIdMAX> days"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:331
+#, c-format
+msgid "%<PRIdMAX> day ago"
+msgid_plural "%<PRIdMAX> days ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ui-shared.c:155
+#, c-format
+msgid "%<PRIdMAX> hour"
+msgid_plural "%<PRIdMAX> hours"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:324
+#, c-format
+msgid "%<PRIdMAX> hour ago"
+msgid_plural "%<PRIdMAX> hours ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ui-shared.c:148
+#, c-format
+msgid "%<PRIdMAX> minute"
+msgid_plural "%<PRIdMAX> minutes"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:317
+#, c-format
+msgid "%<PRIdMAX> minute ago"
+msgid_plural "%<PRIdMAX> minutes ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ui-shared.c:176
+#, c-format
+msgid "%<PRIdMAX> month"
+msgid_plural "%<PRIdMAX> months"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:343
+#, c-format
+msgid "%<PRIdMAX> month ago"
+msgid_plural "%<PRIdMAX> months ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:310
+#, c-format
+msgid "%<PRIdMAX> second ago"
+msgid_plural "%<PRIdMAX> seconds ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ui-shared.c:169
+#, c-format
+msgid "%<PRIdMAX> week"
+msgid_plural "%<PRIdMAX> weeks"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:337
+#, c-format
+msgid "%<PRIdMAX> week ago"
+msgid_plural "%<PRIdMAX> weeks ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/date.c:355 csvncgi/ui-shared.c:182
+#, c-format
+msgid "%<PRIdMAX> year"
+msgid_plural "%<PRIdMAX> years"
+msgstr[0] ""
+msgstr[1] ""
+
+#. Otherwise, just years. Centuries is probably overkill.
+#: csvncgi/date.c:362 csvncgi/date.c:366
+#, c-format
+msgid "%<PRIdMAX> year ago"
+msgid_plural "%<PRIdMAX> years ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ctx.c:994
+#, c-format
+msgid "%d Branch"
+msgid_plural "%d Branches"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ctx.c:993
+#, c-format
+msgid "%d Commit"
+msgid_plural "%d Commits"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ctx.c:965
+#, c-format
+msgid "%d Subversion Repository"
+msgid_plural "%d Subversion Repositories"
+msgstr[0] ""
+msgstr[1] ""
+
+#: csvncgi/ctx.c:995
+#, c-format
+msgid "%d Tag"
+msgid_plural "%d Tags"
+msgstr[0] ""
+msgstr[1] ""
+
+#. TRANSLATORS: "%s" is "<n> months"
+#: csvncgi/date.c:358
+#, c-format
+msgid "%s, %<PRIdMAX> month ago"
+msgid_plural "%s, %<PRIdMAX> months ago"
+msgstr[0] ""
+msgstr[1] ""
+
+#. TRANSLATORS: IEC 80000-13:2008 byte
+#: csvncgi/strbuf.c:638
+#, c-format
+msgid "%u byte"
+msgid_plural "%u bytes"
+msgstr[0] ""
+msgstr[1] ""
+
+#. TRANSLATORS: IEC 80000-13:2008 byte/second
+#: csvncgi/strbuf.c:640
+#, c-format
+msgid "%u byte/s"
+msgid_plural "%u bytes/s"
+msgstr[0] ""
+msgstr[1] ""
+
+#. TRANSLATORS: IEC 80000-13:2008 gibibyte
+#: csvncgi/strbuf.c:605
+#, c-format
+msgid "%u.%2.2u GiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 gibibyte/second
+#: csvncgi/strbuf.c:607
+#, c-format
+msgid "%u.%2.2u GiB/s"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 kibibyte
+#: csvncgi/strbuf.c:628
+#, c-format
+msgid "%u.%2.2u KiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 kibibyte/second
+#: csvncgi/strbuf.c:630
+#, c-format
+msgid "%u.%2.2u KiB/s"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 mebibyte
+#: csvncgi/strbuf.c:617
+#, c-format
+msgid "%u.%2.2u MiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 mebibyte/second
+#: csvncgi/strbuf.c:619
+#, c-format
+msgid "%u.%2.2u MiB/s"
+msgstr ""
+
+#: csvncgi/date.c:304
+msgid "in the future"
+msgstr ""
Index: csvn-ui-0.1.5/po/en@boldquot.header
===================================================================
--- csvn-ui-0.1.5/po/en@boldquot.header	(nonexistent)
+++ csvn-ui-0.1.5/po/en@boldquot.header	(revision 12)
@@ -0,0 +1,25 @@
+# All this catalog "translates" are quotation characters.
+# The msgids must be ASCII and therefore cannot contain real quotation
+# characters, only substitutes like grave accent (0x60), apostrophe (0x27)
+# and double quote (0x22). These substitutes look strange; see
+# http://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
+#
+# This catalog translates grave accent (0x60) and apostrophe (0x27) to
+# left single quotation mark (U+2018) and right single quotation mark (U+2019).
+# It also translates pairs of apostrophe (0x27) to
+# left single quotation mark (U+2018) and right single quotation mark (U+2019)
+# and pairs of quotation mark (0x22) to
+# left double quotation mark (U+201C) and right double quotation mark (U+201D).
+#
+# When output to an UTF-8 terminal, the quotation characters appear perfectly.
+# When output to an ISO-8859-1 terminal, the single quotation marks are
+# transliterated to apostrophes (by iconv in glibc 2.2 or newer) or to
+# grave/acute accent (by libiconv), and the double quotation marks are
+# transliterated to 0x22.
+# When output to an ASCII terminal, the single quotation marks are
+# transliterated to apostrophes, and the double quotation marks are
+# transliterated to 0x22.
+#
+# This catalog furthermore displays the text between the quotation marks in
+# bold face, assuming the VT100/XTerm escape sequences.
+#
Index: csvn-ui-0.1.5/po/en@quot.header
===================================================================
--- csvn-ui-0.1.5/po/en@quot.header	(nonexistent)
+++ csvn-ui-0.1.5/po/en@quot.header	(revision 12)
@@ -0,0 +1,22 @@
+# All this catalog "translates" are quotation characters.
+# The msgids must be ASCII and therefore cannot contain real quotation
+# characters, only substitutes like grave accent (0x60), apostrophe (0x27)
+# and double quote (0x22). These substitutes look strange; see
+# http://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html
+#
+# This catalog translates grave accent (0x60) and apostrophe (0x27) to
+# left single quotation mark (U+2018) and right single quotation mark (U+2019).
+# It also translates pairs of apostrophe (0x27) to
+# left single quotation mark (U+2018) and right single quotation mark (U+2019)
+# and pairs of quotation mark (0x22) to
+# left double quotation mark (U+201C) and right double quotation mark (U+201D).
+#
+# When output to an UTF-8 terminal, the quotation characters appear perfectly.
+# When output to an ISO-8859-1 terminal, the single quotation marks are
+# transliterated to apostrophes (by iconv in glibc 2.2 or newer) or to
+# grave/acute accent (by libiconv), and the double quotation marks are
+# transliterated to 0x22.
+# When output to an ASCII terminal, the single quotation marks are
+# transliterated to apostrophes, and the double quotation marks are
+# transliterated to 0x22.
+#
Index: csvn-ui-0.1.5/po/insert-header.sin
===================================================================
--- csvn-ui-0.1.5/po/insert-header.sin	(nonexistent)
+++ csvn-ui-0.1.5/po/insert-header.sin	(revision 12)
@@ -0,0 +1,23 @@
+# Sed script that inserts the file called HEADER before the header entry.
+#
+# At each occurrence of a line starting with "msgid ", we execute the following
+# commands. At the first occurrence, insert the file. At the following
+# occurrences, do nothing. The distinction between the first and the following
+# occurrences is achieved by looking at the hold space.
+/^msgid /{
+x
+# Test if the hold space is empty.
+s/m/m/
+ta
+# Yes it was empty. First occurrence. Read the file.
+r HEADER
+# Output the file's contents by reading the next line. But don't lose the
+# current line while doing this.
+g
+N
+bb
+:a
+# The hold space was nonempty. Following occurrences. Do nothing.
+x
+:b
+}
Index: csvn-ui-0.1.5/po/quot.sed
===================================================================
--- csvn-ui-0.1.5/po/quot.sed	(nonexistent)
+++ csvn-ui-0.1.5/po/quot.sed	(revision 12)
@@ -0,0 +1,6 @@
+s/"\([^"]*\)"/“\1”/g
+s/`\([^`']*\)'/‘\1’/g
+s/ '\([^`']*\)' / ‘\1’ /g
+s/ '\([^`']*\)'$/ ‘\1’/g
+s/^'\([^`']*\)' /‘\1’ /g
+s/“”/""/g
Index: csvn-ui-0.1.5/po/remove-potcdate.sin
===================================================================
--- csvn-ui-0.1.5/po/remove-potcdate.sin	(nonexistent)
+++ csvn-ui-0.1.5/po/remove-potcdate.sin	(revision 12)
@@ -0,0 +1,19 @@
+# Sed script that remove the POT-Creation-Date line in the header entry
+# from a POT file.
+#
+# The distinction between the first and the following occurrences of the
+# pattern is achieved by looking at the hold space.
+/^"POT-Creation-Date: .*"$/{
+x
+# Test if the hold space is empty.
+s/P/P/
+ta
+# Yes it was empty. First occurrence. Remove the line.
+g
+d
+bb
+:a
+# The hold space was nonempty. Following occurrences. Do nothing.
+x
+:b
+}
Index: csvn-ui-0.1.5/po/ru_RU.utf8.po
===================================================================
--- csvn-ui-0.1.5/po/ru_RU.utf8.po	(nonexistent)
+++ csvn-ui-0.1.5/po/ru_RU.utf8.po	(revision 12)
@@ -0,0 +1,223 @@
+# Russian translations for csvn-ui package
+# Английские переводы для пакета csvn-ui.
+# Copyright (C) 2020 Andrey V.Kosteltsev.
+# This file is distributed under the same license as the csvn-ui package.
+# Andrey V.Kosteltsev <kx@radix.pro>, 2020.
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: csvn-ui 0.1.5\n"
+"Report-Msgid-Bugs-To: <support@radix.pro>\n"
+"POT-Creation-Date: 2020-12-10 04:30+0300\n"
+"PO-Revision-Date: 2020-12-10 04:34+0300\n"
+"Last-Translator: Andrey V.Kosteltsev <kx@radix.pro>\n"
+"Language-Team: Russian\n"
+"Language: ru_RU.utf8\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2);\n"
+
+#: csvncgi/ui-shared.c:162
+#, c-format
+msgid "%<PRIdMAX> day"
+msgid_plural "%<PRIdMAX> days"
+msgstr[0] "%<PRIdMAX> день"
+msgstr[1] "%<PRIdMAX> дня"
+msgstr[2] "%<PRIdMAX> дней"
+
+#: csvncgi/date.c:331
+#, c-format
+msgid "%<PRIdMAX> day ago"
+msgid_plural "%<PRIdMAX> days ago"
+msgstr[0] "%<PRIdMAX> день назад"
+msgstr[1] "%<PRIdMAX> дня назад"
+msgstr[2] "%<PRIdMAX> дней назад"
+
+#: csvncgi/ui-shared.c:155
+#, c-format
+msgid "%<PRIdMAX> hour"
+msgid_plural "%<PRIdMAX> hours"
+msgstr[0] "%<PRIdMAX> час"
+msgstr[1] "%<PRIdMAX> часа"
+msgstr[2] "%<PRIdMAX> часов"
+
+#: csvncgi/date.c:324
+#, c-format
+msgid "%<PRIdMAX> hour ago"
+msgid_plural "%<PRIdMAX> hours ago"
+msgstr[0] "%<PRIdMAX> час назад"
+msgstr[1] "%<PRIdMAX> часа назад"
+msgstr[2] "%<PRIdMAX> часов назад"
+
+#: csvncgi/ui-shared.c:148
+#, c-format
+msgid "%<PRIdMAX> minute"
+msgid_plural "%<PRIdMAX> minutes"
+msgstr[0] "%<PRIdMAX> минута"
+msgstr[1] "%<PRIdMAX> минуты"
+msgstr[2] "%<PRIdMAX> минут"
+
+#: csvncgi/date.c:317
+#, c-format
+msgid "%<PRIdMAX> minute ago"
+msgid_plural "%<PRIdMAX> minutes ago"
+msgstr[0] "%<PRIdMAX> минута назад"
+msgstr[1] "%<PRIdMAX> минуты назад"
+msgstr[2] "%<PRIdMAX> минут назад"
+
+#: csvncgi/ui-shared.c:176
+#, c-format
+msgid "%<PRIdMAX> month"
+msgid_plural "%<PRIdMAX> months"
+msgstr[0] "%<PRIdMAX> месяц"
+msgstr[1] "%<PRIdMAX> месяца"
+msgstr[2] "%<PRIdMAX> месяцев"
+
+#: csvncgi/date.c:343
+#, c-format
+msgid "%<PRIdMAX> month ago"
+msgid_plural "%<PRIdMAX> months ago"
+msgstr[0] "%<PRIdMAX> месяц назад"
+msgstr[1] "%<PRIdMAX> месяца назад"
+msgstr[2] "%<PRIdMAX> месяцев назад"
+
+#: csvncgi/date.c:310
+#, c-format
+msgid "%<PRIdMAX> second ago"
+msgid_plural "%<PRIdMAX> seconds ago"
+msgstr[0] "%<PRIdMAX> секунда назад"
+msgstr[1] "%<PRIdMAX> секунды назад"
+msgstr[2] "%<PRIdMAX> секунд назад"
+
+#: csvncgi/ui-shared.c:169
+#, c-format
+msgid "%<PRIdMAX> week"
+msgid_plural "%<PRIdMAX> weeks"
+msgstr[0] "%<PRIdMAX> неделю"
+msgstr[1] "%<PRIdMAX> недели"
+msgstr[2] "%<PRIdMAX> недель"
+
+#: csvncgi/date.c:337
+#, c-format
+msgid "%<PRIdMAX> week ago"
+msgid_plural "%<PRIdMAX> weeks ago"
+msgstr[0] "%<PRIdMAX> неделю назад"
+msgstr[1] "%<PRIdMAX> недели назад"
+msgstr[2] "%<PRIdMAX> недель назад"
+
+#: csvncgi/date.c:355 csvncgi/ui-shared.c:182
+#, c-format
+msgid "%<PRIdMAX> year"
+msgid_plural "%<PRIdMAX> years"
+msgstr[0] "%<PRIdMAX> год"
+msgstr[1] "%<PRIdMAX> года"
+msgstr[2] "%<PRIdMAX> лет"
+
+#. Otherwise, just years. Centuries is probably overkill.
+#: csvncgi/date.c:362 csvncgi/date.c:366
+#, c-format
+msgid "%<PRIdMAX> year ago"
+msgid_plural "%<PRIdMAX> years ago"
+msgstr[0] "%<PRIdMAX> год назад"
+msgstr[1] "%<PRIdMAX> года назад"
+msgstr[2] "%<PRIdMAX> лет назад"
+
+#: csvncgi/ctx.c:994
+#, c-format
+msgid "%d Branch"
+msgid_plural "%d Branches"
+msgstr[0] "%d Ветка"
+msgstr[1] "%d Ветки"
+msgstr[2] "%d Веток"
+
+#: csvncgi/ctx.c:993
+#, c-format
+msgid "%d Commit"
+msgid_plural "%d Commits"
+msgstr[0] "%d Ревизия"
+msgstr[1] "%d Ревизии"
+msgstr[2] "%d Ревизий"
+
+#: csvncgi/ctx.c:965
+#, c-format
+msgid "%d Subversion Repository"
+msgid_plural "%d Subversion Repositories"
+msgstr[0] "%d Subversion Репозиторий"
+msgstr[1] "%d Subversion Репозитория"
+msgstr[2] "%d Subversion Репозиториев"
+
+#: csvncgi/ctx.c:995
+#, c-format
+msgid "%d Tag"
+msgid_plural "%d Tags"
+msgstr[0] "%d Тег"
+msgstr[1] "%d Тега"
+msgstr[2] "%d Тегов"
+
+#. TRANSLATORS: "%s" is "<n> months"
+#: csvncgi/date.c:358
+#, c-format
+msgid "%s, %<PRIdMAX> month ago"
+msgid_plural "%s, %<PRIdMAX> months ago"
+msgstr[0] "%s, %<PRIdMAX> месяц назад"
+msgstr[1] "%s, %<PRIdMAX> месяца назад"
+msgstr[2] "%s, %<PRIdMAX> месяцев назад"
+
+#. TRANSLATORS: IEC 80000-13:2008 byte
+#: csvncgi/strbuf.c:638
+#, c-format
+msgid "%u byte"
+msgid_plural "%u bytes"
+msgstr[0] "%u байт"
+msgstr[1] "%u байта"
+msgstr[2] "%u байтов"
+
+#. TRANSLATORS: IEC 80000-13:2008 byte/second
+#: csvncgi/strbuf.c:640
+#, c-format
+msgid "%u byte/s"
+msgid_plural "%u bytes/s"
+msgstr[0] "%u байт/с"
+msgstr[1] "%u байта/с"
+msgstr[2] "%u байтов/с"
+
+#. TRANSLATORS: IEC 80000-13:2008 gibibyte
+#: csvncgi/strbuf.c:605
+#, c-format
+msgid "%u.%2.2u GiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 gibibyte/second
+#: csvncgi/strbuf.c:607
+#, c-format
+msgid "%u.%2.2u GiB/s"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 kibibyte
+#: csvncgi/strbuf.c:628
+#, c-format
+msgid "%u.%2.2u KiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 kibibyte/second
+#: csvncgi/strbuf.c:630
+#, c-format
+msgid "%u.%2.2u KiB/s"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 mebibyte
+#: csvncgi/strbuf.c:617
+#, c-format
+msgid "%u.%2.2u MiB"
+msgstr ""
+
+#. TRANSLATORS: IEC 80000-13:2008 mebibyte/second
+#: csvncgi/strbuf.c:619
+#, c-format
+msgid "%u.%2.2u MiB/s"
+msgstr ""
+
+#: csvncgi/date.c:304
+msgid "in the future"
+msgstr ""
Index: csvn-ui-0.1.5/po
===================================================================
--- csvn-ui-0.1.5/po	(nonexistent)
+++ csvn-ui-0.1.5/po	(revision 12)

Property changes on: csvn-ui-0.1.5/po
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~
Index: csvn-ui-0.1.5
===================================================================
--- csvn-ui-0.1.5	(nonexistent)
+++ csvn-ui-0.1.5	(revision 12)

Property changes on: csvn-ui-0.1.5
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,36 ##
+
+autom4te.cache/
+
+Makefile
+Makefile.in
+config.h
+config.h.in
+config.log
+config.status
+compile
+config.guess
+config.sub
+configure
+install-sh
+missing
+stamp-h1
+aclocal.m4
+depcomp
+
+csvncgi/.deps/
+csvncgi/Makefile
+csvncgi/Makefile.in
+
+po/Makefile
+po/Makefile.in
+po/POTFILES
+po/remove-potcdate.sed
+po/stamp-po
+po/*.gmo
+po/*~
+
+m4/intlmacosx.m4
+m4/pkg.m4
+m4/*~
+
+*~