texlive[69733] Master/texmf-dist: asmeconf (7feb24)
commits+karl at tug.org
commits+karl at tug.org
Wed Feb 7 22:01:17 CET 2024
Revision: 69733
https://tug.org/svn/texlive?view=revision&revision=69733
Author: karl
Date: 2024-02-07 22:01:17 +0100 (Wed, 07 Feb 2024)
Log Message:
-----------
asmeconf (7feb24)
Modified Paths:
--------------
trunk/Master/texmf-dist/bibtex/bst/asmeconf/asmeconf.bst
trunk/Master/texmf-dist/doc/latex/asmeconf/README.md
trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-sample.bib
trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.pdf
trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.tex
trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-fontspec.tex
trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-lualatex-ode-example.tex
trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.pdf
trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.tex
trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-1.pdf
trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-2a.pdf
trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-2b.pdf
trunk/Master/texmf-dist/tex/latex/asmeconf/asmeconf.cls
Modified: trunk/Master/texmf-dist/bibtex/bst/asmeconf/asmeconf.bst
===================================================================
--- trunk/Master/texmf-dist/bibtex/bst/asmeconf/asmeconf.bst 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/bibtex/bst/asmeconf/asmeconf.bst 2024-02-07 21:01:17 UTC (rev 69733)
@@ -4,7 +4,7 @@
%%%%% *** https://www.asme.org/publications-submissions/proceedings/author-guidelines/elements-of-a-paper/references ***
%%%%% *** The examples given by ASME do *not* cover all possibilities ***
%%%%%
-%%%%% This file is version 1.15 dated 2022/12/30
+%%%%% This file is version 1.16 dated 2024/02/03
%%%%%
%%%%% Author: John H. Lienhard V
%%%%% Department of Mechanical Engineering
@@ -27,6 +27,9 @@
%%%%% Added: venue and eventdate to @inproceedings
%%%%%
%%%%%
+%%%%% Edits in version 1.16, 2024/02/03
+%%%%% fix spacing and punctuation in journal title macros
+%%%%%
%%%%% Edits in version 1.15, 2022/12/30
%%%%% Add macro "jhmt" for "ASME J. Heat Mass Transfer"
%%%%%
@@ -56,7 +59,7 @@
%%%%% add "urldate" to eprint format, for optional use.
%%%%% warn in @online not to use both eprint and url, and warn if neither is given.
%%%%% remove series and add volume to @inproceedings.
-%%%%%
+%%%%%
%%%%% Feel free to edit this file to suit your own needs, but please make note of changes in this header.
%%%%%
%%=========================================================
@@ -468,65 +471,65 @@
MACRO {pubmed} {"https://www.ncbi.nlm.nih.gov/pubmed/"}
-MACRO {amr} {"Appl. Mech. Rev."}
+MACRO {amr} {"Appl.\ Mech. Rev."}
MACRO {lds} {"ASME Letters Dynamic Systems"}
MACRO {jru} {"ASME J. Risk Uncertainty"}
-MACRO {jsbc} {"ASME J. Sustainable Bldg. and Cities"}
+MACRO {jsbc} {"ASME J. Sustainable Bldg.\ and Cities"}
-MACRO {jam} {"ASME J. Appl. Mech."}
+MACRO {jam} {"ASME J. Appl.\ Mech."}
-MACRO {jbe} {"ASME J. Biomed. Eng."}
+MACRO {jbe} {"ASME J. Biomed.\ Eng."}
-MACRO {jcnd} {"ASME J. Comput. Nonlin. Dyn."}
+MACRO {jcnd} {"ASME J. Comput.\ Nonlin.\ Dyn."}
-MACRO {jcise} {"ASME J. Comput. Inf. Sci. Eng."}
+MACRO {jcise} {"ASME J. Comput.\ Inf.\ Sci.\ Eng."}
-MACRO {jds} {"J. Dyn. Syst.-T. ASME"}
+MACRO {jds} {"J. Dyn. Syst.---T. ASME"}
-MACRO {jep} {"ASME J. Electron. Packag."}
+MACRO {jep} {"ASME J. Electron.\ Packag."}
MACRO {jert} {"ASME J. Energy Resour."}
-MACRO {jegtp} {"ASME J. Eng. Gas Turbines Power"}
+MACRO {jegtp} {"ASME J. Eng.\ Gas Turbines Power"}
-MACRO {jem} {"ASME J. Eng. Mater."}
+MACRO {jem} {"ASME J. Eng.\ Mater."}
MACRO {jfe} {"ASME J. Fluids Eng."}
-MACRO {jfcst} {"ASME J. Fuel Cell Sci. Tech."}
+MACRO {jfcst} {"ASME J. Fuel Cell Sci.\ Tech."}
MACRO {jht} {"ASME J. Heat Transfer"}
MACRO {jhmt} {"ASME J. Heat Mass Transfer"}
-MACRO {jmse} {"ASME J. Manuf. Sci. E."}
+MACRO {jmse} {"ASME J. Manuf.\ Sci.\ E."}
-MACRO {jmd} {"ASME J. Mech. Des."}
+MACRO {jmd} {"ASME J. Mech.\ Des."}
-MACRO {jmr} {"ASME J. Mech. Robot."}
+MACRO {jmr} {"ASME J. Mech.\ Robot."}
-MACRO {jmdv} {"ASME J. Med. Devices"}
+MACRO {jmdv} {"ASME J. Med.\ Devices"}
MACRO {jmnm} {"ASME J. Micro Nano-Manuf."}
-MACRO {jnem} {"ASME J. Nanotech Eng. Med."}
+MACRO {jnem} {"ASME J. Nanotech Eng.\ Med."}
-MACRO {joma} {"ASME J. Offshore Mech. Arct."}
+MACRO {joma} {"ASME J. Offshore Mech.\ Arct."}
-MACRO {jpv} {"ASME J. Press. Vess."}
+MACRO {jpv} {"ASME J. Press.\ Vess."}
-MACRO {jse} {"ASME J. Sol. Energy"}
+MACRO {jse} {"ASME J. Sol.\ Energy"}
-MACRO {jtsea} {"ASME J. Therm. Sci. Eng. Appl."}
+MACRO {jtsea} {"ASME J. Therm.\ Sci.\ Eng.\ Appl."}
MACRO {jtb} {"ASME J. Tribol."}
MACRO {jtm} {"ASME J. Turbomach."}
-MACRO {jva} {"ASME J. Vib. Acoust."}
+MACRO {jva} {"ASME J. Vib.\ Acoust."}
MACRO {acmcs} {"ACM Computing Surveys"}
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/README.md
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/README.md 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/README.md 2024-02-07 21:01:17 UTC (rev 69733)
@@ -1,11 +1,11 @@
#asmeconf: A latex template for ASME conference papers#
- Version 1.36 dated 2022/12/28.
+ Version 1.37 dated 2024/02/06.
####Overview####
This class provides a LaTeX template for ASME Conference papers formatted according to
- the requirements on ASME's web pages (as posted in 2022):
+ the requirements on ASME's web pages (as posted in 2024):
[www.asme.org/publications-submissions/proceedings/formatting-the-paper](https://www.asme.org/publications-submissions/proceedings/formatting-the-paper)
@@ -31,7 +31,7 @@
- support copyright footer for federal employees and contractors
-- enable various math and text features with newtxmath and newtxtext packages
+- enable various math and text features from the newtx package
- support bold face, sans serif math in section headings
@@ -79,22 +79,34 @@
---
####Change log####
- v1.36 (2022/12/28)
- - Change option-passing to xcolor package to address recent changes that package's code which lead to an error message.
- v1.35 (2022/10/19)
+ v1.37 (2024/02/06)
+ - Under luaLaTeX, fontspec is now loaded by default. The option [nofontspec] will prevent this.
+ - Eliminate the following long-deprecated options: [oldauthor, lang, lang-second, lang-third]
+ - newtxtext has removed the superiors font options (Jan 2024). As a result, the option [nodefaultsups] has been removed from asmeconf, along with supporting code
+ - Streamline code for option handling and compatibility testing; other code clean-up
+ - Switch code handling successive footnotes to expl3, adjust intersecting code
+ - Small code changes to accommodate future tagged pdf
+ - Refresh sample figures, edit sample bib file
+ - Edits to asmeconf.bst: fix punctuation and spacing in journal title macros
+
+
+ v1.36 (2023/12/28)
+ - Change option-passing to xcolor package to address recent changes that package's code which lead to an error message.
+
+ v1.35 (2023/10/19)
- Adjust pdf-a code to accommodate recent changes to hyperxmp package. NOTE: \\DocumentMetadata{ ..} is now preferred to using class option [pdf-a].
- Add option to not use boldface text in captions: [unboldcaption]
- Add mathversion sans for sans-serif math and set as default in unbolded captions
- v1.34 (2022/12/30)
+ v1.34 (2022/12/30)
- Roll back advanced metadata feature for compatibility with pre-2022 installations
- v1.33 (2022/12/30)
+ v1.33 (2022/12/30)
- Update headers to 2023 IMECE
- Add macro "jhmt" to asmeconf.bst for "ASME J. Heat Mass Transfer"; add sample citation and figures from jhmt.
- v1.32 (2022/09/14)
+ v1.32 (2022/09/14)
- Incorporate patch to correct bug in hyperxmp that had impaired pdf/a compliance.
- Add code to asmeconf.bst for empty page field in @article.
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-sample.bib
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-sample.bib 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-sample.bib 2024-02-07 21:01:17 UTC (rev 69733)
@@ -1,6 +1,6 @@
%% Sample bibliography file for asmeconf.bst and asmeconf.cls
%%
-%% Revised 30 December 2022
+%% Revised 25 January 2024
%% Copyright John H. Lienhard, MIT
%% Offered under the MIT license: https://ctan.org/license/mit
@@ -150,30 +150,31 @@
%% If you need to change "Chap." to something else, use for example: type = {{C}hapter},
%% It's very uncommon to have the "series" field as above.
- at article{Lienhard2019b,
- author = {Lienhard, V, John H.},
- title = {Exterior Shape Factors from Interior Shape Factors},
- journal = jht,
- doi = {10.1115/1.4042912},
- volume = {141},
- number = {6},
- eid = {061301},
- year = {2019},
+ at article{lienhard2020,
+ author = {Lienhard, John H.},
+ title = {Heat Transfer in Flat-Plate Boundary Layers: A Correlation for Laminar, Transitional, and Turbulent Flow},
+ journal = jht,
+ volume = {142},
+ number = {6},
+ eid = {061805},
+ year = {2020},
+ month = jun,
+ doi = {10.1115/1.4046795},
}
%% Note eid field rather than page numbers. Will not produce "pp." before the eid number.
%% May include numpages = {} to get "eid (numpages pages)"
%% Note use of jht macro for title title (produces "ASME J. Heat Transfer"). All ASME journals have macros.
- at article{lienhard2023,
- author = {Lienhard, V, John H.},
- title = {Steady Two-Dimensional Conduction: Simple and Double Layer Potentials, Corner Singularities, and Induced Heat Flux},
- journal = jhmt,
- volume = {145},
- number = {3},
- eid = {031401},
- year = {2023},
- month = {3},
- doi = {10.1115/1.4055833},
+ at article{lienhard2019,
+ author = {Lienhard, John H.},
+ title = {Linearization of Nongray Radiation Exchange: The Internal Fractional Function Reconsidered},
+ journal = jht,
+ volume = {141},
+ number = {5},
+ eid = {052701},
+ year = {2019},
+ month = mar,
+ doi = {10.1115/1.4042158},
}
%% note use of: eid in place of pages, and use of jhmt macro for the journal name
@@ -191,8 +192,18 @@
%% You can change "Accessed" with "urltype", e.g., urltype = {retrieved},
%% You can change "Version" with "versiontype, e.g., versiontype = {Release},
+ at online{lienhard2024,
+ author = {Lienhard, John H.},
+ title = {Example of {\LuaLaTeX} with {\texttt{asmeconf.cls}} for {ODE} integration},
+ version = {1.01},
+ organization = {Comprehensive \TeX\ Archive Network},
+ year = {2024},
+ url = {https://www.ctan.org/pkg/asmeconf},
+ urldate = {January 23, 2024},
+}
+
@online{lienhard2021,
- author = {Lienhard, V, John H.},
+ author = {Lienhard, John H.},
title = {Language Support in {\texttt{asmeconf}}: non-latin alphabets, {\LuaLaTeX}, and {\texttt{fontspec}}},
version = {1.0},
organization = {Comprehensive \TeX\ Archive Network},
@@ -294,7 +305,7 @@
}
@online{lienhard2022,
- author = {Lienhard, V, John H.},
+ author = {Lienhard, John H.},
title = {Wide Equations in {\texttt{asmeconf.cls}}},
version = {1.0},
organization = {Comprehensive \TeX\ Archive Network},
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.tex 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/asmeconf-template.tex 2024-02-07 21:01:17 UTC (rev 69733)
@@ -4,7 +4,7 @@
%% This file is asmeconf-template.tex, a LaTeX template to format ASME Conference papers according to
%% the requirements on ASME's conference web pages, and including hypertext support for the pdf.
%%
-%% This file is version 1.36 dated 2023/12/28
+%% This file is version 1.37 dated 2024/02/06
%%
%% As of version 1.11, this template defaults to ASME's newer conference guidelines first posted July 2019.
%% Those guidelines changed the requested author block formatting to be inline.
@@ -18,15 +18,6 @@
%%
%% Class options include:
%%
-%% * Math options from M. Sharpe's newtxmath package: upright integrals [upint];
-%% * [varvw] for a v and w that are better distinguished from Greek nu; and also
-%% * [subscriptcorrection, smallerops, varg, frenchmath, varbb, cmbraces, slantedGreek,...]
-%% * See newtx documentation for descriptions (at CTAN: http://ctan.org, v1.6 or higher is best).
-%%
-%% * Options to: omit the ASME copyright footer [nofoot];
-%% * use government employee copyright notice [govt];
-%% * use government contractor copyright notice [contractor]
-%%
%% * An option to use the traditional grid arrangement of author names [grid].
%% * With this option, line breaks (\\) may be inserted into the address as needed.
%% * Author names that include commas should be enclosed in braces, e.g., {Joseph L. Smith, Jr.}.
@@ -43,21 +34,33 @@
%% * just leave a blank line above the displayed equation while you are editing and then remove the
%% * blank line and [lineno] option when you move to your final version.
%%
+%% * An option not to use boldface font for caption text [unboldcaption]
+%%
+%% * Options to: omit the ASME copyright footer [nofoot];
+%% * use government employee copyright notice [govt];
+%% * use government contractor copyright notice [contractor]
+%% * use copyright notice for some gov't employees [somegovt]
+%%
%% * Options for PDF/A compliance. [pdf-a] will produce PDF/A-3u compliance with sRGB OutputIntent.
%% * [pdfapart= 1 or 2 or 3] and [pdfaconformance= b or u] can enable levels 1b, 2b, 2u, and 3b.
-%% * The most recent versions of LaTeX (2021 and later) are moving toward integrated support for pdf-a,
-%% * through \DeclareDocumentMetadata{..}. The asmeconf class supports these new features, which can
-%% * replace the aforementioned class options. (An up-to-date LaTeX installation is required to use this.)
+%% *
+%% * The most recent versions of LaTeX (2021 and later) have adopted integrated support for pdf-a,
+%% * through \DeclareDocumentMetadata{..}. The asmeconf class supports these features, which are preferred
+%% * to the aforementioned class options. (An up-to-date LaTeX installation is required to use this.)
%%
%% * Many options for calligraphic, script, and fraktur fonts from the mathalfa package; the
-%% * example shown here is: [mathalfa=cal=boondoxo] to use a Boondox font for \mathcal.
+%% * example shown here is: [mathalfa=cal=boondoxo] to use the Boondox font for \mathcal.
%% * Some other options for cal are: dutchcal, zapfc, cm (default), euler,...
%% * frak (fraktur), bb (blackboard bold), scr (script) may also be chosen this way.
-%% * For details, refer to mathalfa documentation (at CTAN: http://ctan.org).
+%% * For details, refer to mathalfa documentation (at CTAN: https://www.ctan.org/pkg/mathalpha).
%%
-%% * Option to use superiors font from newtxtext for footnotes [nodefaultsups] and
-%% * for slightly larger small capitals, [largesc], also from newtxtext.
+%% * Math options from M. Sharpe's newtxmath package: upright integrals [upint];
+%% * [varvw] for a v and w that are better distinguished from Greek nu; and also
+%% * [subscriptcorrection, smallerops, varg, frenchmath, varbb, cmbraces, slantedGreek,...]
+%% * See newtx documentation for descriptions (at CTAN: https://www.ctan.org/pkg/newtx, v1.6 or higher is best).
%%
+%% * Option to for slightly larger small capitals, [largesc], from newtxtext package.
+%%
%% * An option to allow hyphenation of the typewriter font [hyphenate], from inconsolata package.
%% * Hyphenation is normally suppressed for typewriter mode because it is often used for code.
%% * To replace the default variable word spacing by monospacing, use the option [mono].
@@ -65,8 +68,11 @@
%%
%% * Options (used by the babel package) to include passages in languages other than English (e.g., a translation
%% * of the abstract). Languages are called as options, e.g. [french], [spanish], [greek], [russian], etc.
-%% * Language support is greatest when running LuaLaTeX with the [fontspec] option.
-%% * See Appendix B for details.
+%% * See Appendix B for details.
+%% * Language support is most extensive when running LuaLaTeX, which automatically loads fontspec, but
+%% * be aware that you may to install additional fonts on your system to use fontspec.
+%% *
+%% * To use LuaLaTeX without bothering about extra fonts, use the [nofontspec] option to asmeconf.
%%
%% The use of commands defined or modified by the asmeconf class is illustrated throughout this file. In particular,
%% ASME requires capitalized, sans-serif section headings, and as a result some care is needed when using macros
@@ -78,16 +84,16 @@
%%
%% LICENSE:
%%
-%% Copyright (c) 2023 John H. Lienhard
+%% Copyright (c) 2024 John H. Lienhard
%%
%% Offered under the MIT license: https://ctan.org/license/mit
%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-%% RECOMMENDED newpdf management code (June 2022).
-%% This addition the LaTeX kernel was recently made by the LaTeX Project team
-%% see https://www.latex-project.org/news/latex2e-news/ltnews35.pdf
-%% Uncomment the next lines and omit the option [pdf-a] if you are using an up-to-date LaTeX platform
+%% STRONGLY RECOMMENDED new pdf management code follows.
+%% This addition the LaTeX kernel was made in June 2022 by the LaTeX Project team.
+%% https://www.latex-project.org/news/latex2e-news/ltnews35.pdf
+%% Uncomment the next lines and omit the option [pdf-a] from \documentclass[...]{asemconf}
%\DocumentMetadata{%
% pdfstandard=A-3b,% A-2b, A-2u, A-3b, or A-3u (don't use u options with LuaLaTeX)
@@ -102,7 +108,7 @@
%% Remove the [colorlinks] option before *final* submission to ASME, to get black text for printing,
%% but keep that option for other uses.
-\documentclass[balance,upint,subscriptcorrection,varvw,mathalfa=cal=boondoxo,spanish,french,vietnamese,russian,greek,pdf-a,colorlinks]{asmeconf}
+\documentclass[pdf-a,balance,colorlinks,upint,subscriptcorrection,varvw,mathalfa=cal=boondoxo, spanish,french,vietnamese,russian,greek]{asmeconf}
%%%%% pdf metadata %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -123,11 +129,11 @@
% You can comment these out if for some reason you don't want a header.
% Use title case (first letters capitalized), not all capitals
-\ConfName{Proceedings of the ASME 2023\linebreak International Mechanical Engineering Congress and Exposition}
-\ConfAcronym{IMECE2023}
-\ConfDate{October 29--November 2, 2023} % update
-\ConfCity{New Orleans, LA} % update
-\PaperNo{IMECE2023-XXXX}
+\ConfName{Proceedings of the ASME 2024\linebreak International Mechanical Engineering Congress and Exposition}
+\ConfAcronym{IMECE2024}
+\ConfDate{November 17--21, 2024} % update
+\ConfCity{Portland, OR} % update
+\PaperNo{IMECE2024-XXXX}
% Units of measure (e.g., cm) and other specialty lowercase terms in the title should be
% enclosed in \NoCaseChange{...} to maintain lower case type
@@ -183,7 +189,7 @@
%% Abstract should be 200 words or less
\begin{abstract}
-This paper is an example of and a {\upshape\LaTeX} template for typesetting ASME conference papers using the {\upshape\texttt{asmeconf}} class. This {\upshape\LaTeX} template follows ASME guidelines for margins, fonts, headings, captions, and reference formats as of 2022. The class is intended to be used with the {\upshape\texttt{asmeconf.bst} \hologo{BibTeX}} style for reference formatting, which is part of this distribution. The template produces pdfs that contain hyperlinks, bookmarks, and metadata; and references can include the DOI and URL fields. Links may be colored, for online use, or black, for publication. The class enables inline author names, following ASME's current style, but can also produce the traditional grid style. Options include line numbering, final column balancing, various math options, government copyright, and archivability (PDF/A). In addition, section headers may contain mathematics, references, citations, and footnotes. The class is compatible with {\upshape\hologo{pdfLaTeX}} or {\upshape\hologo{LuaLaTeX}}.
+This paper is an example of and a {\upshape\LaTeX} template for typesetting ASME conference papers using the {\upshape\texttt{asmeconf}} class. This {\upshape\LaTeX} template follows ASME guidelines for margins, fonts, headings, captions, and reference formats as of 2024. The class is intended to be used with the {\upshape\texttt{asmeconf.bst} \hologo{BibTeX}} style for reference formatting, which is part of this distribution. The template produces pdfs that contain hyperlinks, bookmarks, and metadata; and references can include the DOI and URL fields. Links may be colored, for online use, or black, for publication. The class enables inline author names, following ASME's current style, but can also produce the traditional grid style. Options include line numbering, final column balancing, various math options, government copyright, and archivability (PDF/A). In addition, section headers may contain mathematics, references, citations, and footnotes. The class is compatible with {\upshape\hologo{pdfLaTeX}} or {\upshape\hologo{LuaLaTeX}}.
\end{abstract}
%%%%%%%%% NOMENCLATURE (OPTIONAL) %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -256,8 +262,8 @@
%% captions go below figures
\begin{figure}
-\centering\includegraphics[width=0.7\linewidth]{sample-figure-1.pdf}
-\caption{Caption with math, eqn.~\eqref{eqn:fourier}: $z = (r,\phi)$ \cite{Lienhard2019b}}\label{fig:1}
+\centering\includegraphics[width=\linewidth, alt = {Linearization error in radiant flux}]{sample-figure-1.pdf}
+\caption{Caption with math, eqn.~\eqref{eqn:fourier}: $\Delta T/T_m$ vs.\ $\Delta T/T_1$~\cite{Lienhard2019}}\label{fig:1}
\end{figure}
%%%%%%%%%%%%% end figure %%%%%%%%%%%%%%%%%%%
@@ -393,24 +399,21 @@
%%%%%%%%%%%%%%%%% begin two column figure %%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{figure*}
-\begin{subfigure}[t]{0.5\textwidth} % subfigure is basically the same as minipage
-\vbox{
-\vspace*{1.7em}
+\begin{subfigure}[b]{\columnwidth}% subfigure is basically the same as minipage
\centering{
- \includegraphics{sample-figure-2a.pdf}
-}%
-\vspace*{1.7em}
-}%
-\subcaption{Interior region\label{fig:interior-region}}
+ \includegraphics[width=0.9\linewidth, alt={Nusselt number data for isothermal wall}]{sample-figure-2a.pdf}%
+}
+\subcaption{Uniform temperature wall\label{fig:interior-region}}
\end{subfigure}%
-%%%%%%%%%%%%% no spaces or line breaks between these two subfigures
-\begin{subfigure}[t]{0.5\textwidth}
+\hspace*{\columnsep}% with this space added, puts each figure at column center
+%%%%%%%%%%%%% no line break between these two subfigures
+\begin{subfigure}[b]{\columnwidth}
\centering{%
-\includegraphics{sample-figure-2b.pdf}
+\includegraphics[width=0.927\linewidth, alt={Nusselt number data for constant heat flux wall}]{sample-figure-2b.pdf}%
}%
-\subcaption{Exterior region\label{fig:exterior-region}}
+\subcaption{Uniform heat flux wall with unheated starting length\label{fig:exterior-region}}
\end{subfigure}
-\caption{A figure with two subfigures \cite{lienhard2023}\label{fig:2}}
+\caption{A figure with two subfigures~\cite{lienhard2020}\label{fig:2}}
\end{figure*}
%%%%%%%%%%%%%%%%%%% end two column figure %%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -480,8 +483,10 @@
Note that ASME interprets the author order in the grid style by reading names from left-to-right in the top row, then left-to-right in each subsequent row.
-\subsection{Changing the Copyright Footer} The option \texttt{[nofoot]} will omit the ASME copyright from the page footer. The option \texttt{[govt]} will produce a copyright notice for authors who are employees of the U.\ S.\ Government. The option \texttt{[contractor]} will produce a copyright
+\subsection{Changing the Copyright Footer} The option \texttt{[nofoot]} will omit the ASME copyright from the page footer. The option \texttt{[govt]} will produce a copyright notice for authors who are employees of the U.\ S.\ Government.
+The option \texttt{[contractor]} will produce a copyright
notice for authors who are employed by a U.\ S.\ Government contractor.
+The option \texttt{[somegovt]} gives a copyright notice for the case when only some authors are employees of the U.\ S.\ Government.
The footers are generated with the \texttt{fancyhdr} package~\cite{oostrum} and can be changed using the commands of that package. Only the default arrangement matches ASME's style, however.
@@ -493,13 +498,11 @@
As of late 2021, the \LaTeX 3 team is phasing in native support for PDF/A in the \LaTeX\ kernel, which will make these
class options unnecessary when using up-to-date installations.
-\subsection{Superiors Font} The \texttt{newtxtext} package includes a superiors font (both numbers and letters) for use in footnote markers and text superscripts. To enable this font, use the option \texttt{[nodefaultsups]}.
+\subsection{Typewriter Font Options} This font is the sans-serif \texttt{inconsolata}. By default, the word spacing is variable, but option \texttt{[mono]} ends this behavior. A slashed zero is the default; option \texttt{[var0]} removes the slash. Option \texttt{[hyphenate]} enables hyphenation. (The hyphenation option is not available under \hologo{LuaLaTeX} with \texttt{fontspec}.)
-\subsection{Typewriter Font Options} This font is the sans-serif \texttt{inconsolata}. By default, the word spacing is variable, but option \texttt{[mono]} ends this behavior. A slashed zero is the default; option \texttt{[var0]} removes the slash. Option \texttt{[hyphenate]} enables hyphenation. (The hyphenation option is not available if the \texttt{[fontspec]} option is used.)
+\subsection{Support for Other Languages} This package can be adapted to incorporate (or entirely use) languages other than English. See Appendix \ref{appendix:c} for details.
-\subsection{Support for Other Languages} This package can be adapted to incorporate (or entirely use) languages other than English. See Appendix \ref{appendix:b} for details.
-
%%%%% Conclusions %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Conclusion}
@@ -544,14 +547,31 @@
\end{align}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\section{Multilingual Support}\label{appendix:b}
+\section[Use with LuaLaTeX]{Use with \NoCaseChange{\hologo{LuaLaTeX}}}\label{appendix:b}
+The \hologo{LuaLaTeX} engine is useful with \texttt{asmeconf} in two situations:
+
+\begin{description}
+
+\item \textbf{Executing lua code directly in your \LaTeX\ file.} With lua code, complicated functions can be plotted or numerical integration can be executed. An example file in the distribution demonstrates this capability~\cite{lienhard2024}. In this situation, \textit{be sure to use the class option} \texttt{[nofontspec]}, so that you won't need to install additional fonts on your computer.
+
+\item \textbf{Using complex alphabets.} With \hologo{pdfLaTeX}, the \texttt{asmeconf} package supports Latin alphabets, as well as Cyrillic, Greek, and Vietnamese. If you need scripts such as Arabic, Chinese, or Japanese, \hologo{LuaLaTeX} with the \texttt{fontspec} package can use fonts installed in your computer operating system. See the example file in this distribution for more details~\cite{lienhard2021}.
+
+\end{description}
+
+For clarity, \texttt{fontspec} is automatically loaded when \texttt{asmeconf} is run under \hologo{LuaLaTeX}. Fontspec requires that the necessary system fonts are already installed in your operating system. If you wish to use \hologo{LuaLaTeX} without bothering about system fonts, use the class option \texttt{[nofontspec]}.
+
+Access to \hologo{LuaLaTeX} is different in each \LaTeX\ platform. Check the documentation for your specific platform to see how to access various typesetting engines.
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+\section{Multilingual Support}\label{appendix:c}
+
ASME publishes in English, but the \texttt{babel} package is loaded for
users who may wish to include other languages. For example, an author might wish to include an appendix that provides the
abstract in another language.
When more than one language option is included in \verb|\documentclass[..]{asmeconf}|, English will be
-assumed to be the main language of the document. (To choose a different main language, set \texttt{[main=..]}).
+set as the document's main language. (To choose a different main language, set \texttt{[main=..]}).
If no language options are given, the package defaults to English. As examples, a passage in French is
shown in \selectlanguage{french}\appendixname~\ref{app:fourier}\selectlanguage{english}, followed by
\ifpdftex abstracts in Spanish, Greek, Russian, and Vietnamese.\else abstracts in other languages.\fi
@@ -558,10 +578,10 @@
The input encoding can be utf-8, as for these glyphs:
%% If you have trouble with the next line, your file may not be saved in utf-8 format. You can delete that line to resolve the issue.
-\typeout{If you have trouble with the next line, your file may not be saved in utf-8 format. You can delete that line to resolve the issue. Under LuaLaTeX, you can load the [fontspec] option if you have the relevant systems fonts installed}%
+\typeout{If you have trouble with the next line, your file may not be saved in utf-8 format. You can delete that line to resolve the issue. Under LuaLaTeX, you can load the fontspec will support these characters if you have the relevant systems fonts installed}%
àáâäæãåā èéęëêēė îïíīįì ôöòóœøōõ ûüùúū çćč ł ñń ßśš ÿ žźż.
-Fonts similar to Times/Helvetica are automatically used when the Greek, Vietnamese, or selected cyrillic-alphabet languages are called as options under {\upshape\hologo{pdfLaTeX}}. Using {\upshape\hologo{LuaLaTeX}} with the \texttt{[fontspec]} option, many additional scripts are available; see the supplemental notes for such usage~\cite{lienhard2021}. Possibilities include Arabic, Bengali, Chinese, Devanagari (e.g., for Hindi), Hangul (for Korean), Kana (for Japanese), and Tamil. \textit{The {\upshape\texttt{[fontspec]}} option requires a \LaTeX\ installation dated October 2020 or later.}
+Fonts similar to Times/Helvetica are used when Greek, Vietnamese, or selected cyrillic-alphabet languages are called as options under {\upshape\hologo{pdfLaTeX}}. Using {\upshape\hologo{LuaLaTeX}}, which loads the fontspec package, many additional scripts are available; see the supplemental notes for such usage~\cite{lienhard2021}. Possibilities include Arabic, Bengali, Chinese, Devanagari (e.g., for Hindi), Hangul (for Korean), Kana (for Japanese), and Tamil. (Note: some fonts are not PDF/A compliant.) \textit{These options require a \LaTeX\ installation dated October 2020 or later.}
The bibliography style, \texttt{asmeconf.bst}, is designed in English and aimed at \hologo{BibTeX}.
% Multilingual bibliographies can be supported using \texttt{BibLaTeX}.
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-fontspec.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-fontspec.tex 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-fontspec.tex 2024-02-07 21:01:17 UTC (rev 69733)
@@ -13,12 +13,12 @@
%%
%% LICENSE:
%%
-%% Copyright (c) 2021 John H. Lienhard
+%% Copyright (c) 2024 John H. Lienhard
%% Offered under the MIT license: https://ctan.org/license/mit
%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\documentclass[colorlinks,nofoot,fontspec,spanish,japanese,russian,greek,ukrainian,vietnamese,french,portuguese,turkish,polish,indonesian,italian,german,latin,serbianc,bidi=basic]{asmeconf}
+\documentclass[colorlinks,nofoot,spanish,japanese,russian,greek,ukrainian,vietnamese,french,portuguese,turkish,polish,indonesian,italian,german,latin,serbianc,bidi=basic]{asmeconf}
% note that not all languages given as examples in this file can be called as options.
\hypersetup{%
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-lualatex-ode-example.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-lualatex-ode-example.tex 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-lualatex-ode-example.tex 2024-02-07 21:01:17 UTC (rev 69733)
@@ -4,21 +4,25 @@
%%
%% This file is an example of using asmeconf with lualatex to solve and plot an ode in a landscape figure.
%%
+%% Use of an up-to-date LaTeX distribution (after 2020) is strongly recommended.
+%%
%% Author: John H. Lienhard V
%% Department of Mechanical Engineering
%% Massachusetts Institute of Technology
%% Cambridge, MA 02139-4307 USA
%%
+%% Version 1.01, 6 February 2024
+%%
%=========================================================
%%
%% LICENSE:
%%
-%% Copyright (c) 2021 John H. Lienhard
+%% Copyright (c) 2024 John H. Lienhard
%% Offered under the MIT license: https://ctan.org/license/mit
%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\documentclass[grid,colorlinks,nofoot]{asmeconf}
+\documentclass[nofontspec,grid,colorlinks,nofoot]{asmeconf}
\hypersetup{%
pdftitle={Example of asmconf with LuaLaTeX to solve an ODE},
@@ -27,8 +31,8 @@
}
\usepackage[figuresright]{rotating}% to use a landscape figure
+\usepackage{luacode}% for compatibility with older installations
-
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Now use lua code
@@ -156,11 +160,11 @@
\title{Example of \NoCaseChange{{\upshape\hologo{LuaLaTeX}}} with asmeconf.cls for ODE Integration}
\SetAuthors{John H.\ Lienhard V\affil{1}\CorrespondingAuthor{lienhard at mit.edu}}
-\SetAffiliation{1}{Department of Mechanical Engineering, Massachusetts Institute of Technology, Cambridge, MA}
+\SetAffiliation{1}{Department of Mechanical Engineering \\ Massachusetts Institute of Technology \\ Cambridge, MA}
\maketitle
-\versionfootnote{Version~1.01, \today}
+\versionfootnote{Version~1.02, \today}
\keywords{asmeconf, \hologo{LuaLaTeX}, ODE, pgfplots, landscape}
@@ -226,7 +230,7 @@
\addlegendentry[fill=white]{$\mathsf{A = 1}$}
\end{axis}
\end{tikzpicture}
-\caption{\MakeUppercase{A trial of pgfplot with Luacode Runge-Kutta integration}\label{fig:1}}
+\caption{\MakeUppercase{A trial of pgfplot with Luacode Runge-Kutta integration}}\label{fig:1}
\end{sidewaysfigure*}
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.tex 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/doc/latex/asmeconf/examples/asmeconf-wide-equation-example/asmeconf-template-widetext.tex 2024-02-07 21:01:17 UTC (rev 69733)
@@ -7,8 +7,6 @@
%% * \begin{widetext[N] .. changes upper/lower separation of wide material from default 5pt to Npt
%% * \begin{widetext}[][tbn]: t = top line only; b = bottom line only; n = no lines. BOTH arguments are REQUIRED, even if first is left empty.
%%
-%% asmewide,sty supports one option, [raggedend], which suppresses final page column balancing: \usepackage[raggedend]{asmewide}
-%%
%% The widetext environment can only appear once per page. It clashes with floats and footnotes, as discussed herein.
%%
%% NB: the strip environment from cuted is incompatible with the [lineno] option to asmeconf!
@@ -16,7 +14,7 @@
\documentclass[nofoot,colorlinks,balance,pdf-acolorlinks,balance,pdf-a]{asmeconf}
\def\ACwidetextversion{1.1}
-\def\ACwidetextdate{September 14, 2022}
+\def\ACwidetextdate{February 15, 2022}
\usepackage{lipsum}% Latin filler text
\usepackage{asmewide}
@@ -116,7 +114,7 @@
\centering{\includegraphics{tesseral-harmonic.pdf}}%
\subcaption{\label{fig:tesseral}}%
\end{subfigure}%
-\caption{A figure with two subfigures: (a) Zonal harmonic $n=1, m=0$, (b) Tesseral harmonic $n=2, m=3$. See Appendix~\ref{sec:sph-har}.}\label{fig:1}
+\caption{A figure with two subfigures: (a) Zonal harmonic $n=1, m=0$, (b) Tesseral harmonic $n=2, m=3$. See Appendix~\ref{sec:sph-har}.\label{fig:1}}
\end{figure*}
%%%%%%%%%%%%%%%%%%% end two column figure %%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -267,7 +265,7 @@
%%%%%%%%%%%%%%%%%%% begin linewidth table %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{table}[b]
\newcolumntype{C}{>{$}c<{$}} % math-mode version of "c" column type, from array package
-\caption{Table at full column width with columns in math mode}\label{tab:3}
+\caption{\label{tab:3}Table at full column width with columns in math mode}
\centering{%
\begin{tabular*}{\linewidth}{@{\extracolsep{\fill}}CCCC@{\extracolsep{\fill}}}
\hline\hline
@@ -322,7 +320,7 @@
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\appendix
-\section{Spherical harmonics}\label{sec:sph-har}
+\section{Spherical harmonics\label{sec:sph-har}}
Without getting into the details, a regular function $f(\theta,\phi)$ on the surface of the unit sphere may be written
\begin{equation}
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-1.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-2a.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/doc/latex/asmeconf/sample-figure-2b.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/tex/latex/asmeconf/asmeconf.cls
===================================================================
--- trunk/Master/texmf-dist/tex/latex/asmeconf/asmeconf.cls 2024-02-07 21:01:06 UTC (rev 69732)
+++ trunk/Master/texmf-dist/tex/latex/asmeconf/asmeconf.cls 2024-02-07 21:01:17 UTC (rev 69733)
@@ -2,11 +2,11 @@
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%
%% This file provides the asmeconf LaTeX class for formatting conference papers according to
-%% ASME conference requirements as represented on ASME's conference web pages in 2022.
+%% ASME conference requirements as represented on ASME's conference web pages in 2024.
%%
%% This file's version and date:
- \def\versionno{1.36}
- \def\versiondate{2023/11/19\space}
+ \def\versionno{1.37}
+ \def\versiondate{2024/02/06\space}
%%
%% Author: John H. Lienhard, V
%% Department of Mechanical Engineering
@@ -27,10 +27,10 @@
%% 10. Enable various math and text features from the newtxmath and newtxtext packages
%% 11. Support inclusion of passages in languages other than English
%%
-%% This class is compatible with either pdfLaTeX or LuaLaTeX. FontSpec may be loaded as an option (to
-%% access language-specific fonts), but the class does not support unicode-math.
+%% This class is compatible with either pdfLaTeX or LuaLaTeX. Fontspec will load automatically with LuaLaTeX,
+%% but the class does not support unicode-math. To use LuaLaTeX without fontspec, call the [nofontspec] option.
%%
-%% Use an up-to-date LaTeX distribution: for pdfLaTeX, TeX Live 2016 or later; for LuaLaTeX, TeX Live 2021 or later.
+%% Use an up-to-date LaTeX distribution: for pdfLaTeX, TeX Live 2020 or later; for LuaLaTeX, TeX Live 2021 or later.
%% A complete LaTeX installation is also recommended: asmeconf loads ~30 packages, in addition to LaTeX core packages.
%% All packages required by the class are in TeXLive and CTAN (https://ctan.org/).
%%
@@ -37,9 +37,6 @@
%% Commands for entering conference headers and author names are specific to this class.
%% See asmeconf-template.tex for details.
%%
-%% The \section[]{} command's optional argument is changed to better support pdf bookmarks,
-%% and \section* is modified similarly.
-%%
%% The class defines abstract (with keywords), abstract* (no keywords), and nomenclature environments.
%% The latter has an optional argument to control the space between the entries and the definitions.
%%
@@ -47,7 +44,7 @@
%%
%% LICENSE:
%%
-%% Copyright (c) 2023 John H. Lienhard
+%% Copyright (c) 2024 John H. Lienhard
%%
%% Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
%% associated documentation files (the "Software"), to deal in the Software without restriction,
@@ -72,84 +69,101 @@
\LoadClass[twoside,twocolumn,10pt]{article}
% Even/odd page layout is not used in ASME's specs, although the papers are printed in two-sided format.
-\ifdefined\NewDocumentCommand\else
- \RequirePackage{xparse} % enable older installations to access features recently moved into LaTeX kernel
-\fi
+\RequirePackage{iftex}% provides \ifpdftex (many) & \ifluatex (once)
+\RequirePackage{ifthen}% ifthenelse (many) & \whiledo (once)
+\RequirePackage{etoolbox}% using patchcmd in 4 places
-\RequirePackage{etoolbox}
-\RequirePackage{ifthen}
%%%%%%%%%%%%% Test compatibility of older distributions %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\providecommand\IfFormatAtLeastTF{\@ifl at t@r\fmtversion}% compare version to date
+\providecommand\IfFormatAtLeastTF{\@ifl at t@r\fmtversion}% compare version to date; \If... added to latex 2020/10/01
+\providecommand\IfPackageAtLeastTF{\@ifpackagelater}% compare version to date; \If... added to latex 2020/10/01
+\providecommand\IfPackageLoadedTF{\@ifpackageloaded}% \If...added to latex 2021/11/15
-\IfFormatAtLeastTF{2017/04/15}{%
- \ClassInfo{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX distributions 2020 or later are strongly recommended for best results}
+\IfFormatAtLeastTF{2020/10/01}{%
+ \ClassInfo{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX distributions 2020/10/01 or later are strongly recommended for best results}
}{%
- \ClassIF{asmeconf}{Your LaTeX format is dated \fmtversion. Formats dated 2020 or later are recommended for the asmeconf class. Older formats may generate errors}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/. You can try to click past the errors for now.}%
+ \ClassError{asmeconf}{Your LaTeX format is dated \fmtversion. Formats dated 2020/10/01 or later are recommended for the asmejour class. Older formats and packages may generate errors or fail entirely!}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/. You can try to click past the errors for now.}%
}
-
+
+\ifdefined\NewDocumentCommand\else
+ \RequirePackage{xparse}% enable older installations to access features in LaTeX kernel since 2020/10/01; but need at least 2018/04...
+\fi
+
\DeclareDocumentCommand\LogNote{m}{%
- \IfFormatAtLeastTF{2021/11/01}{%
- \ClassNoteNoLine{asmeconf}{#1}%
+ \IfFormatAtLeastTF{2021/11/15}{%
+ \ClassNoteNoLine{asmeconf}{#1}% Added to LaTeX in Nov. 2021
}{%
\ClassWarningNoLine{asmeconf}{#1}%
}
}
-%% provide iftex command \ifpdftex for those still running old distributions
-\IfFormatAtLeastTF{2019/11/07}{%
- \RequirePackage{iftex}[2019/11/07]% check whether pdftex or another engine is used
- }{%
- \LogNote{The asmeconf class requires the missing package iftex---trying a work-around.}
- % Code copied from iftex package written by the LaTeX3 Project (used under LPPL).
- \def\IFTEX at let#1#2{%
- \expandafter\let\csname if#1\expandafter\endcsname
- \csname if#2\endcsname}
- % pdftex (including in dvi mode)
- \begingroup\expandafter\expandafter\expandafter\endgroup
- \expandafter\ifx\csname pdftexversion\endcsname\relax
- \IFTEX at let{pdftex}{false}
- \else
- \IFTEX at let{pdftex}{true}
- \fi
- \IFTEX at let{PDFTeX}{pdftex}
+\IfPackageAtLeastTF{iftex}{2019/11/07}{\relax}{%
+ \ClassError{asemconf}{Package iftex is too old. Go to \string https://ctan.org and download an up-to-date version.}%
}
+%% Test whether \DocumentMetadata has been loaded (Thank you Ulrike Fischer)
+\newif\if at asme@pdfmanagement
+% \IfPDFManagementActiveTF{\@asme at pdfmanagementtrue}{\@asme at pdfmanagementfalse}% New 2021/07/23, don't implement yet
+\ExplSyntaxOn
+ \IfFormatAtLeastTF{2020/02/02}{%
+ \bool_if:nTF
+ {
+ \bool_lazy_and_p:nn
+ {\cs_if_exist_p:N \pdfmanagement_if_active_p:}
+ { \pdfmanagement_if_active_p: }
+ }
+ {
+ \@asme at pdfmanagementtrue
+ }
+ {
+ \@asme at pdfmanagementfalse
+ }
+ }{\@asme at pdfmanagementfalse}
+\ExplSyntaxOff
+
+
%%%%%%%%%%%%%% Options for the class %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\RequirePackage{kvoptions}
\SetupKeyvalOptions{
- family=asmeconf,
- prefix=asmeconf@,
- family=pdfaopt,
- prefix=pdafopt@,
- setkeys=\kvsetkeys,
+ family=asmeconf,
+ prefix=asmeconf@,
+ setkeys=\kvsetkeys,
}
%%% set key [colorlinks] to have colored hyperlinks, rather than black links (use a key with new pdfmanagement, 2021/12/01)
\define at key{asmeconf}{colorlinks}[colorlinks]{%
- \PassOptionsToPackage{#1}{hyperref}%
+ \PassOptionsToPackage{#1}{hyperref}%
}
-%%% for mathalfa, we may now pass options in this format: mathalfa=cal=euler, mathalfa=frak=boondox
-\define at key{asmeconf}{mathalfa}{%
- \PassOptionsToPackage{#1}{mathalfa}%
-}
+%% Option for caption text not to use boldface type [unboldcaption]
+\DeclareBoolOption{unboldcaption}
-%%% set key [nodefaultsups] to obtain newtx superiors font for footnotes.
-\newboolean{DefaultSups}\setboolean{DefaultSups}{true}
-\define at key{asmeconf}{nodefaultsups}[false]{%
- \setboolean{DefaultSups}{#1}
-}
+%% Option to obtain line numbers [lineno]
+\DeclareBoolOption{lineno}
-%%% set key [unboldcaption] for caption text not to use boldface type.
-\newif\ifac at unboldcaption\ac at unboldcaptionfalse
-\define at key{asmeconf}{unboldcaption}[false]{%
- \ac at unboldcaptiontrue
-}
-% (with two key families active, \DeclareBoolOption has problems..)
+%% Option to balance column height on last page [balance]
+\DeclareBoolOption{balance}
+%% Option to convert inline author data to a grid of authors
+\DeclareBoolOption{grid}
+
+%% Option for copyright notice if all authors are government employees [govt]
+\DeclareBoolOption{nofoot}
+
+%% Option for copyright notice if all authors are government employees [govt]
+\DeclareBoolOption{govt}
+
+%% Option for copyright notice if some (not all) authors are government employees [govtsome]
+\DeclareBoolOption{govtsome}
+
+%% Option for government contractor copyright notice [contractor]
+\DeclareBoolOption{contractor}
+
+%% Option NOT to use fontspec package under luaLaTeX [nofontspec]
+\DeclareBoolOption{nofontspec}
+
%%% Use these switches to load other alphabets for Cyrillic, Greek, Japanese, and Vietnamese text
\newif\ifac at cyrillic\ac at cyrillicfalse
\newif\ifac at greek\ac at greekfalse
@@ -189,29 +203,12 @@
}
\define at key{asmeconf}{vietnamese}[]{%
\RequirePackage[vietnamese=nohyphenation]{hyphsubst}% using key, not option, to allow loading package w/o babel warning.
- \PassOptionsToPackage{vietnamese}{babel}%
+ \PassOptionsToPackage{vietnamese.noencoding}{babel}% modified.noencoding suppresses unnecessary warning about inputenc
\ac at vietnamesetrue
\def\ac at Tfive{T5}%
}
-%%% only main= is actually needed, but keeping these legacy commands for backward compatibility
-\define at key{asmeconf}{lang}[english]{% deprecated option
- \PassOptionsToPackage{main=#1,#1}{babel}%
- \PassOptionsToPackage{pdflang=en}{hyperref}
- \ac at mainsettrue%
- \ifthenelse{\equal{#1}{english}}{%
- \relax}{%
- \LogNote{Selecting #1 as the primary language}%
- }%
-}
-\define at key{asmeconf}{lang-second}[english]{% deprecated option
- \PassOptionsToPackage{#1}{babel}%
-}
-\define at key{asmeconf}{lang-third}[english]{% deprecated option
- \PassOptionsToPackage{#1}{babel}%
-}
-
-\DeclareDefaultOption{}% suppress warning about unused mathalfa option, 2021/06/15
+\DeclareDefaultOption{}% suppress warnings about unused options
\ProcessKeyvalOptions{asmeconf}
%% if main language was not chosen explicitly, default to English
@@ -225,35 +222,181 @@
\def\@KeyFamily{asmeconf}
\NewDocumentCommand\ac at DisableOption{m}{%
\DisableKeyvalOption[%
- action=ignore,%
- class=asmeconf%
+ action=ignore,%
+ class=asmeconf%
]{#1}{\@KeyFamily}%
}
\NewDocumentCommand\@DisableKeys{>{\SplitList{;}}m}{\ProcessList{#1}{\ac at DisableOption}}
-\@DisableKeys{main;lang;nodefaultsups;mathalfa;lang-second;lang-third;vietnamese}
+\@DisableKeys{colorlinks;unboldcaption;lineno;balance;grid;nofoot;govt;govtsome;contractor;nofontspec;main;vietnamese}
+%%%%%%%%% Various font-related options %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+\SetupKeyvalOptions{
+ family=acfonts,
+ prefix=acfonts@,
+ setkeys=\kvsetkeys,
+}
+
+%%% for mathalfa, we may now pass options in this format: mathalfa=cal=euler, mathalfa=frak=boondox
+\define at key{acfonts}{mathalfa}{%
+ \PassOptionsToPackage{#1}{mathalfa}%
+}
+
+%% option for slightly larger small capitals font, via newtxtext
+\DeclareOption{largesc}{%
+ \ifpdftex
+ \PassOptionsToPackage{largesc=true}{newtxtext}% largesc is a boolean key in newtxtext
+ \else
+ \ClassWarningNoLine{asmeconf}{largesc option is not available under luaLateX. It will be ignored}%
+ \fi
+}
+
+%% Disable newtxtext osf option, which is not appropriate for documents in this class
+\DeclareOption{osf}{%
+ \PassOptionsToPackage{lining}{newtxtext}%
+}
+
+%% option to hyphenate the inconsolata typewriter font [hyphenate] and to issue a warning when that's done.
+\DeclareOption{hyphenate}{%
+ \ifac at fontspec
+ \ClassWarningNoLine{asmeconf}{hyphenate option is not supported by fontspec, will be ignored}%
+ \else
+ \PassOptionsToPackage{hyphenate}{inconsolata}% hyphenate is a key via xkeyval in inconsolata
+ \LogNote{Allowing hyphenation of typewriter font}%
+ \fi
+}
+%% option for monospacing in inconsolata typewriter font [mono].
+\DeclareOption{mono}{%
+ \ifac at fontspec
+ \def\MonoNotMono{}%
+ \else
+ \PassOptionsToPackage{mono}{inconsolata}% mono is a key via xkeyval in inconsolata
+ \fi
+}
+%% option for unslashed zero in inconsolata typewriter font [var0].
+\DeclareOption{var0}{%
+ \ifac at fontspec
+ \def\ssztwo{+ss02}% stylistic alternate for regular zero
+ \else
+ \PassOptionsToPackage{var0}{inconsolata}% var0 is a key via xkeyval in inconsolata
+ \fi
+}
+
+\ProcessKeyvalOptions{acfonts}%
+\def\@KeyFamily{acfonts}
+\@DisableKeys{mathalfa;largesc;osf;hyphenate;mono;var0}
+
+
+%%%%%%% PDF/A Compliance Options %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+%% new pdf management in LaTeX, with \DocumentMetaData{..}, is preferred to this approach.
+
+\newif\ifac at setpdfa\ac at setpdfafalse
+\newif\ifac at pdfaone\ac at pdfaonefalse
+
+\if at asme@pdfmanagement\else
+
+ \SetupKeyvalOptions{
+ family=pdfaopt,
+ prefix=pdafopt@,
+ setkeys=\kvsetkeys,
+ }
+ \ifpdftex %% PDF/A compliance has only been configured for pdflatex
+ %
+ %%% set key [pdfa] to activate pdf/a compliance (default is pdf/A-3u)
+ \define at key{pdfaopt}{pdf-a}[true]{%
+ \IfFormatAtLeastTF{2018/12/01}{\relax}{%
+ \ClassError{asmeconf}{Your LaTeX format is dated \fmtversion. Formats dated 2018/12/01 or later are necessary for the [pdf-a] option. Older formats may generate errors}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/. Meanwhile, you can remove the [pdf-a] option and try again}%
+ }
+ \ac at setpdfatrue
+ \PassOptionsToPackage{pdfa}{hyperref}
+ \AtBeginDocument{\hypersetup{pdfapart=3,pdfaconformance=u}}% note: hyperref takes these options if hyperxmp is loaded
+ }
+ %%% to select part 1, 2 or 3
+ \define at key{pdfaopt}{pdfapart}[3]{%
+ \def\asmeconf at tempa{#1}
+ \AtBeginDocument{\hypersetup{pdfapart=\asmeconf at tempa}}
+ \ifthenelse{\equal{#1}{1}}{\ac at pdfaonetrue}{\relax}%
+ }
+ %%% to select conformance b or u. NB: a is not possible with pdfLaTeX, and u is not possible with 1.
+ \ExplSyntaxOn
+ \define at key{pdfaopt}{pdfaconformance}[u]{%
+ \str_set:Ne \l_tmp_str { \str_uppercase:n {#1} }
+ % \typeout{\l_tmp_str}
+ \AtBeginDocument{\hypersetup{pdfaconformance=\l_tmp_str}}
+ }
+ \ExplSyntaxOff
+ \else
+ \define at key{pdfaopt}{pdf-a}[true]{%
+ \ac at setpdfatrue
+ }
+ \fi
+
+ \ProcessKeyvalOptions{pdfaopt}%
+
+ %% Done with these keys, so we can now disable them
+ \def\@KeyFamily{pdfaopt}
+ \@DisableKeys{pdf-a;pdfapart;pdfaconformance}
+\fi
+
+
+%%%%%%%%%%%% PDF/A compliance related %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+\if at asme@pdfmanagement\else
+ \ifpdftex
+ \ifac at pdfaone
+ \pdfminorversion=4 % for pdf/a-1 need version 4, not 7
+ \else
+ \pdfminorversion=7 % this selection is not essential.
+ \fi
+ \else
+ \ifluatex
+ \ifac at setpdfa\ClassWarningNoLine{asmeconf}{pdf-a option requires pdfLaTeX engine. Under LuaLaTeX, use %
+ \protect\DocumentMetadata{pdfstandard=A-3b} before \protect\documentclass[..]{asmeconf}}%
+ \fi
+ \directlua{
+ if pdf.getminorversion() \string~= 7 then
+ if (status.pdf_gone and status.pdf_gone > 0)
+ or (status.pdf_ptr and status.pdf_ptr > 0) then
+ tex.error("PDF version cannot be changed anymore")
+ else
+ pdf.setminorversion(7)
+ end
+ end
+ }
+ \else
+ \ClassError{asmeconf}{Please use either pdfLaTeX or LuaLaTeX}{This class has NOT been configured to support other engines, and the results will be unpredictable. Exit and rerun using either pdfLaTeX or LuaLaTeX.}%
+ \fi
+ \fi
+\fi
+
+
%%%%%%%%%%%%% More Language options %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% option to use fontspec [fontspec] (for complex language-specific fonts)
\newif\ifac at fontspec\ac at fontspecfalse
\newif\iffontspecloaded\fontspecloadedfalse% so user can test in .tex file
-\DeclareOption{fontspec}{%
- \ifpdftex
- \ClassWarningNoLine{asmeconf}{fontspec option requires LuaLaTeX, will be ignored under pdfLaTeX}%
+
+\ifpdftex
+ \ifasmeconf at nofontspec
+ \ClassWarningNoLine{asmeconf}{The [nofontspec] option requires LuaLaTeX. It will be ignored under pdfLaTeX}%
+ \fi
+\else
+ \ifasmeconf at nofontspec
+ \ClassWarningNoLine{asmeconf}{The [nofontspec] option has been issued. LuaLaTeX will run without font support}%
\else
- \IfFormatAtLeastTF{2020/10/01}{%
- \ClassInfo{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX distributions after 2020 are needed with [fontspec] for language support}
+ \IfFormatAtLeastTF{2020/10/01}{%
\ac at fontspectrue
\fontspecloadedtrue
\def\ssztwo{}% for Inconsolatazi4; default uses slashed zero, +ss02 uses regular zero
\def\MonoNotMono{WordSpace={1,1.33,1.67}}% for Inconsolatazi4; default allows word spacing (is not mono)
- }{%
- \ClassError{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX installations dated 2020/10/01 or later are needed for the [fontspec] option. Option [fontspec] will be ignored. Language support will be minimal}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/}%
- }
+ }{%
+ \ClassError{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX installations dated 2020/10/01 or later are needed to run LuaLaTeX with the fontspec package. Fontspec will NOT be loaded. Language support will be minimal}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/. You may alternatively choose the [nofontspec] option.}%
+ }
\fi
-}
+\fi
\DeclareOption{japanese}{% mainly to control loading of fontspec options
\ifac at fontspec
@@ -260,7 +403,7 @@
\PassOptionsToPackage{japanese}{babel}%
\ac at japanesetrue
\else
- \ClassWarningNoLine{asmeconf}{japanese option is supported only with the [fontspec] option + LuaLaTeX. It will be ignored}%
+ \ClassWarningNoLine{asmeconf}{[japanese] option is supported only under LuaLaTeX with fontspec. It will be ignored}%
\fi
}
@@ -301,148 +444,12 @@
%
\DeclareOption{tamil}{\ClassError{asmeconf}{Do not specify "tamil" as a class option}{Babel does not have an ldf file for Tamil. Instead, specify "tamil" when you call the language within your document. No class option is needed.}}
-
-%%%%%%% PDF/A Compliance Options %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-
-\newif\ifac at setpdfa\ac at setpdfafalse
-\newif\ifac at pdfaone\ac at pdfaonefalse
-
-\ifpdftex %% PDF/A compliance has only been configured for pdflatex
-%
- %%% set key [pdfa] to activate pdf/a compliance (default is pdf/A-3u)
- \define at key{pdfaopt}{pdf-a}[true]{%
- \IfFormatAtLeastTF{2018/12/01}{%
- \ClassInfo{asmeconf}{Your LaTeX format is dated \fmtversion. LaTeX distributions 2019 or later are necessary with the [pdf-a] option}
- }{%
- \ClassError{asmeconf}{Your LaTeX format is dated \fmtversion. Formats dated 2018/12/01 or later are necessary for the [pdf-a] option. Older formats may generate errors}{Please UPDATE your LaTeX distribution to obtain best results. TeX Live is available for download at no charge: \string https://www.tug.org/texlive/. Meanwhile, you can remove the [pdf-a] option and try again}%
- }
- \ac at setpdfatrue
-% \PassOptionsToPackage{pdfa,pdfapart=3,pdfaconformance=u}{hyperref}% note: hyperref takes these options if hyperxmp is loaded
- \PassOptionsToPackage{pdfa}{hyperref}% note: hyperref takes these options if hyperxmp is loaded
- \AtBeginDocument{\hypersetup{pdfapart=3,pdfaconformance=u}}
- }
- %%% to select part 1, 2 or 3
- \define at key{pdfaopt}{pdfapart}[3]{%
-% \PassOptionsToPackage{pdfapart=#1}{hyperref}%
- \def\asmeconf at tempa{#1}
- \AtBeginDocument{\hypersetup{pdfapart=\asmeconf at tempa}}
- \ifthenelse{\equal{#1}{1}}{\ac at pdfaonetrue}{\relax}%
- }
- %%% to select conformance b or u. NB: a is not possible with pdfLaTeX, and u is not possible with 1.
- \ExplSyntaxOn
- \define at key{pdfaopt}{pdfaconformance}[u]{%
-% \PassOptionsToPackage{pdfaconformance=#1}{hyperref}%
- \str_set:Ne \l_tmp_str { \str_uppercase:n {#1} }
-% \typeout{\l_tmp_str}
- \AtBeginDocument{\hypersetup{pdfaconformance=\l_tmp_str}}
- }
- \ExplSyntaxOff
-\else
- \define at key{pdfaopt}{pdf-a}[true]{%
- \ac at setpdfatrue
- }
-\fi
-
-\ProcessKeyvalOptions{pdfaopt}%
-
-%% Done with these keys, so we can now disable them
-\def\@KeyFamily{pdfaopt}
-\@DisableKeys{pdf-a;pdfapart;pdfaconformance}
-
-
-%%%%%%%%% Miscellaneous options %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-
-%%% option to balance column height on last page [balance]
-\newif\ifac at balance\ac at balancefalse
-\DeclareOption{balance}{%
- \ac at balancetrue
- \LogNote{Loading flushend package to balance column height on last page}%
-}
-
-%%% option to obtain line numbers [lineno]
-\newif\ifac at lineno\ac at linenofalse
-\DeclareOption{lineno}{\ac at linenotrue}
-
-%% option to omit ASME footer [nofoot]
-\newif\ifac at nofoot\ac at nofootfalse
-\DeclareOption{nofoot}{\ac at nofoottrue}
-
-
-%%% option [contractor] to obtain government contractor copyright notice.
-\newif\ifac at contractor\ac at contractorfalse
-\DeclareOption{contractor}{\ac at contractortrue}
-
-%%% option [govt] to obtain government employee copyright notice.
-\newif\ifac at govt\ac at govtfalse
-\DeclareOption{govt}{\ac at govttrue}
-
-%% option to convert inline author data to a grid of authors
-\newboolean{grid}\setboolean{grid}{false}
-\DeclareOption{grid}{%
- \setboolean{grid}{true}%
- \LogNote{Selected option for a grid of author blocks}%
-}
-%% option to directly use grid of authors
-\newboolean{Oldauthors}\setboolean{Oldauthors}{false}
-\DeclareOption{authorgrid}{%
- \setboolean{Oldauthors}{true}%
- \LogNote{Selected option for a grid of author blocks}%
-}
-\DeclareOption{oldauthors}{%% deprecated, but retained for backward compatibility
- \setboolean{Oldauthors}{true}%
- \LogNote{Selected option for a grid of author blocks}%
-}
-
-%% option for slightly larger small capitals font, via newtxtext
-\DeclareOption{largesc}{%
- \ifac at fontspec
- \ClassWarningNoLine{asmeconf}{largesc option is not available under fontspec, will be ignored}%
- \else
- \PassOptionsToPackage{largesc=true}{newtxtext}% largesc is a boolean key in newtxtext
- \fi
-}
-
-%% Disable newtxtext osf option, which is not appropriate for documents in this class
-\DeclareOption{osf}{%
- \PassOptionsToPackage{lining}{newtxtext}%
-}
-
-%% option to hyphenate the typewriter font [hyphenate] and to issue a warning when that's done.
-\DeclareOption{hyphenate}{%
- \ifac at fontspec
- \ClassWarningNoLine{asmeconf}{hyphenate option is not supported by fontspec, will be ignored}%
- \else
- \PassOptionsToPackage{hyphenate}{inconsolata}% hyphenate is a key via xkeyval in inconsolata
- \LogNote{Allowing hyphenation of typewriter font}%
- \fi
-}
-%% option for monospacing in typewriter font [mono].
-\DeclareOption{mono}{%
- \ifac at fontspec
- \def\MonoNotMono{}%
- \else
- \PassOptionsToPackage{mono}{inconsolata}% mono is a key via xkeyval in inconsolata
- \fi
-}
-%% option for unslashed zero typewriter font [var0].
-\DeclareOption{var0}{%
- \ifac at fontspec
- \def\ssztwo{+ss02}% stylistic alternate for regular zero
- \else
- \PassOptionsToPackage{var0}{inconsolata}% var0 is a key via xkeyval in inconsolata
- \fi
-}
-
-\ifthenelse{\boolean{DefaultSups}}{%
- \ifac at fontspec\relax\else
- \PassOptionsToPackage{defaultsups=true}{newtxtext}% defaultsups is a boolean key in newtxtext
- \fi}{\relax}
-
%% Suppress warnings about unused global options
\DeclareOption*{}
-\ProcessOptions \relax
+\ProcessOptions \relax %% end of options section
+
%%%%%%%%%%%%% Geometry, bibliography, graphics, colors %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\RequirePackage[letterpaper, left=0.5in, right=0.5in, top=0.5in, bottom = 1.in, footskip=0.5in, columnsep=0.38in]{geometry}
@@ -452,9 +459,18 @@
\RequirePackage[sort&compress,numbers]{natbib}
\setlength\bibsep{1pt plus 1pt minus 1pt}
-\RequirePackage{graphicx} % remove obsolete options, 2023/11/19
+\RequirePackage{graphicx} % removed obsolete options, 2023/11/19
\RequirePackage[dvipsnames,svgnames,x11names]{xcolor}
+% Allow pre 2021/11/15 formats to see the graphicx alt key without causing an error, in preparation for tagged pdf
+\IfFormatAtLeastTF{2021/11/15}{
+ \relax
+}{
+ \AtBeginDocument{
+ \IfPackageLoadedTF{graphicx}{\define at key{Gin}{alt}{}}{\relax}
+ }
+}
+
%%%%%%%%%%%% Table related %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\RequirePackage{booktabs}
@@ -464,41 +480,12 @@
\newcolumntype{d}[1]{D{.}{.}{#1}}% NB: This conflicts with babel's Spanish language option which makes "." an active character.
% To use "," separator, put this command in your preamble: \newcolumntype{d}[1]{D{,}{,}{#1}}
-%%%%%%%%%%%% PDF/A compliance related %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\ifpdftex % moved fontenc 2021/01/31
- \ifac at pdfaone
- \pdfminorversion=4 % for pdf/a-1 need version 4, not 7
- \else
- \pdfminorversion=7 % this selection is not essential.
- \fi
- \RequirePackage[\ac at TtwoA,\ac at LGR,\ac at Tfive,T1]{fontenc}% T2A - Cyrillic (w/o babel warning); LGR - Greek; T5 - Vietnamese; put T1 last 22/03/10
- \RequirePackage[utf8]{inputenc} % for backward compatibility with pre-2018 LaTeX distributions
-\else
- \ifluatex
- \ifac at setpdfa\ClassWarningNoLine{asmeconf}{pdf-a option requires pdfLaTeX engine. Under LuaLaTeX, use %
- \protect\DocumentMetadata{pdfstandard=A-3b} before \protect\documentclass[..]{asmeconf}}%
- \fi
- \directlua{
- if pdf.getminorversion() \string~= 7 then
- if (status.pdf_gone and status.pdf_gone > 0)
- or (status.pdf_ptr and status.pdf_ptr > 0) then
- tex.error("PDF version cannot be changed anymore")
- else
- pdf.setminorversion(7)
- end
- end
- }
- \else
- \ClassError{asmeconf}{Please use either pdfLaTeX or LuaLaTeX}{This class has NOT been configured to support other engines, and the results will be unpredictable. Your best course of action is to exit and rerun using either pdfLaTeX or LuaLaTeX.}%
- \fi
-\fi
-
%%%%%%%%% Caption related %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-%% Needs to come before babel messes with captions, to keep uppercase text. 2021/12/25
+%% Needs to come before babel messes with the captions, to keep uppercase text. 2021/12/25
-\ifx\AddToNoCaseChangeList\@undefined % updated July 3, see https://github.com/John02139/asmeconf/issues/5
+\ifx\AddToNoCaseChangeList\@undefined % updated 2022/07/03, see https://github.com/John02139/asmeconf/issues/5
\RequirePackage{textcase} %% Allows uppercase titles and captions without errors from math and citations
\typeout{Asmeconf is loading textcase package.}
\else
@@ -512,7 +499,7 @@
\DeclareCaptionTextFormat{boldmath}{\mathversion{sansbold}#1}
\DeclareCaptionTextFormat{sansmath}{\mathversion{sans}#1}
-\ifac at unboldcaption
+\ifasmeconf at unboldcaption
\captionsetup[figure]{labelformat=uppercase,labelfont={sf,bf,small},textfont={sf,md,small},textformat=sansmath,labelsep=colon}
\captionsetup[table]{labelformat=uppercase,labelfont={sf,bf,small},textfont={sf,md,small},textformat=sansmath,labelsep=colon,skip=0.5\baselineskip}
\else
@@ -531,8 +518,13 @@
\RequirePackage{mathtools}% loads and extends amsmath
-%\def\BabelCaseHack{} %see https://github.com/latex3/babel/issues/193; using this will affect Medieval Latin and a few other languages.
-% Babel update has corrected this issue 24 October 2022.
+\ifpdftex
+ % must load before babel
+ \RequirePackage[\ac at TtwoA,\ac at LGR,\ac at Tfive,T1]{fontenc}
+ % T2A - Cyrillic (w/o babel warning); LGR - Greek; T5 - Vietnamese; put T1 last 2022/03/10
+ \IfFormatAtLeastTF{2018/04/01}{\relax}{\RequirePackage[utf8]{inputenc}}
+\fi
+
\RequirePackage[]{babel}
\ifpdftex
@@ -931,45 +923,32 @@
BoldItalicFont = *-Bold,% has no italic face
]{NotoSansTamil}
%
- \babelprovide[import, captions/abstract = Muhtasari, language = Default]{swahili}
+ \babelprovide[import, captions/abstract = Muhtasari, language = Default]{swahili}
%
- \else % use lualatex without font support for other languages (easier set-up and still enables luacode for numerics)
- % extensive edits 2022/03/14
+ \else % use lualatex without support for system fonts (easier set-up and still enables luacode for numerics)
+ % dropped newtxtext completely, 2024/01/19
\renewcommand*\rmdefault{ntxtlf} % roman font for math
\RequirePackage[T1]{fontenc} % qhv and zi4 are not TU encoded, 2021/12/24
- \DeclareFontFamily{T1}{\sfdefault}{} % sf for math
+ \DeclareFontFamily{T1}{\sfdefault}{} % sf for math
\DeclareFontShape{T1}{\sfdefault}{m}{n}{<-> s*[0.94] ec-qhvr}{} %% see t1qhv.fd; 0.9-->0.94 2022/01/15
+ \DeclareFontShape{T1}{\sfdefault}{b}{n}{<-> s*[0.94] ec-qhvb}{} %% see t1qhv.fd; 0.9-->0.94 2022/01/15
+ \DeclareFontShape{T1}{\sfdefault}{bx}{n}{<-> s*[0.94] ec-qhvb}{} %% see t1qhv.fd; 0.9-->0.94 2022/01/15
\DeclareFontFamily{T1}{zi4}{}% typewriter (Inconsolata)
\DeclareFontShape{T1}{zi4}{m}{n}{<-> s*[1.05] t1-zi4r-5}{}% with options varl and var qu
\DeclareFontShape{T1}{zi4}{b}{n}{<-> s*[1.05] t1-zi4b-5}{}
\DeclareFontShape{T1}{zi4}{bx}{n}{<-> s*[1.05] t1-zi4b-5}{}
\RequirePackage[]{newtxmath} % options will be as passed from newtx
- \RequirePackage[type1text,nofontspec,helvratio=0.91]{newtxtext}% will lose some accented characters this way ... better to use fontspec
- \@ifpackagelater{newtxtext}{2022/02/28}{\relax}{%
- \ClassWarning{asmeconf}{Your copy of the newtxtext package is older than 2022/02/28, so you will see error messages about unknown options 'type1text' and 'nofontspec'. You can click through these for now, but I recommend you update your LaTeX installation for best results.}
- }
\providecommand*{\DeclareFontFamilySubstitution}[3]{\relax}% folks with old latex formats will get a different typewriter font...
\AtBeginDocument{%
\DeclareFontFamilySubstitution{T1}{\ttdefault}{zi4}
}
- \fi
+ \fi
\fi
\RequirePackage[]{mathalfa}% load optional fonts for Calligraphy, Script, Fraktur. Key format: mathalfa=cal=euler (etc.)
\RequirePackage{bm}% load after all math to give further access to bold math
-%% option not to use latex default superscripts; if fontspec loaded, use the superiors package.
-\ifthenelse{\boolean{DefaultSups}}{\relax}{%
- \ifac at fontspec
- \RequirePackage{superiors}% must come after text font is loaded
- \else
- \relax
- \fi
-}
-%% override \textsu if using default superiors
-\ifthenelse{\boolean{DefaultSups}}{\let\textsu\textsuperscript}{\relax}
-
%% Ensure that the current font is used for equation tags, not \normalfont as set by amsmath
\def\maketag@@@#1{\hbox{\m at th#1}}
@@ -1043,27 +1022,39 @@
\renewcommand{\headrulewidth}{0pt}
\renewcommand{\footrulewidth}{0pt}
-\ifac at govt
+\ifasmeconf at govt
\newgeometry{left=0.5in, right=0.5in, top=0.5in, bottom = 1.in, footskip = 0.3in, columnsep = 0.38in}
\fancyfoot[RO,RE]{}
\fancyfoot[CE,CO]{\@SetFont\thepage\\[1ex]\small This material is declared a work of the U.\ S.~Government and is not subject to copyright protection in the United States.\\Approved for public release; distribution is unlimited.}
\fi
-\ifac at contractor
+\ifasmeconf at contractor
\newgeometry{left=0.5in, right=0.5in, top=0.5in, bottom = 1.in, footskip = 0.3in, columnsep = 0.38in}
\fancyfoot[RO,RE]{}
\fancyfoot[CE,CO]{\@SetFont\thepage\\[1ex]\footnotesize The United States Government retains, and by accepting the article for publication, the publisher acknowledges that the United States Government retains, a non-exclusive, paid-up, irrevocable, worldwide license to publish or reproduce the published form of this work, or allow others to do so, for United States Government purposes.}
\fi
-\ifac at nofoot
+% was missing from earlier versions...?
+\ifasmeconf at govtsome
+ \newgeometry{left=0.5in, right=0.5in, top=0.5in, bottom = 1.in, footskip = 0.3in, columnsep = 0.38in}
+ \fancyfoot[RO,RE]{}
+ \fancyfoot[CE,CO]{\@SetFont\thepage\\[1ex]\small This work was authored in part by a U.\ S.\ Government employee in the scope of his/her employment. ASME disclaims all interest in the U.\ S.\ Government's contribution.}
+\fi
+
+\ifasmeconf at nofoot
\fancyfoot[RO,RE]{}
\fi
-%%%%%% footnotes %%%%%%%
-\RequirePackage{fnpos}
-\makeFNbottom
-\makeFNbelow
+%%%%%% Footnotes %%%%%%%
+\RequirePackage{footmisc}%
+\IfPackageAtLeastTF{footmisc}{2022/02/05}{
+ \PassOptionsToPackage{belowfloats}{footmisc}%
+ }{ \RequirePackage{fnpos}
+ \makeFNbottom
+ \makeFNbelow
+ }%
+\setlength\footnotemargin{2ex}% reduce indentation of footnotes, from footmisc
\setlength{\skip\footins}{\baselineskip}% <=== per ASME, 1 extra line
\renewcommand{\footnoterule}{%
@@ -1071,12 +1062,15 @@
\hrule width 0.5in height 0.4pt
\kern 2pt
}
+
+%% include a comma for sequential footnotes. 2024/01/18
+\ExplSyntaxOn
+ \cs_new:Npn \__asmeconf_NoteComma:n { \peek_meaning:NT \footnote { \textsuperscript{\mdseries,} } }
+ \cs_new_eq:NN \__savefootnote \footnote
+ \cs_gset_protected:Npn \footnote #1 { \__savefootnote{#1} \__asmeconf_NoteComma:n }
+\ExplSyntaxOff
-%% reduce indentation of footnotes
-\RenewDocumentCommand\@makefntext{m}{%
- \noindent\makebox[2ex][r]{\@makefnmark}#1}% <== To discourage hyphenation, do \hyphenpenalty=300\exhyphenpenalty=300 before #1
-
%%%%%%%%% Section headings %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% wish to accommodate hyperref
@@ -1102,35 +1096,16 @@
\titleformat{\section}{\mathversion{sansbold}\bfseries\sffamily\raggedright}{\MakeTextUppercase{\appendixname}\ \thesection.}{0.5em}{\MakeTextUppercase}
}
-%% This patches titlesec's unprotected re-definition of \footnote. See discussion here: https://github.com/jbezos/titlesec/issues/48
+%% This patches titlesec's unprotected re-definition of \footnote.
+%% See discussion here: https://github.com/jbezos/titlesec/issues/48
%% Without this patch, recent versions of LaTeX will require \protect\footnote in section headings.
+%% This issue may be corrected in titlesec, but keeping the patch anyway.
\patchcmd{\ttl at select}{\def\footnote}{\protected\def\footnote}{\typeout{Asmeconf.sty patched titlesec to have protected def of footnote}}{}
%%%%%%%%%% Hyperref, bookmarks, and PDF/A %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\newif\if at asme@pdfmanagement% Thanks to Ulrike Fischer
-
-% New 2021/07/23, don't implement yet
-% \IfPDFManagementActiveTF{\@asme at pdfmanagementtrue}{\@asme at pdfmanagementfalse}
-
-\ExplSyntaxOn
- \IfFormatAtLeastTF{2020/02/02}{%
- \bool_if:nTF
- {
- \bool_lazy_and_p:nn
- {\cs_if_exist_p:N \pdfmanagement_if_active_p:}
- { \pdfmanagement_if_active_p: }
- }
- {
- \@asme at pdfmanagementtrue
- }
- {
- \@asme at pdfmanagementfalse
- }
- }{\@asme at pdfmanagementfalse}
-\ExplSyntaxOff
-
+%% new pdf management in LaTeX, with \DocumentMetaData{..}, is preferred to this *legacy* approach.
\ifpdftex
%%% to assist with unicode glyph mapping, following M. Sharpe's recommendation in the newtx documentation.
\IfFormatAtLeastTF{2020/10/01}{\relax}{%
@@ -1141,7 +1116,7 @@
\InputIfFileExists{glyphtounicode-ntx.tex}{}{} %% additional mappings
\ifac at setpdfa
- %%%% the pdfmanagement options are experimental, from Ulrike Fischer 2021/06/12
+ %%%% pdfmanagement options, from Ulrike Fischer 2021/06/12
\if at asme@pdfmanagement
\ClassInfo{asmeconf}{pdfmanagement is defined. Class file will not load a color profile}
\else
@@ -1163,11 +1138,9 @@
\fi
\fi
-
\RequirePackage[psdextra]{hyperref} % recent kernel transition suggests providing most hyperref options via \hypersetup,
% but setting psdextra here (for additional math support in bookmarks) 2021/12/01
\hypersetup{%
- unicode, % Unicode encoded PDF strings
pdfborder={0 0 0},%
bookmarksnumbered=true,%
bookmarksopen=true,
@@ -1191,27 +1164,29 @@
\providecommand\hrefurl[2]{\href{#1}{#2}}% to address certain issues around URL recognition with new pdf management code, 2021/12/02
-\RequirePackage{hyperxmp}% improve transfer of metadata to pdf
-
-% Patch bug in hyperxmp, unless a more recent version is used.
-\ifdefined\hyxmp at no@bad at parts% \hyxmp at no@bad at parts is not def'd in TeX Live 2019 or older
- \@ifpackagelater{hyperxmp}{2022/10/15}{% v5.11 or later
- \relax
-% \ClassInfo{asmeconf}{hyperxmp v5.11 or later is in use}
- }{%
- \newcount\hypxmp at tempcnt
- \define at key{Hyp}{pdfapart}{%
- \afterassignment\hyxmp at no@bad at parts\hypxmp at tempcnt=0#1\relax
- \hyxmp at pdfstringdef\@pdfapart{\the\hypxmp at tempcnt}%
+\if at asme@pdfmanagement
+ \ClassInfo{asmejour}{pdfmanagement is defined. Class file will not load hyperxmp}
+\else
+ \RequirePackage{hyperxmp}% improve transfer of metadata to pdf
+
+ % Patch bug in hyperxmp, unless a more recent version is used.
+ \ifdefined\hyxmp at no@bad at parts% \hyxmp at no@bad at parts is not def'd in TeX Live 2019 or older
+ \@ifpackagelater{hyperxmp}{2022/10/15}{% v5.11 or later
+ \relax
+ }{%
+ \newcount\hypxmp at tempcnt
+ \define at key{Hyp}{pdfapart}{%
+ \afterassignment\hyxmp at no@bad at parts\hypxmp at tempcnt=0#1\relax
+ \hyxmp at pdfstringdef\@pdfapart{\the\hypxmp at tempcnt}%
+ }
}
- }
-\else
- \relax
+ \else
+ \relax
+ \fi
\fi
-
%%% ==> recent and evolving development of \pdfstring removes all robust commands from bookmarks, so
-%%% the following interventions may become unnecessary over time (2021/12/01).
+%%% by early 2024, errors are not present; however, these commands serve to still suppress warnings.
%% Since \bm may be useful in headings, this fix will reduce frequency with which
%% alternate pdfstrings must be given in revised section command as \section[pdfstring]{texstring}
@@ -1219,34 +1194,39 @@
\def\bm#1#{\relax}%
}
-%% Let's disable \( and \) in pdf bookmarks, 2020/02/28
+% Let's disable \( and \) in pdf bookmarks, 2020/02/28
\pdfstringdefDisableCommands{%
\def\({\relax}%
\def\){\relax}%
}
-%% Let's also make sure \NoCaseChange in section headings won't break pdf bookmarks
+% Let's also make sure \NoCaseChange in section headings won't break pdf bookmarks
\pdfstringdefDisableCommands{%
\let\NoCaseChange\relax%
}
-%% Let's just remove citations from pdf bookmarks
+% Let's just remove citations from pdf bookmarks
\pdfstringdefDisableCommands{%
\def\cite{\@gobble}%
}
-%% Let's make sure footnotes in section headings don't break pdf bookmarks.
-\robustify{\footnote}
-% \patchcmd{\section}{\sectionmark}{\let\footnote\@gobble\sectionmark}{}{}% <== not really needed in this context, 2020/02/28
+%% Ensure that tag color does not follow \eqref into bookmarks, 2020/02/28
\pdfstringdefDisableCommands{%
+ \def\eqref#1{(\ref{#1})}%
+}
+
+% Let's make sure footnotes in section headings don't break pdf bookmarks.
+% Revised footnote command above is already robust
+\pdfstringdefDisableCommands{%
\def\footnote#1{}%
}
+
%% Let's also add \footnote to the \TextUppercase exception list, so that footnote text won't be capitalized
%% if given in section headings. Ditto for \eqref
%
-\ifx\AddToNoCaseChangeList\@undefined % updated July 3, see https://github.com/John02139/asmeconf/issues/5
+\ifx\AddToNoCaseChangeList\@undefined % updated 2022/07/03, see https://github.com/John02139/asmeconf/issues/5
\patchcmd{\@uclcnotmath}{\@nonchangecase\ref}{\@nonchangecase\ref\@nonchangecase\footnote}{\typeout{Asmeconf patched textcase nonchangecase to include footnote.}}{}
\patchcmd{\@uclcnotmath}{\@nonchangecase\ref}{\@nonchangecase\ref\@nonchangecase\eqref}{\typeout{Asmeconf patched textcase nonchangecase to include eqref.}}{} %% corrected 2020/01/24
\else
@@ -1253,56 +1233,47 @@
\AddToNoCaseChangeList{\eqref \footnote}
\fi
-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%% There should be no errors for section headings with \(, \), \cite, \ref, \eqref, \label, \footnote, \NoCaseChange, or \bm
-%%% Create an optional argument for unnumbered sections and set pdf bookmark (thru \addcontentsline).
-%%% The optional argument will manually set the pdf bookmark for that section; can be used to avoid hyperref
-%%% errors when macros are in section titles.
-%%% There should not be errors for $, \cite, \ref, \eqref, \label, \footnote, \NoCaseChange, or \bm with current constructions.
-\let\svsection\section
-\RenewDocumentCommand{\section}{s o m}{%
- \IfBooleanTF {#1}
- {\svsection*{#3}\phantomsection%
- {\IfNoValueTF {#2}
- {\addcontentsline{toc}{section}{#3}}
- {\addcontentsline{toc}{section}{#2}}% removed trailing space 2020/02/28
- }%
- }%
- {\IfNoValueTF {#2}
- {\svsection{#3}}
- {\svsection[#2]{#3}}%
- }%
-}
%%%%%%%%%%%%% Line numbering and balancing columns on last page %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-%%% Allow line numbering in AMS math environments.
-%%% postdisplaypenalty adjusted to avoid extra line number at end, see discussion here: https://tex.stackexchange.com/a/461192/
-%%% multline has some additional problem that puts an extra line number above it.
-
-\NewDocumentCommand{\@losepostpenalty}{}{\patchcmd{\linenomathWithnumbers}{\advance\postdisplaypenalty\linenopenalty}{}{}{}}
-
-\NewDocumentCommand{\@FixAMSMath}{m}{%
- \AtBeginEnvironment{#1}{\@losepostpenalty\linenomath}%
- \AtEndEnvironment{#1}{\endlinenomath}%
- \AtBeginEnvironment{#1*}{\@losepostpenalty\linenomath}%
- \AtEndEnvironment{#1*}{\endlinenomath}%
-}
-
-\NewDocumentCommand{\@FixAll}{>{\SplitList{;}}m}{\ProcessList{#1}{\@FixAMSMath}}
-
%%% Adjustments when lineno option is used
-\ifac at lineno%
+\ifasmeconf at lineno%
\RequirePackage[switch,mathlines]{lineno}
\renewcommand{\linenumberfont}{\normalfont\footnotesize\color{red}}
\AtBeginDocument{\linenumbers}
- \ClassWarningNoLine{asmeconf}{Package lineno loaded, so final column balancing is disabled}
- \@FixAll{align;alignat;gather;flalign;multline}
- \else
- \ifac at balance\RequirePackage{flushend}\fi % flushend is NOT compatible with lineno
+ \ifasmeconf at balance
+ \ClassWarningNoLine{asmeconf}{Package lineno loaded, so final column balancing will be disabled}%
+ \fi
+ %%% Patch to allow line numbering in AMS math environments.
+ %%% This patch is for lineno versions earlier than v5.2 [2023/05/19]. As of mid-2023, the lineno package
+ %%% has been corrected to account for the AMS math environments. Retaining temporarily for backward compatibility.
+ %%% postdisplaypenalty adjusted to avoid extra line number at end, see: https://tex.stackexchange.com/a/461192/
+ %%% multline has some additional problem that puts an extra line number above it.
+ \IfPackageAtLeastTF{lineno}{2023/05/19}{\relax}{
+ \NewDocumentCommand{\ac at losepostpenalty}{}{\patchcmd{\linenomathWithnumbers}{\advance\postdisplaypenalty\linenopenalty}{}{}{}}
+ %
+ \NewDocumentCommand{\ac at FixAMSMath}{m}{%
+ \AtBeginEnvironment{#1}{\ac at losepostpenalty\linenomath}%
+ \AtEndEnvironment{#1}{\endlinenomath}%
+ \AtBeginEnvironment{#1*}{\ac at losepostpenalty\linenomath}%
+ \AtEndEnvironment{#1*}{\endlinenomath}%
+ }
+ %
+ \NewDocumentCommand{\ac at FixAll}{>{\SplitList{;}}m}{\ProcessList{#1}{\ac at FixAMSMath}}
+ %
+ \ac at FixAll{align;alignat;gather;flalign;multline}
+ }
+\else
+ \ProvideDocumentEnvironment{linenomath}{}{}{}%
+ \ifasmeconf at balance
+ \RequirePackage{flushend}% flushend package is NOT compatible with lineno
+ \AtEndDocument{\flushcolsend}%
+ \LogNote{Calling flushend package to balance column height on last page}%
+ \fi%
\fi
-%%% Enable dropping lineno option without trashing .aux file
-\providecommand{\@LN at col}[1]{\relax}
+\providecommand{\@LN at col}[1]{\relax}% Enable dropping lineno option without trashing .aux file
\providecommand{\@LN}[2]{\relax}
@@ -1345,39 +1316,22 @@
\newlength\nomenwidth
\newlength\savitemsep
-%% ==> xparse "g" argument used in this version of \entry is deprecated; so have phased out this version, 2021/12/01
-%% If second argument of \entry is omitted, will produce an italicized heading (e.g. "Greek letters")
-%\NewDocumentCommand\entry{m g}{%
-% \IfNoValueTF{#2}{%
-% \itemsep3\p@ plus 1\p@ minus 1\p@%
-% \goodbreak\item[\itshape#1\hfill]\setlength\itemsep\savitemsep\@itempenalty=1000%
-% }{%
-% \item[#1\hfill]#2%
-% \@itempenalty=-\@lowpenalty%
-% }%
-%}
-
-\NewDocumentCommand\entry{m m}{%
- \ifblank{#2}{%
- \ClassWarningNoLine{asmeconf}{The command \protect\entry requires two arguments. To obtain a subheading, use \protect\EntryHeading}
- \itemsep3\p@ plus 1\p@ minus 1\p@%
- \goodbreak\item[\itshape#1\hfill]\setlength\itemsep\savitemsep\@itempenalty=1000%
- }{%
+\NewDocumentCommand\entry{m m}{% simplified greatly 2024/01/18
\item[#1\hfill]#2%
- \@itempenalty=-\@lowpenalty%
- }%
+ \@itempenalty=-\@lowpenalty
}
%% A separate command command for nomenclature subheadings
\NewDocumentCommand\EntryHeading{m}{%
- \itemsep3\p@ plus 1\p@ minus 1\p@%
- \goodbreak\item[\itshape#1\hfill]\mbox{}\setlength\itemsep\savitemsep\@itempenalty=1000%
+ \itemsep3\p@ plus 1\p@ minus 1\p@
+ \goodbreak\item[\itshape#1\hfill]\mbox{}%
+ \setlength{\itemsep}{\savitemsep}\@itempenalty=1000
}
%% Increase first optional argument to a dimension > 2em if wide entries cause undesired misalignment of columns.
%% Second optional argument can be used to rename the environment, e.g., to List of Symbols.
\NewDocumentEnvironment{nomenclature}{O{2em} O{\nomname}}{%
- \setlength\columnsep{2em}
+ \setlength{\columnsep}{2em}
\setlength{\nomenwidth}{#1}
\section*{#2}
\raggedright
@@ -1388,7 +1342,7 @@
\setlength{\labelwidth}{\nomenwidth}%
\setlength{\leftmargin}{\labelwidth}%
\addtolength{\leftmargin}{\labelsep}%
- \setlength\savitemsep\itemsep%
+ \setlength{\savitemsep}{\itemsep}%
}%
}{\end{list}\ignorespacesafterend}
@@ -1407,40 +1361,35 @@
\NewDocumentCommand\ConfCity{m}{\gdef\@ConfCity{#1}}
\providecommand\@ConfCity{\hbox{ }}
-\NewDocumentCommand\HeaderConfName{}{%
+\NewDocumentCommand\PaperNo{m}{\gdef\@PaperNo{#1}}
+\providecommand\@PaperNo{\protect\phantom{NO.}}
+
+\NewDocumentCommand\PaperTitle{m}{\gdef\@PaperTitle{#1}}
+\providecommand\@PaperTitle{\hbox{ }}
+
+\NewDocumentCommand\@HeaderTitle{}{%
+ {\bfseries\sffamily
\parbox{\linewidth}{%
- \raggedleft\bfseries\sffamily%
+ \raggedleft
\@ConfName\par%
\MakeTextUppercase{\@ConfAcronym}\par
- \@ConfDate\@ConfCity%
+ \@ConfDate\@ConfCity
}%
-}
-
-\NewDocumentCommand\PaperNo{m}{\gdef\@PaperNo{#1}}
-\providecommand\@PaperNo{\protect\phantom{NO.}}
-
-\NewDocumentCommand\paperno{}{%
\vspace*{2\baselineskip}
- \parbox{\linewidth}{\raggedleft\bfseries\sffamily\LARGE%
+ \parbox{\linewidth}{\raggedleft\LARGE
\MakeTextUppercase{\@PaperNo}%
}%
+ \vspace*{3\baselineskip}
+ \parbox{\linewidth}{\mathversion{sansbold}\centering{\large
+ \MakeTextUppercase{\@PaperTitle}\par}}%%% <=== extra \par to make font leading stick. See adjustment in \MakeTitle
+ }%
}
-\NewDocumentCommand\PaperTitle{m}{\gdef\@PaperTitle{#1}}
-\providecommand\@PaperTitle{\hbox{ }}
-
-\NewDocumentCommand\papertitle{}{%
-\vspace*{3\baselineskip}
-\parbox{\linewidth}{\mathversion{sansbold}\centering{\bfseries\sffamily\large%
-\MakeTextUppercase{\@PaperTitle}\par}%%% <=== extra \par to make font leading stick. See adjustment in \MakeTitle
- }%
-}
-
%%%%%%%%%%% Author and affiliation block %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\RequirePackage{xcoffins}
-%% To maintain compatibility with newtxtext superiors option, if used, save the definition (inline author style resets it)
+%% Inline author style resets the footnote mark; save the definitions so we can restore them later
\let\savethefootnote\thefootnote
\let\savemakefnmark\@makefnmark
@@ -1466,9 +1415,11 @@
}%
}
+
%%%% option to use the traditional grid layout of authors or the inline style
-\ifthenelse{\boolean{grid}\or\boolean{Oldauthors}}{% This command works better than \if... in this context.
+\ifasmeconf at grid
+ \LogNote{Selected option for a grid of author blocks}%
%%%%%%%%%%%%%%%%%%%% Gridded author layout %%%%%%%%%%%%%%%%%%%%%%%%%
@@ -1495,122 +1446,51 @@
\newlength{\coffinsep}% horizontal space between coffins
\setlength{\coffinsep}{0.03\textwidth}
- \ifthenelse{\boolean{grid}}{%
- \newcounter{authorcnt}
- \setcounter{authorcnt}{0}
+ \newcounter{authorcnt}
+ \setcounter{authorcnt}{0}
+
+ \NewDocumentCommand\SetAffiliation{mm}{\expandafter\xdef\csname af@#1\endcsname{#2}}% defines \af@#1 as Affiliation #2
+
+ \AtBeginDocument{% error control, when no author or empty \affil is given
+ \SetAffiliation{-1}{Missing author name!\\Or extra comma!}
+ \SetAffiliation{99}{Missing affiliation tag!!}
+ \SetAffiliation{100}{Missing number in affiliation!!}
+ }
+
+ \NewDocumentCommand\SetAuthors{>{\SplitList{,}}m}{\ProcessList{#1}{\@TagAutAff}}
- \NewDocumentCommand\SetAffiliation{mm}{\expandafter\xdef\csname af@#1\endcsname{#2}}% defines \af@#1 as Affiliation #2
-
- \AtBeginDocument{% error control, when no author or empty \affil is given
- \SetAffiliation{-1}{Missing author name!\\Or extra comma!}
- \SetAffiliation{99}{Missing affiliation tag!!}
- \SetAffiliation{100}{Missing number in affiliation!!}
- }
-
- \NewDocumentCommand\SetAuthors{>{\SplitList{,}}m}{\ProcessList{#1}{\@TagAutAff}}
-
- \NewDocumentCommand\@AuthNo{m}{%
- \ifblank{#1}{%
- \expandafter\xdef\csname aut@\theauthorcnt\endcsname{}%
- \expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{-1}
- \ClassWarning{asmeconf}{Missing author name, check for extra comma}%
- }{\expandafter\xdef\csname aut@\theauthorcnt\endcsname{#1}%
- }%
- }% defines \aut at authorcnt as Name #1
-
- \NewExpandableDocumentCommand\affil{m}{%
- \ifblank{#1}{%
- \expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{100}%
- }{\expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{#1}%
- }%
- }% defines \autaffil at authorcnt as #1 (unique association)
-
- \NewDocumentCommand\@TagAutAff{m}{%
- \addtocounter{authorcnt}{1}%
- \@AuthNo{#1}%
- }
- \NewDocumentCommand\@SetAuthorBlock{}{%
- \whiledo{\value{authorno}<\value{authorcnt}}{% starting with authorno = 0 ensures we reach authorcnt with +1
- \addtocounter{authorno}{1}%
- \SetVerticalCoffin{\authorblock}{0.3\textwidth}{%
- \centering\sffamily%
- \textbf{\ignorespaces\csname aut@\theauthorno\endcsname\ignorespaces}\\
+ \NewDocumentCommand\@AuthNo{m}{%
+ \ifblank{#1}{%
+ \expandafter\xdef\csname aut@\theauthorcnt\endcsname{}%
+ \expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{-1}
+ \ClassWarning{asmeconf}{Missing author name, check for extra comma}%
+ }{\expandafter\xdef\csname aut@\theauthorcnt\endcsname{#1}%
+ }%
+ }% defines \aut at authorcnt as Name #1
+
+ \NewExpandableDocumentCommand\affil{m}{%
+ \ifblank{#1}{%
+ \expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{100}%
+ }{\expandafter\xdef\csname autaffil@\theauthorcnt\endcsname{#1}%
+ }%
+ }% defines \autaffil at authorcnt as #1 (unique association)
+
+ \NewDocumentCommand\@TagAutAff{m}{%
+ \addtocounter{authorcnt}{1}%
+ \@AuthNo{#1}%
+ }
+ \NewDocumentCommand\@SetAuthorBlock{}{%
+ \whiledo{\value{authorno}<\value{authorcnt}}{% starting with authorno = 0 ensures we reach authorcnt with +1
+ \addtocounter{authorno}{1}%
+ \SetVerticalCoffin{\authorblock}{0.3\textwidth}{%
+ \centering\sffamily%
+ \textbf{\ignorespaces\csname aut@\theauthorno\endcsname\ignorespaces}\\
\ifcsname autaffil@\theauthorno\endcsname% in case the \affil command has been omitted
- \csname af@\csname autaffil@\theauthorno\endcsname\endcsname
+ \csname af@\csname autaffil@\theauthorno\endcsname\endcsname
\else
\csname af at 99\endcsname
\fi
- \par}
- \ifnum\value{authorno}=1
- \JoinCoffins\firstrowauthorblock[r,t]\authorblock[l,t]
- \else
- \ifnum\value{authorno}=2
- \JoinCoffins\firstrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \else
- \ifnum\value{authorno}=3
- \JoinCoffins\firstrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \fi
- \fi
- \fi
- \ifnum\value{authorno}=4
- \JoinCoffins\secondrowauthorblock[r,t]\authorblock[l,t]
- \else
- \ifnum\value{authorno}=5
- \JoinCoffins\secondrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \else
- \ifnum\value{authorno}=6
- \JoinCoffins\secondrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \fi
- \fi
- \fi
- \ifnum\value{authorno}=7
- \JoinCoffins\thirdrowauthorblock[r,t]\authorblock[l,t]
- \else
- \ifnum\value{authorno}=8
- \JoinCoffins\thirdrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \else
- \ifnum\value{authorno}=9
- \JoinCoffins\thirdrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \fi
- \fi
- \fi
- \ifnum\value{authorno}=10
- \JoinCoffins\fourthrowauthorblock[r,t]\authorblock[l,t]
- \else
- \ifnum\value{authorno}=11
- \JoinCoffins\fourthrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \else
- \ifnum\value{authorno}=12
- \JoinCoffins\fourthrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \fi
- \fi
- \fi
- \ifnum\value{authorno}=13
- \JoinCoffins\fifthrowauthorblock[r,t]\authorblock[l,t]
- \else
- \ifnum\value{authorno}=14
- \JoinCoffins\fifthrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \else
- \ifnum\value{authorno}=15
- \JoinCoffins\fifthrowauthorblock[r,t]\authorblock[l,t](\coffinsep,0pt)
- \fi
- \fi
- \fi
- \ifnum\value{authorno}>15
- \ClassWarningNoLine{asmeconf}{The class is programmed for up to 15 author blocks. If some of your authors are at the same institution, %
- you may put more than one name above a single address. If you need more than 15 author blocks, try using the in-line author style %
- instead of the [grid] option}
- \fi
- }% end whiledo
- }
- }{% end ifthen for grid, now do else for Oldauthors
- \NewDocumentCommand\SetAuthorBlock{mm}{%
- \addtocounter{authorno}{1}%
- \SetVerticalCoffin{\authorblock}{0.3\textwidth}{%
- \centering\sffamily%
- \textbf{\ignorespaces#1\ignorespaces}\\
- #2%
- }
+ \par}
\ifnum\value{authorno}=1
\JoinCoffins\firstrowauthorblock[r,t]\authorblock[l,t]
\else
@@ -1669,56 +1549,11 @@
\ifnum\value{authorno}>15
\ClassWarningNoLine{asmeconf}{The class is programmed for up to 15 author blocks. If some of your authors are at the same institution, %
you may put more than one name above a single address. If you need more than 15 author blocks, try using the in-line author style %
- instead of the [authorgrid] option}
+ instead of the [grid] option}
\fi
- }
-
- % Changed to follow syntax of the inline style, which is much easier to use! 2020/12/29
- % % allow for NO email address to be given by omitting second argument
- % \NewDocumentCommand{\CorrespondingAuthor}{m g}{%
- % \global\ac at CAtrue%
- % \IfNoValueTF{#2}{%
- % \gdef\@CAsep{\relax}%
- % \gdef\@CAemail{\relax}%
- % }{%
- % \gdef\@CAsep{:\space}%
- % \gdef\@CAemail{#2}%
- % }%
- % \ignorespaces#1\ignorespaces$\bm{^\ast}$%\footnotemark[1]%
- % }
-
- %%% to deal with sequential notes as, e.g., "1,*", or "1,2,*" %%%%%%%%%%
- % bug fixed 2020/12/29
- \newcommand\nextToken\relax
-
- \newcommand\isOthernote{%
- \ifx\CorrespondingAuthor\nextToken\textsuperscript{\sffamily\bfseries,}%
- \else%
- \ifx\JointFirstAuthor\nextToken\textsuperscript{\sffamily\bfseries,}%
- \fi%
- \fi%
- \ignorespaces%
- }
-
- \let\oldCorrespondingAuthor\CorrespondingAuthor
- \renewcommand\CorrespondingAuthor[1]{%
- \oldCorrespondingAuthor{#1}\futurelet\nextToken\isOthernote}
-
- \let\oldJointFirstAuthor\JointFirstAuthor
- \renewcommand\JointFirstAuthor{%
- \oldJointFirstAuthor\futurelet\nextToken\isOthernote}
-
- \let\oldfootnote\footnote
- \renewcommand\footnote[1]{%
- \oldfootnote{#1}\futurelet\nextToken\isOtherfnote}
-
- \newcommand\isOtherfnote{%
- \ifx\footnote\nextToken\textsu{\mdseries,}%
- \fi%
- }
- }%end ifthenelse
-
- \NewDocumentCommand\ConstructAuthorBlock{}{%
+ }% end whiledo
+ }
+ \NewDocumentCommand\@ConstructAuthorBlock{}{%
\ifnum\value{authorno}>3
\JoinCoffins\firstrowauthorblock[hc,b]\secondrowauthorblock[hc,t](0pt, -1.5\baselineskip)
\fi
@@ -1734,7 +1569,7 @@
\centerline{\TypesetCoffin\firstrowauthorblock}%% in this instance, \centerline is better than \centering
}
%%% otherwise use the new compact layout of authors
-}{% i.e., this begins "else"
+\else
%%%%%%%%%%%%%%%%%%%%%% New author layout (inline) %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\NewCoffin{\AuthorBlock}
@@ -1769,47 +1604,29 @@
}
%%% to deal with sequential notes as, e.g., "1,*", or "1,2,*" %%%%%%%%%%
- \let\oldaffil\affil
- \newcommand\nextToken\relax
-
- \renewcommand\affil[1]{%
- \oldaffil{#1}\futurelet\nextToken\isOthernote}
-
- \newcommand\isOthernote{%
- \ifx\CorrespondingAuthor\nextToken\textsuperscript{\sffamily\bfseries,}%
- \else%
- \ifx\JointFirstAuthor\nextToken\textsuperscript{\sffamily\bfseries,}%
- \else
- \ifx\affil\nextToken\textsuperscript{\sffamily\bfseries,}%
- \fi%
- \fi%
- \fi%
- \ignorespaces%
- }
-
- \let\oldCorrespondingAuthor\CorrespondingAuthor
- \renewcommand\CorrespondingAuthor[1]{%
- \oldCorrespondingAuthor{#1}\futurelet\nextToken\isOthernote}
-
- \let\oldJointFirstAuthor\JointFirstAuthor
- \renewcommand\JointFirstAuthor{%
- \oldJointFirstAuthor\futurelet\nextToken\isOthernote}
-
- \let\oldfootnote\footnote
- \renewcommand\footnote[1]{%
- \oldfootnote{#1}\futurelet\nextToken\isOtherfnote}
-
- \newcommand\isOtherfnote{%
- \ifx\footnote\nextToken\textsu{\mdseries,}%
- \fi%
- }
+ \ExplSyntaxOn
+ \cs_new:Npn \__asmecome_OtherNoteComma:n {
+ \peek_meaning:NTF \affil
+ { \textsuperscript{\mdseries,} }
+ { \peek_meaning:NTF \CorrespondingAuthor
+ { \textsuperscript{\mdseries,} }
+ { \peek_meaning:NT \JointFirstAuthor { \textsuperscript{\mdseries,} } }
+ }
+ }
+ \cs_new_eq:NN \__saveAF \affil
+ \cs_gset_protected:Npn \affil #1 { \__saveAF{#1} \__asmecome_OtherNoteComma:n }
+ \cs_new_eq:NN \__saveCA \CorrespondingAuthor
+ \cs_gset_protected:Npn \CorrespondingAuthor #1 { \__saveCA{#1} \__asmecome_OtherNoteComma:n }
+ \cs_new_eq:NN \__saveJA \JointFirstAuthor
+ \cs_gset_protected:Npn \JointFirstAuthor { \__saveJA \__asmecome_OtherNoteComma:n }
+ \ExplSyntaxOff
+
%%%
- \NewDocumentCommand\SetAuthorBlock{}{%
- \let\savethefootnote\thefootnote
+ \NewDocumentCommand\@SetAuthorBlock{}{%
\JoinCoffins\AuthorBlock[hc,b]\AffiliationsBlock[hc,t](0pt,-\baselineskip)
\centerline{\TypesetCoffin\AuthorBlock}
}
-} %% end ifthenelse for Oldauthors
+\fi % end if...else for grid
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -1817,31 +1634,25 @@
\NewDocumentCommand\MakeTitlePage{}{%
\twocolumn[
\begin{@twocolumnfalse}
- \HeaderConfName
- \paperno
- \papertitle
+ \@HeaderTitle
\vspace*{2\baselineskip}
- \ifthenelse{\boolean{Oldauthors}}{%
- \ConstructAuthorBlock}{%
- \ifthenelse{\boolean{grid}}{%
- \@SetAuthorBlock\ConstructAuthorBlock}{%
- \SetAuthorBlock}}
+ \ifasmeconf at grid
+ \@SetAuthorBlock\@ConstructAuthorBlock
+ \else
+ \@SetAuthorBlock
+ \fi
\vspace*{3\baselineskip}
\end{@twocolumnfalse}
]
- \let\@makefnmark\savemakefnmark
+ \let\@makefnmark\savemakefnmark% restore footnote mark font
\renewcommand*{\thefootnote}{\fnsymbol{footnote}}
\ifac at JA
- \ifDefaultSups\relax\else\ifac at fontspec\def\f@@tn at te{blub}\fi\fi% https://tex.stackexchange.com/a/565263/46356
\footnotetext[2]{\JAwords}
\fi
\ifac at CA
\footnotetext[1]{\CAwords\@CAsep\@CAemail}
\fi
- \ifDefaultSups\relax\else
- \ifac at fontspec\def\f@@tn at te{footnote}\fi
- \fi
- \let\thefootnote\savethefootnote
+ \let\thefootnote\savethefootnote% restore footnote symbol
}
%%%%%%%%%%
@@ -1852,10 +1663,10 @@
\RenewDocumentCommand{\thanks}{m}{\relax}% disabling this standard command (inconsistent with this format)
-%% Produces an unmarked footnote about the version date, to replace "date"
+%% \versionfootnote produces an unmarked footnote about the version date, to replace "date"
%% This tool is for editing and should not be used in the final draft
-%% This version provides working hyperlink, but throws warning; also, \gdef -->\def. 2021/12/09
+%% This form provides working hyperlink, but it throws warning; also, \gdef -->\def. 2021/12/09
%\NewDocumentCommand\versionfootnote{m}{\def\@thefnmark{}\@footnotetext{#1}}
%% A hyperlink in this footnote will not function, since NoHyper is used to suppress 'missing anchor' warning
@@ -1955,7 +1766,8 @@
%%%%%%%%%%%%%%%%%% Times-like fonts for specific languages %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-\ifpdftex % Under lualatex, babel has problems with the following approach. Use [fontspec] option instead.
+\ifpdftex % Under lualatex, babel has problems with the following approach, which assumes that fontspec has not been loaded.
+ % Recommend not to choose the [nofontspec] option.
% Several modifications made in response to newtx v1.71, 2022/03/14
\ifac at vietnamese
%
@@ -1968,7 +1780,6 @@
\DeclareFontFamilySubstitution{T5}{\rmdefault}{qtm} % new in 02/20/2020 format of LaTeX! Need to test.
\DeclareFontFamilySubstitution{T5}{\ttdefault}{qcr}
}
- % 2021/12/24 removed substitute font package
% Vietnamese is in T5 encoding, can use Tex Gyre Termes font (qtm);
% qhv = Heros (helvetica). We get the right font w/o loading this.
% qcr = Cursor (monospaced) is poor match to inconsolata; qhv (the sf font) matches better, but isn't monospaced.
More information about the tex-live-commits
mailing list.