%\iffalse
%<*package>
%% \CharacterTable
%%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
%%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z
%%   Digits        \0\1\2\3\4\5\6\7\8\9
%%   Exclamation   \!     Double quote  \"     Hash (number) \#
%%   Dollar        \$     Percent       \%     Ampersand     \&
%%   Acute accent  \'     Left paren    \(     Right paren   \)
%%   Asterisk      \*     Plus          \+     Comma         \,
%%   Minus         \-     Point         \.     Solidus       \/
%%   Colon         \:     Semicolon     \;     Less than     \<
%%   Equals        \=     Greater than  \>     Question mark \?
%%   Commercial at \@     Left bracket  \[     Backslash     \\
%%   Right bracket \]     Circumflex    \^     Underscore    \_
%%   Grave accent  \`     Left brace    \{     Vertical bar  \|
%%   Right brace   \}     Tilde         \~}
%</package>
%\fi
% \iffalse
% Doc-Source file to use with LaTeX2e
% Copyright (C) 2015-2018 Nicola Talbot, all rights reserved.
% (New maintainer add relevant lines here.)
% \fi
% \iffalse
%<*driver>
\documentclass{ltxdoc}

\usepackage{alltt}
\usepackage{graphicx}
\usepackage{fontspec}
\usepackage[colorlinks,
            bookmarks,
            hyperindex=false,
            pdfauthor={Nicola L.C. Talbot},
            pdftitle={datetime2.sty Russian Module}]{hyperref}

\newfontfamily\cyrillicfont{Liberation Serif}
\setmonofont{Liberation Mono}

\CheckSum{401}

\renewcommand*{\usage}[1]{\hyperpage{#1}}
\renewcommand*{\main}[1]{\hyperpage{#1}}
\IndexPrologue{\section*{\indexname}\markboth{\indexname}{\indexname}}
\setcounter{IndexColumns}{2}

\newcommand*{\sty}[1]{\textsf{#1}}
\newcommand*{\opt}[1]{\texttt{#1}\index{#1=\texttt{#1}|main}}

\RecordChanges
\PageIndex
\CodelineNumbered

\begin{document}
\DocInput{datetime2-russian.dtx}
\end{document}
%</driver>
%\fi
%
%\MakeShortVerb{"}
%
%\title{Russian Module for datetime2 Package}
%\author{Nicola L. C. Talbot (inactive)}
%\date{2018-12-07 (v1.1)}
%\maketitle
%
%This module is currently unmaintained and may be subject to change.
%If you want to volunteer to take over maintanance, contact me at
%\url{http://www.dickimaw-books.com/contact.html}
%
%\begin{abstract}
%This is the Russian language module for the \sty{datetime2}
%package. If you want to use the settings in this module you must
%install it in addition to installing \sty{datetime2}. If you use
%\sty{babel} or \sty{polyglossia}, you will need this module to
%prevent them from redefining \cs{today}. The \sty{datetime2}
% \opt{useregional} setting must be set to "text" or "numeric"
% for the language styles to be set.
% Alternatively, you can set the style in the document using
% \cs{DTMsetstyle}, but this may be changed by \cs{date}\meta{language}
% depending on the value of the \opt{useregional} setting.
%\end{abstract}
%
%I've copied the date style from \texttt{babel-russian}'s \cs{today}.
%
%I don't know if these settings are correct as I can't speak Russian.
%In particular, I don't know if the "russian" time style is
%correct. Currently this just uses the "default" time style. Please
%be aware that this may change. Whoever takes over maintanance
%of this module may can change it as appropriate.
%
%The new maintainer should add the line:
%\begin{verbatim}
% The Current Maintainer of this work is Name.
%\end{verbatim}
%to the preamble part in \texttt{datetime2-russian.ins} where Name
%is the name of the maintainer(s) and replace
%the `inactive' status to `maintained'.
%
%Currently there is only a regionless style.
%
%\StopEventually{%
%\clearpage
%\phantomsection
%\addcontentsline{toc}{section}{Change History}%
%\PrintChanges
%\addcontentsline{toc}{section}{\indexname}%
%\PrintIndex}
%\section{The Code}
%\iffalse
%    \begin{macrocode}
%<*datetime2-russian-utf8.ldf>
%    \end{macrocode}
%\fi
%\subsection{UTF-8}
%This file contains the settings that use UTF-8 characters. This
%file is loaded if XeLaTeX or LuaLaTeX are used. Please make sure
%your text editor is set to UTF-8 if you want to view this code.
%\changes{1.0}{2015-03-31}{Initial release}
% Identify module
%    \begin{macrocode}
\ProvidesDateTimeModule{russian-utf8}[2018/12/07 v1.1]
%    \end{macrocode}
%\begin{macro}{\DTMrussianordinal}
%    \begin{macrocode}
\newcommand*{\DTMrussianordinal}[1]{%
  \number#1
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianyear}
%    \begin{macrocode}
\newcommand*{\DTMrussianyear}[1]{%
  \number#1
  \DTMtexorpdfstring{\protect~}{\space}г.%
}
%    \end{macrocode}
%\end{macro}
%
%
%\begin{macro}{\DTMrussianmonthname}
% Russian month names.
%    \begin{macrocode}
\newcommand*{\DTMrussianmonthname}[1]{%
  \ifcase#1
  \or
  января%
  \or
  февраля%
  \or
  марта%
  \or
  апреля%
  \or
  мая%
  \or
  июня%
  \or
  июля%
  \or
  августа%
  \or
  сентября%
  \or
  октября%
  \or
  ноября%
  \or
  декабря%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianMonthname}
