%\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) 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 Galician Module}]{hyperref}

\setmainfont{Liberation Serif}
\setmonofont{Liberation Mono}

\CheckSum{261}

\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-galician.dtx}
\end{document}
%</driver>
%\fi
%
%\MakeShortVerb{"}
%
%\title{Galician Module for datetime2 Package}
%\author{Nicola L. C. Talbot (inactive)}
%\date{2018-04-13 (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 Galician 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-galician}'s \cs{today}.
%
%I don't know if these settings are correct as I can't speak Galician.
%In particular, I don't know if the "galician" 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-galician.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-galician-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-30}{Initial release}
% Identify module
%    \begin{macrocode}
\ProvidesDateTimeModule{galician-utf8}[2018/04/13 v1.1]
%    \end{macrocode}
%\begin{macro}{\DTMgalicianordinal}
%    \begin{macrocode}
\newcommand*{\DTMgalicianordinal}[1]{%
  \number#1
}
%    \end{macrocode}
%\end{macro}
%
%
%\begin{macro}{\DTMgalicianmonthname}
% Galician month names.
%    \begin{macrocode}
\newcommand*{\DTMgalicianmonthname}[1]{%
  \ifcase#1
  \or
  xaneiro%
  \or
  febreiro%
  \or
  marzo%
  \or
  abril%
  \or
  maio%
  \or
  xuño%
  \or
  xullo%
  \or
  agosto%
  \or
  setembro%
  \or
  outubro%
  \or
  novembro%
  \or
  decembro%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgalicianMonthname}
% As above but capitalize.
%    \begin{macrocode}
\newcommand*{\DTMgalicianMonthname}[1]{%
  \ifcase#1
  \or
  Xaneiro%
  \or
  Febreiro%
  \or
  Marzo%
  \or
  Abril%
  \or
  Maio%
  \or
  Xuño%
  \or
  Xullo%
  \or
  Agosto%
  \or
  Setembro%
  \or
  Outubro%
  \or
  Novembro%
  \or
  Decembro%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%If abbreviated dates are supported, short month names should be
%likewise provided.
%
%\iffalse
%    \begin{macrocode}
%</datetime2-galician-utf8.ldf>
%    \end{macrocode}
%\fi
%\iffalse
%    \begin{macrocode}
%<*datetime2-galician-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-galician-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-30}{Initial release}
% Identify module
%    \begin{macrocode}
\ProvidesDateTimeModule{galician-ascii}[2018/04/13 v1.1]
%    \end{macrocode}
%
%If abbreviated dates are supported, short month names should be
%likewise provided.
%\begin{macro}{\DTMgalicianordinal}
%    \begin{macrocode}
\newcommand*{\DTMgalicianordinal}[1]{%
  \number#1
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgalicianmonthname}
% Galician month names.
%    \begin{macrocode}
\newcommand*{\DTMgalicianmonthname}[1]{%
  \ifcase#1
  \or
  xaneiro%
  \or
  febreiro%
  \or
  marzo%
  \or
  abril%
  \or
  maio%
  \or
  xu\protect\~no%
  \or
  xullo%
  \or
  agosto%
  \or
  setembro%
  \or
  outubro%
  \or
  novembro%
  \or
  decembro%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgalicianMonthname}
% As above but capitalize.
%    \begin{macrocode}
\newcommand*{\DTMgalicianMonthname}[1]{%
  \ifcase#1
  \or
  Xaneiro%
  \or
  Febreiro%
  \or
  Marzo%
  \or
  Abril%
  \or
  Maio%
  \or
  Xu\protect\~no%
  \or
  Xullo%
  \or
  Agosto%
  \or
  Setembro%
  \or
  Outubro%
  \or
  Novembro%
  \or
  Decembro%
  \fi
}
%    \end{macrocode}
%\end{macro}
%
%
%\iffalse
%    \begin{macrocode}
%</datetime2-galician-ascii.ldf>
%    \end{macrocode}
%\fi
%
%\subsection{Main Galician Module (\texttt{datetime2-galician.ldf})}
%\changes{1.0}{2015-03-30}{Initial release}
%
%\iffalse
%    \begin{macrocode}
%<*datetime2-galician.ldf>
%    \end{macrocode}
%\fi
%
% Identify Module
%    \begin{macrocode}
\ProvidesDateTimeModule{galician}[2018/04/13 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{galician-utf8} if either of those engines are used
% otherwise load \texttt{galician-ascii}.
%    \begin{macrocode}
\ifxetex
 \RequireDateTimeModule{galician-utf8}
\else
 \ifluatex
   \RequireDateTimeModule{galician-utf8}
 \else
   \RequireDateTimeModule{galician-ascii}
 \fi
\fi
%    \end{macrocode}
%
% Define the \texttt{galician} 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 "galician" and
% "galician-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}{\DTMgaliciandaymonthsep}
% The separator between the day and month for the text format.
%    \begin{macrocode}
\newcommand*{\DTMgaliciandaymonthsep}{%
 \DTMtexorpdfstring{\protect~}{\space}%
 de\space
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgalicianmonthyearsep}
% The separator between the month and year for the text format.
%    \begin{macrocode}
\newcommand*{\DTMgalicianmonthyearsep}{%
 \space de%
 \DTMtexorpdfstring{\protect~}{\space}%
}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgaliciandatetimesep}
% The separator between the date and time blocks in the full format
% (either text or numeric).
%    \begin{macrocode}
\newcommand*{\DTMgaliciandatetimesep}{\space}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgaliciantimezonesep}
% The separator between the time and zone blocks in the full format
% (either text or numeric).
%    \begin{macrocode}
\newcommand*{\DTMgaliciantimezonesep}{\space}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgaliciandatesep}
% The separator for the numeric date format.
%    \begin{macrocode}
\newcommand*{\DTMgaliciandatesep}{/}
%    \end{macrocode}
%\end{macro}
%
%\begin{macro}{\DTMgaliciantimesep}
% The separator for the numeric time format.
%    \begin{macrocode}
\newcommand*{\DTMgaliciantimesep}{:}
%    \end{macrocode}
%\end{macro}
%
%Provide keys that can be used in \cs{DTMlangsetup} to set these
%separators.
%    \begin{macrocode}
\DTMdefkey{galician}{daymonthsep}{\renewcommand*{\DTMgaliciandaymonthsep}{#1}}
\DTMdefkey{galician}{monthyearsep}{\renewcommand*{\DTMgalicianmonthyearsep}{#1}}
\DTMdefkey{galician}{datetimesep}{\renewcommand*{\DTMgaliciandatetimesep}{#1}}
\DTMdefkey{galician}{timezonesep}{\renewcommand*{\DTMgaliciantimezonesep}{#1}}
\DTMdefkey{galician}{datesep}{\renewcommand*{\DTMgaliciandatesep}{#1}}
\DTMdefkey{galician}{timesep}{\renewcommand*{\DTMgaliciantimesep}{#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{galician}{mapzone}[true]{}
%    \end{macrocode}
% The default is to use mappings.
%    \begin{macrocode}
\DTMsetbool{galician}{mapzone}{true}
%    \end{macrocode}
%
% Define a boolean key that determines if the day of month should be
% displayed.
%    \begin{macrocode}
\DTMdefboolkey{galician}{showdayofmonth}[true]{}
%    \end{macrocode}
% The default is to show the day of month.
%    \begin{macrocode}
\DTMsetbool{galician}{showdayofmonth}{true}
%    \end{macrocode}
%
% Define a boolean key that determines if the year should be
% displayed.
%    \begin{macrocode}
\DTMdefboolkey{galician}{showyear}[true]{}
%    \end{macrocode}
% The default is to show the year.
%    \begin{macrocode}
\DTMsetbool{galician}{showyear}{true}
%    \end{macrocode}
%
% Define the "galician" style. (TODO: implement day of week?)
%    \begin{macrocode}
\DTMnewstyle
 {galician}% label
 {% date style
   \renewcommand*\DTMdisplaydate[4]{%
     \DTMifbool{galician}{showdayofmonth}
     {\DTMgalicianordinal{##3}\DTMgaliciandaymonthsep}%
     {}%
     \DTMgalicianmonthname{##2}%
     \DTMifbool{galician}{showyear}%
     {%
       \DTMgalicianmonthyearsep
       \number##1
     }%
     {}%
   }%
   \renewcommand*\DTMDisplaydate[4]{%
     \DTMifbool{galician}{showdayofmonth}
     {%
       \DTMgalicianordinal{##3}\DTMgaliciandaymonthsep
       \DTMgalicianmonthname{##2}%
     }%
     {%
       \DTMgalicianMonthname{##2}%
     }%
     \DTMifbool{galician}{showyear}%
     {%
       \DTMgalicianmonthyearsep
       \number##1
     }%
     {}%
   }%
 }%
 {% time style (use default)
   \DTMsettimestyle{default}%
 }%
 {% zone style
   \DTMresetzones
   \DTMgalicianzonemaps
   \renewcommand*{\DTMdisplayzone}[2]{%
     \DTMifbool{galician}{mapzone}%
     {\DTMusezonemapordefault{##1}{##2}}%
     {%
       \ifnum##1<0\else+\fi\DTMtwodigits{##1}%
       \ifDTMshowzoneminutes\DTMgaliciantimesep\DTMtwodigits{##2}\fi
     }%
   }%
 }%
 {% full style
   \renewcommand*{\DTMdisplay}[9]{%
    \ifDTMshowdate
     \DTMdisplaydate{##1}{##2}{##3}{##4}%
     \DTMgaliciandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMgaliciantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
   \renewcommand*{\DTMDisplay}[9]{%
    \ifDTMshowdate
     \DTMDisplaydate{##1}{##2}{##3}{##4}%
     \DTMgaliciandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMgaliciantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
 }%
%    \end{macrocode}
%
% Define numeric style.
%    \begin{macrocode}
\DTMnewstyle
 {galician-numeric}% label
 {% date style
    \renewcommand*\DTMdisplaydate[4]{%
      \DTMifbool{galician}{showdayofmonth}%
      {%
        \number##3 % space intended
        \DTMgaliciandatesep
      }%
      {}%
      \number##2 % space intended
      \DTMifbool{galician}{showyear}%
      {%
        \DTMgaliciandatesep
        \number##1 % space intended
      }%
      {}%
    }%
    \renewcommand*{\DTMDisplaydate}{\DTMdisplaydate}%
 }%
 {% time style
    \renewcommand*\DTMdisplaytime[3]{%
      \number##1
      \DTMgaliciantimesep\DTMtwodigits{##2}%
      \ifDTMshowseconds\DTMgaliciantimesep\DTMtwodigits{##3}\fi
    }%
 }%
 {% zone style
   \DTMresetzones
   \DTMgalicianzonemaps
   \renewcommand*{\DTMdisplayzone}[2]{%
     \DTMifbool{galician}{mapzone}%
     {\DTMusezonemapordefault{##1}{##2}}%
     {%
       \ifnum##1<0\else+\fi\DTMtwodigits{##1}%
       \ifDTMshowzoneminutes\DTMgaliciantimesep\DTMtwodigits{##2}\fi
     }%
   }%
 }%
 {% full style
   \renewcommand*{\DTMdisplay}[9]{%
    \ifDTMshowdate
     \DTMdisplaydate{##1}{##2}{##3}{##4}%
     \DTMgaliciandatetimesep
    \fi
    \DTMdisplaytime{##5}{##6}{##7}%
    \ifDTMshowzone
     \DTMgaliciantimezonesep
     \DTMdisplayzone{##8}{##9}%
    \fi
   }%
   \renewcommand*{\DTMDisplay}{\DTMdisplay}%
 }
%    \end{macrocode}
%
%\begin{macro}{\DTMgalicianzonemaps}
% The time zone mappings are set through this command, which can be
% redefined if extra mappings are required or mappings need to be
% removed. No default mappings are provided at the moment.
%    \begin{macrocode}
\newcommand*{\DTMgalicianzonemaps}{%
  \DTMdefzonemap{01}{00}{CET}%
  \DTMdefzonemap{02}{00}{CEST}%
}
%    \end{macrocode}
%\end{macro}

% Switch style according to the \opt{useregional} setting.
%    \begin{macrocode}
\DTMifcaseregional
{}% do nothing
{\DTMsetstyle{galician}}
{\DTMsetstyle{galician-numeric}}
%    \end{macrocode}
%
% Redefine \cs{dategalician} (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-04-13}{removed spurious space}
%    \begin{macrocode}
\ifcsundef{date\CurrentTrackedDialect}
{%
  \ifundef\dategalician
  {% do nothing
  }%
  {%
    \def\dategalician{%
      \DTMifcaseregional
      {}% do nothing
      {\DTMsetstyle{galician}}%
      {\DTMsetstyle{galician-numeric}}%
    }%
  }%
}%
{%
  \csdef{date\CurrentTrackedDialect}{%
    \DTMifcaseregional
    {}% do nothing
    {\DTMsetstyle{galician}}%
    {\DTMsetstyle{galician-numeric}}%
  }%
}%
%    \end{macrocode}
%\iffalse
%    \begin{macrocode}
%</datetime2-galician.ldf>
%    \end{macrocode}
%\fi
%\Finale
\endinput