%\iffalse % iaria.dtx generated using makedtx version 1.2 (c) Nicola Talbot % Command line args: % -doc "doc/iaria.tex" % -dir "src" % -author "Christoph P. Neumann " % -src "(_cpn_copyIntoExamplesFolder_cls.cmd|iaria.cls)=>\1" % -macrocode ".*" % -date "2023-2025" % -setambles ".*=>\nopreamble" % -preamble "Copyright 2023-2024 Christoph P. Neumann This work may be distributed and/or modified under the conditions of the LaTeX Project Public License, either version 1.3c of this license or any later version. The latest version of this license is in https://www.latex-project.org/lppl.txt and version 1.3c or later is part of all distributions of LaTeX version 2008 or later. This work has the LPPL maintenance status maintained. The Current Maintainer of this work is Christoph P. Neumann. " % iaria % Created on 2025/1/18 13:44 %\fi %\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 \~} % %\fi % \iffalse % Doc-Source file to use with LaTeX2e % Copyright (C) 2023-2025 Christoph P. Neumann , all rights reserved. % \fi % \iffalse %<*driver> \documentclass{ltxdoc} \CodelineNumbered \EnableCrossrefs \CodelineIndex \RecordChanges \GetFileInfo{iaria.cls} \parskip1.0ex \parindent0.0ex \begin{document} \DocInput{iaria.dtx} \end{document} % %\fi %\title{\textsf{iaria}\\ %An Unofficial IARIA LaTeX Class} %\author{Christoph P.\ Neumann \texttt{$<$cyberpetaneuron@gmail.com$>$}} %\date{Version 0.6} %\maketitle %\PrintChanges % %\begin{abstract} %The \texttt{iaria}--class provides a convenient environment for writing IARIA scholary publications. %This version also implements full IARIA specifications for citation style, %which can only be templated for a specific technological combination like latex/pdflatex in combination with biblatex using a biber backend. %\end{abstract} % %\section{Installation} % %The \texttt{zip} or \texttt{tar.gz} file comes with a \texttt{iaria.ins} %and a \texttt{iaria.dtx} file included which contains the \LaTeX\ stuff. % %To extract the class files call: % %\begin{verbatim} % $ latex iaria.ins %\end{verbatim} % %This call will extract all \LaTeX\ specific files to the current %directory. You can either use the files for a single %cv project or you can integrate the files into your \TeX\ installation. % %If you just want to use \textsf{iaria} for a single curriculum vitae %project, the simplest way is just to copy the generated files to the %folder of the project. % %If you want to integrate \textsf{iaria} into your \TeX\ installation, %create a directory \texttt{tex/latex/iaria} beneath your \TeX\ installation %(e.g.~beneath \texttt{/usr/share/texmf}) and copy all files from the %current directory there. Now call: % %\begin{verbatim} % $ mktexlsr %\end{verbatim} % %to update the file--cache of \LaTeX. % %Hint: The \textsf{iaria} distribution contains a sample docstrip configuration %in \texttt{docstrip.cfg} via which files can be distributed %automatically to their correct positions inside a \LaTeX\ installation. %Feel free to adapt this file to your environment and afterwards call %\texttt{latex iaria.ins} to install the package to its right place. % %\section{Templates} % %For a quick start the \textsf{iaria} distribution contains document %templates. %The templates can be found in the \texttt{iaria-example-neumann.zip} file. % %\section{Documentclass} % %\DescribeMacro{documentclass iaria} %This package provides the documentclass \texttt{iaria}. The documentclass %supports the following options: % %\begin{itemize} %\item |conference| Passed to IEEEtran %\item |a4paper| Passed to IEEEtran %\item |subfig| Loads subfig package with IARIA style settings %\item |subcaption| Loads subcaption package with IARIA style settings %\item |flushend| Activate flushend package (compatible with arXiv build process) %\item |pbalance| Activate pbalance package (incompatible with arXiv build process) %\end{itemize} % %A Remark about two-column document balancing on the last page: %The flushend package is recommended, because it works within the arXiv automated build process. %However, flushend has a major incampatibility with package lineno, which is, e.\,g., transitively loaded by package mindflow. %Thus, in case when flushend does not have any effect, check whether one of your packages loads lineno. %Usually you are stuck with your packages and, thus, will instead be forced to switch from flushend to pbalance. %Please be aware that pbalance works great and has high compatibility, but unfortunately it will not have any effect within the arXiv automated build process. %In case of both, a somehow needed lineno package and an intended arXiv upload, I recommend to do without two-column balancing on the last page and just to stay away from both flushend and pbalance, in order to ensure that your paper is layouted identically in IARIA submission and arXiv upload. %I hope this remark proves helpful, it took me some nerve to find out. % %There is also another important difference between flushend and pbalance: the handling of footnotes on the last page. %Flushend provides a decent result, but the result of pbalance is incomprehensible. %I strongly recommend avoiding footnotes on the last page. %If you absolutely need footnotes on the last page, consider staying away from two-column balancing on the last page. % %About subfigures: %Both well-known packages subfig and subcaption can be used. %However, they are not compatible with each other and we can either load one or the other. %Both require dedicated style settings to be compatible with IARIA formatting rules. %Thus, the document class provides options to load them for you with correct settings. % %In order, to configure table/figure captions correctly for IARIA requirements, the package caption is used. %There would be other options to achieve this, however, the babel package is disruptive to the table label -- using package caption provides stability to the label configuration against babel intervention. %There are minor downsides of using caption package: %it results in a warning about unknown document class that cannot be suppressed, and if you do not use any tables or figures, caption package also results in a warning about ``unused captionsetup'' that cannot be suppressed, either. % %\section{Requirements} % %We instrument several other \LaTeX\ packages for different purposes, %which must be available under your installation. % %\begin{itemize} %\item IEEEtran %\item biblatex %\item extdash %\item flushend %\item fontenc %\item graphicx %\item hyperref %\item inputenc %\item orcidlink %\item pbalance %\item subcaption %\item subfig %\item times %\item url %\item xcolor %\item xpatch %\end{itemize} % % %\StopEventually{} %\section{The Code} %\iffalse % \begin{macrocode} %<*_cpn_copyIntoExamplesFolder_cls.cmd> % \end{macrocode} %\fi % \begin{macrocode} @echo off rem *************************************************************************** rem * author: Christoph P. Neumann rem *************************************************************************** cd /d "%~dp0" echo == ..\examples\* == for /D %%D in (..\examples\*) do ( echo == %%D == xcopy /Y ".\*.cls" "%%~D" ) pause% \end{macrocode} %\iffalse % \begin{macrocode} % % \end{macrocode} %\fi %\iffalse % \begin{macrocode} %<*iaria.cls> % \end{macrocode} %\fi % \begin{macrocode} %# Copyright (c) 2023-2025 Christoph P. Neumann % !TeX spellcheck = en-US % LTeX: language=en-US % !TeX encoding = utf8 % !TeX program = pdflatex % !BIB program = biblatex / biber % DISCLAIMER: Only for latex/pdflatex in combination with biblatex using a % biber backend. (And neither for XeLaTeX or LuaTeX nor for bibtex or natbib.) % Because to set the required bibliography configuration, the biblatex % package needs to be loaded. % I also need to adjust formatting of ONLINE entries, thus, I have to make % some assumptions to rely on. And inputenc must be loaded before biblatex. % Thus, inputenc, fontenc and biblatex with backend=biber are hard coded part % of this template. % I could remove these from the cls and make this part of the example.tex, % but then it would be less foolproof in my opinion. % I apologize for this opinionated design decission to anyone who is % jeopardised by it. % % I also had to decide whether to hardcode required usage of IEEEtran % "conference" option into my class. I decided against it. % Thus, it is required to use IARIA class like this: % \documentclass[conference]{iaria}. % The iaria class passes all class options (like "conference") to IEEEtran. % The reasoning: There might be a future use case (speculatively) to pass % IEEEtran options like "a4paper", for IARIA purposes (?) % For now, IARIA requires IEEE "conference" option, only. \NeedsTeXFormat{LaTeX2e} \ProvidesClass{iaria}[2025/01/16 IARIA template v0.6] % Define marker counter for options (counter are global in latex): \newcounter{iaria@subfigtracker} \newcounter{iaria@subcaptiontracker} \newcounter{iaria@pbalancetracker} \newcounter{iaria@flushendtracker} % Declare options: \DeclareOption{subfig}{ \setcounter{iaria@subfigtracker}{1} \typeout{iaria class: subfig option is set (use subfloat command).} } \DeclareOption{subcaption}{ \setcounter{iaria@subcaptiontracker}{1} \typeout{iaria class: subcaption option is set (use subfigure command).} } % IEEE option onecolumn will be ignored \DeclareOption{onecolumn}{\OptionNotUsed} \DeclareOption{pbalance}{ \setcounter{iaria@pbalancetracker}{1} \typeout{iaria class: pbalance option is set.} } \DeclareOption{flushend}{ \setcounter{iaria@flushendtracker}{1} \typeout{iaria class: flushend option is set.} } % We'll pass any document class options along to the underlying class % (required IEEE options: conference! For IARIA purposes.) \DeclareOption*{% \PassOptionsToClass{\CurrentOption}{IEEEtran} } % Now we'll execute any options passed in \ProcessOptions\relax % Instead of defining each and every little detail % required to create a new document class, % you can base your class on an existing document class. \LoadClass{IEEEtran} % Now paste your code from the preamble here. % Replace \usepackage with \RequirePackage. % (The syntax for both commands is the same.) \RequirePackage{times} % Times New Roman % inputenc must be loaded before biblatex \RequirePackage[utf8]{inputenc} % https://tex.stackexchange.com/questions/664 % /why-should-i-use-RequirePackaget1fontenc % Has to be loaded AFTER any font packages. % See https://tex.stackexchange.com/a/2869/9075. \RequirePackage[T1]{fontenc} \RequirePackage{graphicx} \RequirePackage{xcolor} \RequirePackage{url} \RequirePackage{orcidlink} \RequirePackage{hyperref} \hypersetup{hidelinks,unicode} % Diferring from IEEE, IARIA requires % in bibliography: 6+ authors as first author et al. % in \citeauthor: any case of et al. with just first author et al. \RequirePackage[ defernumbers=true, style=ieee, backend=biber, url=false, hyperref, maxnames=5, minnames=1, maxcitenames=2, mincitenames=1 ]{biblatex} % Due to applied option defernumbers=true: % Prevent citations in the references are being numbered as '0' in ArXiv % https://tex.stackexchange.com/questions/463556 % /all-the-citations-in-the-references-are-being-numbered-as-0-in-arxiv-while-upl \makeatletter \let\blx@rerun@biber\relax \makeatother % When using multiple citation keys in the same \cite command, % change "[1], [5], [7]" to IARIA-required "[1][5][7]": \renewcommand*{\multicitedelim}{} \renewcommand*{\bibfont}{\small} % Diferring from IEEE, IARIA requires, for ONLINE entries, % no point but a comma between author and title: % For style=ieee \DeclareBibliographyDriver{online}{% \usebibmacro{bibindex}% \usebibmacro{begentry}% \usebibmacro{author/editor+others/translator+others} \setunit{\labelnamepunct}\newblock \usebibmacro{title}% \newunit \printlist{language}% \newunit\newblock \usebibmacro{byauthor}% \newunit\newblock \usebibmacro{byeditor+others}% \newunit\newblock \printfield{version}% \newunit \printfield{note}% \newunit\newblock \printlist{organization} \newunit\newblock \usebibmacro{date}% \newunit\newblock \iftoggle{bbx:eprint} {\usebibmacro{eprint}} {}% \newunit\newblock \usebibmacro{url+urldate}% \newunit\newblock \usebibmacro{addendum+pubstate}% \setunit{\bibpagerefpunct}\newblock \usebibmacro{pageref}% \usebibmacro{finentry}} \makeatletter % Diferring from IEEE, IARIA requires non-abbreviated references: \renewcommand{\fnum@figure}{Figure~\thefigure} % Diferring from IEEE, IARIA requires 14 point bold Times for the title \renewcommand{\title}[1]{\renewcommand{\@title}{\bfseries\Large #1}} % Diferring from IEEE, IARIA requires "Keywords" instead of "Index Terms": \renewcommand\IEEEkeywordsname{Keywords} \makeatother \RequirePackage{xpatch} % Diferring from IEEE, IARIA requires a hyphen after "Keywords" % instead of an emdash: \xpatchcmd\IEEEkeywords{---}{-}{}{} % Diferring from IEEE, IARIA requires also the keywords in Italic % (and Bold)(and lower case!): \let\oldIEEEkeywords\IEEEkeywords \def\IEEEkeywords{\oldIEEEkeywords\itshape\ignorespaces} \makeatletter \renewcommand{\IEEEauthorblockN}[1]{% % copied from IEEEtran.cls: \relax\@IEEEauthorblockNstyle% set the default text style \gdef\@IEEEauthorblockXinterlinespace{0pt}% disable strut for spacer row \if@IEEEprevauthorblockincol\expandafter\@IEEEauthorblockNtopspaceline\fi \global\@IEEEprevauthorblockincoltrue% we now have a block in this column \gdef\@IEEEauthorblockXinterlinespace{\@IEEEauthorblockNinterlinespace}% \large #1% \crcr} \makeatother % IARIA requires to bring the table caption in the same line of "Table I" \usepackage{etoolbox} \makeatletter \patchcmd{\@makecaption} {\\} {.\ } {} {} \makeatother % caption is compatible with babel that intervenes with tablename \RequirePackage{caption} % IARIA requires table caption to be % above, centered, with upper case label ('TABLE'), and small caps text. \captionsetup[table]{ name=TABLE, position=above, justification=centering, labelsep=period, textfont={footnotesize, sc}, labelfont=footnotesize} % IARIA requires figure caption to be % below and centered \captionsetup[figure]{ position=below, justification=centering, labelsep=period, font={footnotesize,rm}} % IARIA subfigure captions require parentheses and footnotesize: \ifnum\value{iaria@subfigtracker}=1 \typeout{iaria class: load subfig package (use subfloat command).} \RequirePackage[caption=false,font=footnotesize]{subfig} \fi \ifnum\value{iaria@subcaptiontracker}=1 \typeout{iaria class: load subcaption package (use subfigure command).} \RequirePackage{subcaption} % IARIA requires subfigure caption to number them with % parentheses around latin chars (like "(a)" and "(b)") \captionsetup[subfigure]{labelformat=parens,font=footnotesize} \fi % Balance/level columns at the last page / in bibliography % DISCLAIMER: No solution is a 100%/perfect one! % Mainstream option: pbalance (see https://ctan.org/pkg/pbalance) % BUT: incompatible with arxiv automated process (!) \ifnum\value{iaria@pbalancetracker}=1 \typeout{iaria class: load pbalance package.} \RequirePackage{pbalance} \fi % Flushend => works with arxiv, but major incampatibility with lineno % (and, thus, also with mindflow et al.) \ifnum\value{iaria@flushendtracker}=1 \typeout{iaria class: load flushend package.} \RequirePackage{flushend} \fi % ======================================================== % Packages with recommendation to load them last: % Allows to hyphenate a word that contains a dash: % https://stackoverflow.com/questions/2193307 % /how-do-i-get-latex-to-hyphenate-a-word-that-contains-a-dash % Use \-/ for a breakable dash that does not prevent the % remainer of the word to be hyphenated. \RequirePackage[shortcuts]{extdash} % ======================================================== % Finally, we'll use \endinput to indicate that LaTeX can stop reading % this file. LaTeX will ignore anything after this line. \endinput % \end{macrocode} %\iffalse % \begin{macrocode} % % \end{macrocode} %\fi %\Finale \endinput