% As above but capitalize.
%    \begin{macrocode}
\newcommand*{\DTMrussianMonthname}[1]{%
  \ifcase#1
  \or
  Января%
  \or
  Февраля%
  \or
  Марта%
  \or
  Апреля%
  \or
  Мая%
  \or
  Июня%
  \or
  Июля%
  \or
  Августа%
  \or
  Сентября%
  \or
  Октября%
  \or
  Ноября%
  \or
  Декабря%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%If abbreviated dates are supported, short month names should be
%likewise provided.
%
%\iffalse
%    \begin{macrocode}
%</datetime2-russian-utf8.ldf>
%    \end{macrocode}
%\fi
%\iffalse
%    \begin{macrocode}
%<*datetime2-russian-ascii.ldf>
%    \end{macrocode}
%\fi
%\subsection{ASCII}
%This file contains the settings that use \LaTeX\ commands for
%non-ASCII characters. This should be input if neither XeLaTeX nor
%LuaLaTeX are used. Even if the user has loaded \sty{inputenc} with
%"utf8", this file should still be used not the
%\texttt{datetime2-russian-utf8.ldf} file as the non-ASCII
%characters are made active in that situation and would need
%protecting against expansion.
%\changes{1.0}{2015-03-31}{Initial release}
% Identify module
%    \begin{macrocode}
\ProvidesDateTimeModule{russian-ascii}[2018/12/07 v1.1]
%    \end{macrocode}
%
%If abbreviated dates are supported, short month names should be
%likewise provided.
%\begin{macro}{\DTMrussianordinal}
%    \begin{macrocode}
\newcommand*{\DTMrussianordinal}[1]{%
  \number#1
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianyear}
%    \begin{macrocode}
\newcommand*{\DTMrussianyear}[1]{%
  \number#1 
  \DTMtexorpdfstring{\protect~}{\space}\protect\cyrg.%
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianmonthname}
% Russian month names.
%    \begin{macrocode}
\newcommand*{\DTMrussianmonthname}[1]{%
  \ifcase#1
  \or
   \protect\cyrya\protect\cyrn\protect\cyrv\protect\cyra\protect\cyrr
    \protect\cyrya
  \or
   \protect\cyrf\protect\cyre\protect\cyrv\protect\cyrr\protect\cyra
    \protect\cyrl\protect\cyrya
  \or
   \protect\cyrm\protect\cyra\protect\cyrr\protect\cyrt\protect\cyra
  \or
   \protect\cyra\protect\cyrp\protect\cyrr\protect\cyre\protect\cyrl
    \protect\cyrya
  \or
   \protect\cyrm\protect\cyra\protect\cyrya
  \or
   \protect\cyri\protect\cyryu\protect\cyrn\protect\cyrya
  \or
   \protect\cyri\protect\cyryu\protect\cyrl\protect\cyrya
  \or
   \protect\cyra\protect\cyrv\protect\cyrg\protect\cyru\protect\cyrs
    \protect\cyrt\protect\cyra
  \or
   \protect\cyrs\protect\cyre\protect\cyrn\protect\cyrt\protect\cyrya
    \protect\cyrb\protect\cyrr\protect\cyrya
  \or
   \protect\cyro\protect\cyrk\protect\cyrt\protect\cyrya\protect\cyrb
    \protect\cyrr\protect\cyrya
  \or
   \protect\cyrn\protect\cyro\protect\cyrya\protect\cyrb\protect\cyrr
    \protect\cyrya
  \or
   \protect\cyrd\protect\cyre\protect\cyrk\protect\cyra\protect\cyrb
    \protect\cyrr\protect\cyrya
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianMonthname}
% As above but start with a capital.
%    \begin{macrocode}
\newcommand*{\DTMrussianMonthname}[1]{%
}
%    \end{macrocode}
%\end{macro}
%
%\iffalse
%    \begin{macrocode}
%</datetime2-russian-ascii.ldf>
%    \end{macrocode}
%\fi
%
%\subsection{Main Russian Module (\texttt{datetime2-russian.ldf})}
%\changes{1.0}{2015-03-31}{Initial release}
%
%\iffalse
%    \begin{macrocode}
%<*datetime2-russian.ldf>
%    \end{macrocode}
%\fi
%
% Identify Module
%    \begin{macrocode}
\ProvidesDateTimeModule{russian}[2018/12/07 v1.1]
%    \end{macrocode}
% Need to find out if XeTeX or LuaTeX are being used.
%    \begin{macrocode}
\RequirePackage{ifxetex,ifluatex}
%    \end{macrocode}
% XeTeX and LuaTeX natively support UTF-8, so load
% \texttt{russian-utf8} if either of those engines are used
% otherwise load \texttt{russian-ascii}.
%    \begin{macrocode}
\ifxetex
 \RequireDateTimeModule{russian-utf8}
\else
 \ifluatex
   \RequireDateTimeModule{russian-utf8}
 \else
   \RequireDateTimeModule{russian-ascii}
 \fi
\fi
%    \end{macrocode}
%
% Define the \texttt{russian} style.
% The time style is the same as the "default" style
% provided by \sty{datetime2}. This may need correcting. For
% example, if a 12 hour style similar to the "englishampm" (from the
% "english-base" module) is required. 
%
% Allow the user a way of configuring the "russian" and
% "russian-numeric" styles. This doesn't use the package wide
% separators such as
% \cs{dtm@datetimesep} in case other date formats are also required.
%\begin{macro}{\DTMrussiandaymonthsep}
% The separator between the day and month for the text format.
%    \begin{macrocode}
\newcommand*{\DTMrussiandaymonthsep}{%
 \DTMtexorpdfstring{\protect~}{\space}}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussianmonthyearsep}
% The separator between the month and year for the text format.
%    \begin{macrocode}
\newcommand*{\DTMrussianmonthyearsep}{\space}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussiandatetimesep}
% The separator between the date and time blocks in the full format
% (either text or numeric).
%    \begin{macrocode}
\newcommand*{\DTMrussiandatetimesep}{\space}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussiantimezonesep}
% The separator between the time and zone blocks in the full format
% (either text or numeric).
%    \begin{macrocode}
\newcommand*{\DTMrussiantimezonesep}{\space}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussiandatesep}
% The separator for the numeric date format.
%    \begin{macrocode}
\newcommand*{\DTMrussiandatesep}{.}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMrussiantimesep}
% The separator for the numeric time format.
%    \begin{macrocode}
\newcommand*{\DTMrussiantimesep}{:}
%    \end{macrocode}
%\end{macro}
%
%Provide keys that can be used in \cs{DTMlangsetup} to set these
%separators.
%    \begin{macrocode}
\DTMdefkey{russian}{daymonthsep}{\renewcommand*{\DTMrussiandaymonthsep}{#1}}
\DTMdefkey{russian}{monthyearsep}{\renewcommand*{\DTMrussianmonthyearsep}{#1}}
\DTMdefkey{russian}{datetimesep}{\renewcommand*{\DTMrussiandatetimesep}{#1}}
\DTMdefkey{russian}{timezonesep}{\renewcommand*{\DTMrussiantimezonesep}{#1}}
\DTMdefkey{russian}{datesep}{\renewcommand*{\DTMrussiandatesep}{#1}}
\DTMdefkey{russian}{timesep}{\renewcommand*{\DTMrussiantimesep}{#1}}
%    \end{macrocode}
%
% TODO: provide a boolean key to switch between full and abbreviated
% formats if appropriate. (I don't know how the date should be
% abbreviated.)
%
% Define a boolean key that determines if the time zone mappings
% should be used.
%    \begin{macrocode}
\DTMdefboolkey{russian}{mapzone}[true]{}
%    \end{macrocode}
% The default is to use mappings.
%    \begin{macrocode}
\DTMsetbool{russian}{mapzone}{true}
%    \end{macrocode}
%
% Define a boolean key that determines if the day of month should be
% displayed.
%    \begin{macrocode}
\DTMdefboolkey{russian}{showdayofmonth}[true]{}
%    \end{macrocode}
% The default is to show the day of month.
%    \begin{macrocode}
\DTMsetbool{russian}{showdayofmonth}{true}
%    \end{macrocode}
%
% Define a boolean key that determines if the year should be
% displayed.
%    \begin{macrocode}
\DTMdefboolkey{russian}{showyear}[true]{}
%    \end{macrocode}
% The default is to show the year.
%    \begin{macrocode}
\DTMsetbool{russian}{showyear}{true}
%    \end{macrocode}
%
% Define the "russian" style. (TODO: implement day of week?)
%    \begin{macrocode}
\DTMnewstyle
 {russian}% label
 {% date style
   \renewcommand*\DTMdisplaydate[4]{%
     \DTMifbool{russian}{showdayofmonth}
     {\DTMrussianordinal{##3}\DTMrussiandaymonthsep}%
     {}%
     \DTMrussianmonthname{##2}%
     \DTMifbool{russian}{showyear}%
     {%
       \DTMrussianmonthyearsep
       \DTMrussianyear{##1}%
     }%
     {}%
   }%
   \renewcommand*\DTMDisplaydate[4]{%
     \DTMifbool{russian}{showdayofmonth}
     {%
       \DTMrussianordinal{##3}\DTMrussiandaymonthsep
       \DTMrussianmonthname{##2}%
     }%
     {%
       \DTMrussianMonthname{##2}%
     }%
     \DTMifbool{russian}{showyear}%
     {%
       \DTMrussianmonthyearsep
       \DTMrussianyear{##1}%
     }%
     {}%
   }%
 }%
 {% time style (use default)
   \DTMsettimestyle{default}%
 }%
 {% zone style
   \DTMresetzones
   \DTMrussianzonemaps
   \renewcommand*{\DTMdisplayzone}[2]{%
     \DTMifbool{russian}{mapzone}%
     {\DTMusezonemapordefault{##1}{##2}}%
     {%
       \ifnum##1<0\else+\fi\DTMtwodigits{##1}%
       \ifDTMshowzoneminutes\DTMrussiantimesep\DTMtwodigits{##2}\fi
     }%
   }%
 }%
 {% full style
   \renewcommand*{\DTMdisplay}[9]{%
    \ifDTMshowdate
     \DTMdisplaydate{##1}{##2}{##3}{##4}%
     \DTMrussiandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMrussiantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
   \renewcommand*{\DTMDisplay}[9]{%
    \ifDTMshowdate
     \DTMDisplaydate{##1}{##2}{##3}{##4}%
     \DTMrussiandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMrussiantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
 }%
%    \end{macrocode}
%
% Define numeric style.
%    \begin{macrocode}
\DTMnewstyle
 {russian-numeric}% label
 {% date style
    \renewcommand*\DTMdisplaydate[4]{%
      \DTMifbool{russian}{showdayofmonth}%
      {%
        \number##3 % space intended
        \DTMrussiandatesep
      }%
      {}%
      \number##2 % space intended
      \DTMifbool{russian}{showyear}%
      {%
        \DTMrussiandatesep
        \number##1 % space intended
      }%
      {}%
    }%
    \renewcommand*{\DTMDisplaydate}[4]{\DTMdisplaydate{##1}{##2}{##3}{##4}}%
 }%
 {% time style
    \renewcommand*\DTMdisplaytime[3]{%
      \number##1
      \DTMrussiantimesep\DTMtwodigits{##2}%
      \ifDTMshowseconds\DTMrussiantimesep\DTMtwodigits{##3}\fi
    }%
 }%
 {% zone style
   \DTMresetzones
   \DTMrussianzonemaps
   \renewcommand*{\DTMdisplayzone}[2]{%
     \DTMifbool{russian}{mapzone}%
     {\DTMusezonemapordefault{##1}{##2}}%
     {%
       \ifnum##1<0\else+\fi\DTMtwodigits{##1}%
       \ifDTMshowzoneminutes\DTMrussiantimesep\DTMtwodigits{##2}\fi
     }%
   }%
 }%
 {% full style
   \renewcommand*{\DTMdisplay}[9]{%
    \ifDTMshowdate
     \DTMdisplaydate{##1}{##2}{##3}{##4}%
     \DTMrussiandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMrussiantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
   \renewcommand*{\DTMDisplay}{\DTMdisplay}%
 }
%    \end{macrocode}
%
%\begin{macro}{\DTMrussianzonemaps}
% The time zone mappings are set through this command, which can be
% redefined if extra mappings are required or mappings need to be
% removed. These may need translating (in which case the definitions
% might need to be moved to the \texttt{utf8} and \texttt{ascii} ldf
% files). Daylight saving is not taken into account.
%    \begin{macrocode}
\newcommand*{\DTMrussianzonemaps}{%
  \DTMdefzonemap{03}{00}{MKT}%
  \DTMdefzonemap{04}{00}{SAMT}%
  \DTMdefzonemap{05}{00}{YEKT}%
  \DTMdefzonemap{06}{00}{OMST}%
  \DTMdefzonemap{07}{00}{KRAT}%
  \DTMdefzonemap{08}{00}{IRKST}%
  \DTMdefzonemap{09}{00}{YAKST}%
  \DTMdefzonemap{10}{00}{VLAT}%
  \DTMdefzonemap{11}{00}{SRET}%
  \DTMdefzonemap{12}{00}{PETT}%
}
%    \end{macrocode}
%\end{macro}

% Switch style according to the \opt{useregional} setting.
%    \begin{macrocode}
\DTMifcaseregional
{}% do nothing
{\DTMsetstyle{russian}}
{\DTMsetstyle{russian-numeric}}
%    \end{macrocode}
%
% Redefine \cs{daterussian} (or \cs{date}\meta{dialect}) to prevent
% \sty{babel} from resetting \cs{today}. (For this to work,
% \sty{babel} must already have been loaded if it's required.)
%\changes{1.1}{2018-12-07}{removed spurious space}
%    \begin{macrocode}
\ifcsundef{date\CurrentTrackedDialect}
{%
  \ifundef\daterussian
  {% do nothing
  }%
  {%
    \def\daterussian{%
      \DTMifcaseregional
      {}% do nothing
      {\DTMsetstyle{russian}}%
      {\DTMsetstyle{russian-numeric}}%
    }%
  }%
}%
{%
  \csdef{date\CurrentTrackedDialect}{%
    \DTMifcaseregional
    {}% do nothing
    {\DTMsetstyle{russian}}%
    {\DTMsetstyle{russian-numeric}}%
  }%
}%
%    \end{macrocode}
%\iffalse
%    \begin{macrocode}
%</datetime2-russian.ldf>
%    \end{macrocode}
%\fi
%\Finale
\endinput
