texlive[42128] Master/texmf-dist: nameauth (22sep16)

commits+karl at tug.org commits+karl at tug.org
Thu Sep 22 23:36:19 CEST 2016


Revision: 42128
          http://tug.org/svn/texlive?view=revision&revision=42128
Author:   karl
Date:     2016-09-22 23:36:19 +0200 (Thu, 22 Sep 2016)
Log Message:
-----------
nameauth (22sep16)

Modified Paths:
--------------
    trunk/Master/texmf-dist/doc/latex/nameauth/Makefile
    trunk/Master/texmf-dist/doc/latex/nameauth/README
    trunk/Master/texmf-dist/doc/latex/nameauth/README.txt
    trunk/Master/texmf-dist/doc/latex/nameauth/examples.tex
    trunk/Master/texmf-dist/doc/latex/nameauth/nameauth.pdf
    trunk/Master/texmf-dist/source/latex/nameauth/nameauth.dtx
    trunk/Master/texmf-dist/source/latex/nameauth/nameauth.ins
    trunk/Master/texmf-dist/tex/latex/nameauth/nameauth.sty

Modified: trunk/Master/texmf-dist/doc/latex/nameauth/Makefile
===================================================================
--- trunk/Master/texmf-dist/doc/latex/nameauth/Makefile	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/doc/latex/nameauth/Makefile	2016-09-22 21:36:19 UTC (rev 42128)
@@ -21,7 +21,7 @@
 clean:
 	rm -f $(NAME).{aux,fls,glo,gls,hd,idx,ilg,ind,ins,log,out,toc} README.txt
 distclean: clean
-	rm -f $(NAME).{pdf,sty} README
+	rm -f $(NAME).{dvi,pdf,sty} README
 inst: all
 	mkdir -p $(UTREE)/{tex,source,doc}/latex/$(NAME)
 	cp $(NAME).dtx $(UTREE)/source/latex/$(NAME)

Modified: trunk/Master/texmf-dist/doc/latex/nameauth/README
===================================================================
--- trunk/Master/texmf-dist/doc/latex/nameauth/README	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/doc/latex/nameauth/README	2016-09-22 21:36:19 UTC (rev 42128)
@@ -21,8 +21,12 @@
 Makefile     Automates building with GNU make 3.81
 nameauth.dtx Documented LaTeX file containing both code and documentation
 
-Installation
+Manual Installation
 
+Download the package from
+
+www.ctan.org/tex-archive/macros/latex/contrib/nameauth
+
 Unpack nameauth.zip in an appropriate directory.
 
 Note that the instructions below assume that you are using a *nix-
@@ -89,3 +93,4 @@
 http://www.ctan.org/tex-archive/help/Catalogue/licenses.lppl.html
 
 Happy TeXing!
+

Modified: trunk/Master/texmf-dist/doc/latex/nameauth/README.txt
===================================================================
--- trunk/Master/texmf-dist/doc/latex/nameauth/README.txt	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/doc/latex/nameauth/README.txt	2016-09-22 21:36:19 UTC (rev 42128)
@@ -21,8 +21,12 @@
 Makefile     Automates building with GNU make 3.81
 nameauth.dtx Documented LaTeX file containing both code and documentation
 
-Installation
+Manual Installation
 
+Download the package from
+
+www.ctan.org/tex-archive/macros/latex/contrib/nameauth
+
 Unpack nameauth.zip in an appropriate directory.
 
 Note that the instructions below assume that you are using a *nix-
@@ -89,3 +93,4 @@
 http://www.ctan.org/tex-archive/help/Catalogue/licenses.lppl.html
 
 Happy TeXing!
+

Modified: trunk/Master/texmf-dist/doc/latex/nameauth/examples.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/nameauth/examples.tex	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/doc/latex/nameauth/examples.tex	2016-09-22 21:36:19 UTC (rev 42128)
@@ -1,11 +1,39 @@
 % This is an example file used with the nameauth package.
+% See README and nameauth.pdf for copyright info.
 %
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%     Test which LaTeX engine you are using
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 %
+
+\usepackage{ifxetex}
+\usepackage{ifluatex}
+
+\ifxetex%									uses fontspec
+  \usepackage{fontspec}
+  \defaultfontfeatures{Mapping=tex-text}
+  \usepackage{xunicode}
+  \usepackage{xltxtra}
+\else
+  \ifluatex%								also uses fontspec
+    \usepackage{fontspec}
+    \defaultfontfeatures{Ligatures=TeX}
+  \else%									traditional NFSS
+    \usepackage[utf8]{inputenc}
+    \usepackage[TS1,T1]{fontenc}
+  \fi
+\fi
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%     Print the first use of a name in text and margin
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%
 % Below we print the argument both in the text and in a margin paragraph
 % unless we are in internal vertical mode.
 %
 % This macro is suitable to replace \NamesFormat and \FrontNamesFormat.
 %
+
 \renewcommand*\NamesFormat[1]%
 {%
   #1%
@@ -14,6 +42,10 @@
     \marginpar{\raggedleft\scriptsize #1}%
   \fi
 }
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%     Print a text tag after first name use
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 %
 % Below we print the argument in the text and then we query the text tag
 % database to see if we can print a text tag after the argument.
@@ -20,6 +52,7 @@
 %
 % This macro is suitable to replace \NamesFormat and \FrontNamesFormat.
 %
+
 \newif\ifNoTextTag
 \makeatletter
 \renewcommand*\NamesFormat[1]%
@@ -45,22 +78,32 @@
   \global\NoTextTagfalse%
 }
 \makeatother
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%     Surname index entries in small caps
+%     First surname instances in text are small caps
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 %
-% Below we create a Boolean value \ifSC and set it true.
+% Below we create a Boolean value \ifSC and set it true. That means
+% the surnames in the index will be in small caps.
 %
 % We then create a macro \DoFormat that prints its argument in 
-% small caps if a Boolean value is true, or makes no font change
-% and prints the the argument of the value is false.
+% small caps if \ifSC is true, or makes no font change
+% and prints the the argument.
 %
-% The next macro ignores its argument, sets \SCfalse, then
-% uses some control sequences internal to the naming macros to
-% parse and print the current name values without any formatting.
+% \MainNameHook ignores its argument, sets \SCfalse to suppress
+% small caps in the text only, then uses control sequences and
+% token registers internal to the naming macros to parse and 
+% print the current name values without any formatting.
 %
-% The final macro is suitable to replace \MainNameHook and \FrontNameHook.
+% The hook macro can replace both \MainNameHook and \FrontNameHook.
 %
+
 \makeatletter
+
 \newif\ifSC
 \SCtrue
+
 \def\DoFormat#1{%
   \ifSC
     \textsc{#1}%
@@ -68,9 +111,10 @@
     #1%
   \fi
 }
-\newcommand*\MainNameHook[1]{%
+
+\renewcommand*\MainNameHook[1]{%
   \let\ex\expandafter%
-  \SCfalse\ignorespaces%
+  \SCfalse%
   \protected at edef\arga{\ex\trim at spaces\ex{\the\@nameauth at toksa}}%
   \protected at edef\argb{\ex\trim at spaces\ex{\the\@nameauth at toksb}}%
   \protected at edef\testb{\ex\@nameauth at Root\ex{\the\@nameauth at toksb}}%
@@ -103,7 +147,7 @@
            \argc%
          \else
            \if at nameauth@RevThis
-             \ex\argc\ex\Space\SNN%
+             \ex\argc\ex\space\SNN%
            \else
              \ex\SNN\ex\space\argc%
            \fi
@@ -177,3 +221,154 @@
 }
 \makeatother
 
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%     Surname index entries in talic
+%     First surname instances in text are italic
+%     Capitalize name within that formatting
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%
+% Below we create a Boolean value \ifItal and set it true.
+% This will trigger italics, similar to the Continental
+% example above.
+%
+% We then create a macro \DoFormat that prints its argument in 
+% italic when \ifItal is true, or makes no font change otherwise.
+%
+% The \CP macro only capitalizies its argument inside \NamesFormat below.
+%
+% \Namesformat ignores its argument, sets \InHooktrue, then
+% uses control sequences internal to the naming macros to
+% parse and print the current name values with formatting.
+%
+% The hook macro is suitable to replace \NamesFormat and \FrontNamesFormat.
+% To replace \MainNameHook and \FrontNameHook, wrap the hook macro
+% between \Italfalse and \italtrue for first-only italic.
+%
+
+\newif\ifItal
+\newif\ifFirstCap
+\newif\ifInHook
+\Italtrue
+
+\def\DoFormat#1{%
+  \ifItal\textit{#1}\else#1\fi
+}
+\def\CP#1{%
+  \ifInHook
+    \ifFirstCap\uppercase{#1}\else#1\fi%
+  \else
+    #1%
+  \fi
+}
+
+\newcommand*\CapMe{\FirstCaptrue}
+\makeatletter%
+\renewcommand*\NamesFormat[1]{\ignorespaces%
+  \let\ex\expandafter\ignorespaces%
+  \InHooktrue\ignorespaces%
+  \protected at edef\arga{\ex\trim at spaces\ex{\the\@nameauth at toksa}}\ignorespaces%
+  \protected at edef\argb{\ex\trim at spaces\ex{\the\@nameauth at toksb}}\ignorespaces%
+  \protected at edef\testb{\ex\@nameauth at Root\ex{\the\@nameauth at toksb}}\ignorespaces%
+  \protected at edef\argc{\ex\trim at spaces\ex{\the\@nameauth at toksc}}\ignorespaces%
+  \ifx\argb\testb
+    \protected at edef\Suff{\@empty}\ignorespaces%
+    \let\Reversed\argb\ignorespaces%
+    \let\SNN\argb\ignorespaces%
+    \let\Short\argb\ignorespaces%
+  \else
+    \protected at edef\Suff{\ex\@nameauth at Suffix\ex{\the\@nameauth at toksb}}\ignorespaces%
+    \protected at edef\Reversed{\Suff\Space\testb}\ignorespaces%
+    \protected at edef\SNN{\testb\Space\Suff}\ignorespaces%
+     \if at nameauth@RevThis
+       \let\Short\Suff%
+     \else
+       \let\Short\testb%
+     \fi
+  \fi
+  \if at nameauth@InAKA
+    \ifx\arga\@empty
+      \ifx\argc\@empty
+        \if at nameauth@RevThis
+          \Reversed%
+        \else
+          \SNN%
+        \fi
+      \else
+         \if at nameauth@AltAKA
+           \argc%
+         \else
+           \if at nameauth@RevThis
+             \ex\argc\ex\space\SNN%
+           \else
+             \ex\SNN\ex\space\argc%
+           \fi
+         \fi
+       \fi
+     \else
+       \ifx\argc\@empty
+         \let\FNN\arga%
+       \else
+         \let\FNN\argc%
+       \fi
+       \if at nameauth@AltAKA
+         \FNN%
+       \else
+         \if at nameauth@RevThis
+           \ex\SNN\ex\Space\FNN%
+         \else
+           \ex\FNN\ex\space\SNN%
+         \fi
+       \fi
+     \fi
+  \else
+    \ifx\arga\@empty
+      \ifx\argc\@empty
+        \if at nameauth@FullName
+          \if at nameauth@RevThis
+            \Reversed%
+          \else
+            \SNN%
+          \fi
+        \else
+          \Short%
+        \fi
+      \else
+        \if at nameauth@FullName
+          \if at nameauth@RevThis
+            \ex\argc\ex\space\SNN%
+          \else
+            \ex\SNN\ex\space\argc%
+          \fi
+        \else
+          \if at nameauth@RevThis
+            \argc%
+          \else
+            \Short%
+          \fi
+        \fi
+      \fi
+    \else
+      \ifx\argc\@empty
+        \let\FNN\arga%
+      \else
+        \let\FNN\argc%
+      \fi
+      \let\Short\FNN%
+      \if at nameauth@FullName
+        \if at nameauth@RevThis
+          \ex\SNN\ex\Space\FNN%
+        \else
+          \ex\FNN\ex\space\SNN%
+        \fi
+      \else
+        \if at nameauth@FirstName
+          \Short%
+        \else
+          \testb%
+        \fi
+      \fi
+    \fi
+  \fi
+  \InHookfalse%
+  \global\FirstCapfalse%
+}
\ No newline at end of file

Modified: trunk/Master/texmf-dist/doc/latex/nameauth/nameauth.pdf
===================================================================
(Binary files differ)

Modified: trunk/Master/texmf-dist/source/latex/nameauth/nameauth.dtx
===================================================================
--- trunk/Master/texmf-dist/source/latex/nameauth/nameauth.dtx	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/source/latex/nameauth/nameauth.dtx	2016-09-22 21:36:19 UTC (rev 42128)
@@ -28,8 +28,12 @@
 Makefile     Automates building with GNU make 3.81
 nameauth.dtx Documented LaTeX file containing both code and documentation
 
-Installation
+Manual Installation
 
+Download the package from
+
+www.ctan.org/tex-archive/macros/latex/contrib/nameauth
+
 Unpack nameauth.zip in an appropriate directory.
 
 Note that the instructions below assume that you are using a *nix-
@@ -109,6 +113,7 @@
 \keepsilent
 \askforoverwritefalse
 \preamble
+
 --------:| ----------------------------------------------------------------
 nameauth:| Name authority mechanism for consistency in text and index
   Author:| Charles P. Schaum
@@ -169,21 +174,10 @@
 %<package>\NeedsTeXFormat{LaTeX2e}[1999/12/01]
 %<package>\ProvidesPackage{nameauth}
 %<*package>
-    [2016/04/06 v2.5 Name authority mechanism for consistency in text and index]
+    [2016/09/19 v2.6 Name authority mechanism for consistency in text and index]
 %</package>
 %<*driver>
 \documentclass[11pt]{ltxdoc}
-\usepackage[textwidth=135mm,textheight=237mm,right=25mm,nohead]{geometry}
-\usepackage[numbered]{hypdoc}
-\usepackage{enumitem}
-\usepackage{\jobname}
-\usepackage[ngerman,american]{babel}
-\usepackage{makeidx}
-\usepackage{multicol}
-\usepackage[toc]{multitoc}
-\usepackage{booktabs}
-\usepackage{setspace}
-\usepackage{tikz}
 \usepackage{ifxetex}
 \usepackage{ifluatex}
 \usepackage{ifpdf}
@@ -204,10 +198,18 @@
     \DeclareTextSymbolDefault{\textlongs}{TS1}
     \DeclareTextSymbol{\textlongs}{TS1}{115}
     \newunicodechar{ſ}{\textlongs}
-    \newunicodechar{ā}{\=a}
-    \newunicodechar{ṃ}{\d m}
   \fi
 \fi
+\usepackage{\jobname}
+\usepackage{manfnt}
+\usepackage[textwidth=135mm,textheight=237mm,right=25mm,nohead]{geometry}
+\usepackage[toc]{multitoc}
+\usepackage{makeidx}
+\usepackage{setspace}
+\usepackage{enumitem}
+\usepackage{booktabs}
+\usepackage{tikz}
+\usepackage[numbered]{hypdoc}
 \setlist{rightmargin=\leftmargin,itemsep=0pt}
 \frenchspacing
 \DisableCrossrefs
@@ -230,6 +232,7 @@
   \< Cicero & M.T. & Cicero & >
   \< Confucius & & Confucius & >
   \< CBald & & Charles, the Bald & >
+  \< White & E.\,B. & White & >
   \< Smith & John & Smith & >
   \< JQP & J.Q. & Public & >
   \< Patton & George S. & Patton, Jr. & >
@@ -246,6 +249,7 @@
   \< Bier & Johann & Bier\-mann & >
   \< Howell & Thurston & \textsc{Howell},\textsc{III} &>
   \< Fukuyama & & \uppercase{Fukuyama}, Takeshi & >
+  \< OFukuyama & & \uppercase{Fukuyama} & Takeshi >
   \< KempMed & & Thomas, à~Kempis & >
   \< KempW & Thomas & à~Kempis & >
   \< Lewis & Clive Staples & Lewis & C.S. >
@@ -256,6 +260,7 @@
   \< Cao & & \noexpand\DoFormat{Cao}, Cao & >
   \< JRIII & John David & \noexpand\DoFormat{Rockefeller}, III & >
   \< SDJR & Sammy & \noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}. & >
+  \< deSmet & Pierre-Jean & \noexpand\DoFormat{\noexpand\CP{d}e Smet} & >
 \end{nameauth}
 \TagName[George]{Washington}{, president|hyperpage}
 \TagName[Hernando]{de Soto}{|hyperpage}
@@ -264,10 +269,10 @@
 \TagName{Aristotle}{|hyperpage}
 \TagName{Elizabeth, I}{, queen|hyperpage}
 \TagName{Attila, the Hun}{|hyperpage}
-\TagName{Dagobert}[I]{, king|hyperpage}
-\TagName[Fumimaro]{Konoe}{, PM\dag|hyperpage}
+\TagName{Dagobert}[I]{\ddag, king|hyperpage}
+\TagName[Fumimaro]{Konoe}{\dag, PM|hyperpage}
 \TagName{Yamamoto, Isoroku}{|hyperpage}
-\TagName{Yoshida}[Shigeru]{, PM|hyperpage}
+\TagName{Yoshida}[Shigeru]{\ddag, PM|hyperpage}
 \TagName[Albert]{Einstein}{|hyperpage}
 \TagName[M.T.]{Cicero}{|hyperpage}
 \TagName{Confucius}{|hyperpage}
@@ -277,15 +282,14 @@
 \TagName{Demetrius, I Soter}{, king|hyperpage}
 \TagName{Sun, Yat-sen}{, president|hyperpage}
 \TagName{Plato}{|hyperpage}
-\TagName{Henry}[VIII]{, king|hyperpage}
-\TagName{Henry, VIII}{, king|hyperpage}
-\TagName{Ptolemy I}[Soter]{, king|hyperpage}
-\TagName{Mao}[Tse-tung]{, chairman|hyperpage}
+\TagName{Henry}[VIII]{\ddag, king|hyperpage}
+\TagName{Ptolemy}[I Soter]{\ddag, king|hyperpage}
+\TagName{Mao}[Tse-tung]{\ddag, chairman|hyperpage}
 \TagName[Walter]{de la Mare}{|hyperpage}
 \TagName[Johann Wolfgang von]{Goethe}{|hyperpage}
 \TagName[Adolf]{Harnack}{|hyperpage}
 \TagName{Antiochus, IV}{ Epi\-phanes, king|hyperpage}
-\TagName{Chiang}[Kai-shek]{, president|hyperpage}
+\TagName{Chiang}[Kai-shek]{\ddag, president|hyperpage}
 \TagName{Louis, XIV}{, king|hyperpage}
 \TagName{Leo, I}{, pope|hyperpage}
 \TagName{Gregory, I}{, pope|hyperpage}
@@ -309,7 +313,7 @@
 \TagName[Oskar]{Hammerstein, II}{|hyperpage}
 \TagName[Lafcadio]{Hearn}{|hyperpage}
 \TagName[Bob]{Hope}{|hyperpage}
-\TagName{Ishida}[Yoko]{|hyperpage}
+\TagName{Ishida}[Yoko]{\ddag|hyperpage}
 \TagName{John, Eriugena}{|hyperpage}
 \TagName[Yoko]{Kanno}{\dag|hyperpage}
 \TagName[Martin Luther]{King, Jr.}{|hyperpage}
@@ -321,7 +325,7 @@
 \TagName[Nicolas]{Malebranche}{|hyperpage}
 \TagName[J.S.]{Mill}{|hyperpage}
 \TagName[Aiko]{Nakano}{\dag|hyperpage}
-\TagName{Nogawa}[Sakura]{|hyperpage}
+\TagName{Nogawa}[Sakura]{\ddag|hyperpage}
 \TagName[Heiko]{Oberdiek}{|hyperpage}
 \TagName{Rambam}{|hyperpage}
 \TagName[Robert]{Schlicht}{|hyperpage}
@@ -340,6 +344,9 @@
 \TagName{Voltaire}{|hyperpage}
 \TagName{Yohko}{|hyperpage}
 \TagName[Johann]{Andreä}{|hyperpage}
+\TagName{Bernard, of Clairvaux}{|hyperpage}
+\TagName[Schuyler]{Colfax}{, VP|hyperpage}
+\TagName[Ulysses S.]{Grant}{, president|hyperpage}
 \PretagName{Æthelred, II}{Aethelred 2}
 \TagName{Æthelred, II}{, king|hyperpage}
 \PretagName[Jan]{Łukasiewicz}{Lukasiewicz, Jan}
@@ -378,6 +385,8 @@
 \PretagName[Sammy]{\noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}.}{Davis, Sammy, Jr.}
 \TagName[Sammy]{\noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}.}{|hyperpage}
 \PretagName{\noexpand\DoFormat{Mengde}}{Mengde}
+\PretagName[Pierre-Jean]{\noexpand\DoFormat{\noexpand\CP{d}e Smet}}{de Smet, Pierre-Jean}
+\TagName[Pierre-Jean]{\noexpand\DoFormat{\noexpand\CP{d}e Smet}}{|hyperpage}
 \IndexActual{=}
 \begin{document}
   \DocInput{\jobname.dtx}
@@ -385,7 +394,7 @@
 %</driver>
 % \fi
 %
-% \CheckSum{3321}
+% \CheckSum{3259}
 %
 % \CharacterTable
 %  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
@@ -404,27 +413,11 @@
 %   Right brace   \}     Tilde         \~}
 %
 % \changes{v0.7}{2011/12/26}{Initial release}
-% \changes{v0.8}{2012/01/29}{Add features, bugfixes}
 % \changes{v0.85}{2012/02/05}{Add package options}
-% \changes{v0.86}{2012/02/06}{Fix regressions}
-% \changes{v0.9}{2012/02/10}{Add first name formatting; affix handling expandable}
-% \changes{v0.94}{2012/02/15}{Add index suppression, error checking, name particle caps}
-% \changes{v0.95}{2012/02/17}{Bugfixes}
-% \changes{v0.96}{2012/02/19}{Bugfixes}
 % \changes{v1.0}{2012/02/20}{Works fully with \textsf{microtype} and \textsf{memoir}}
-% \changes{v1.1}{2012/03/08}{Bugfixes}
-% \changes{v1.4}{2012/07/24}{Add features, bugfixes}
-% \changes{v1.5}{2013/02/22}{Add features, bugfixes, options}
-% \changes{v1.6}{2013/03/10}{Add |nameauth| environment}
+% \changes{v1.5}{2013/02/22}{Add package options}
 % \changes{v1.7}{2013/04/02}{Fix options processing}
-% \changes{v1.8}{2013/09/19}{Update docs}
-% \changes{v1.9}{2015/07/09}{Better Eastern name support; fix |nameauth| bugs, global un-tagging}
 % \changes{v2.0}{2015/11/11}{Use dtxgen template instead of dtxtut; update docs}
-% \changes{v2.1}{2015/11/24}{Isolate Unicode issues}
-% \changes{v2.2}{2015/12/01}{Add interface hooks and docs; fix bugs}
-% \changes{v2.3}{2016/01/05}{Improve docs and hooks; add features}
-% \changes{v2.4}{2016/03/15}{Add text tagging features, add generic hooks, and prevent recursion}
-% \changes{v2.41}{2016/03/17}{Instantiate token registers only once}
 % \changes{v2.42}{2016/03/18}{Do not use \cmd{\cmd} in section headings}
 % \changes{v2.5}{2016/04/06}{More examples; no default formatting}
 % \GetFileInfo{\jobname.dtx}
@@ -432,16 +425,23 @@
 % \DoNotIndex{\begingroup, \bfseries, \bgroup, \csdef, \csgdef, \csname, \csundef, \DeclareOption, \def, \detokenize, \edef, \egroup, \else, \endcsname, \endgroup, \endinput, \ExecuteOptions, \expandafter, \fi, \futurelet, \global, \hbox, \if, \ifcsname, \ifx, \ignorespaces, \index, \itshape, \leavevmode, \let, \newcommand, \newcommandx, \newenvironment, \newif, \nobreakspace, \PackageError, \PackageWarning, \ProcessOptions, \relax, \renewcommand, \RequirePackage, \scshape, \space, \textbackslash, \uppercase}
 %
 % \newif\ifSC
+% \newif\ifItal
+% \newif\ifDoTikZ
+% \newif\ifFirstCap
+% \newif\ifInHook
 % \SCtrue
-% \def\DoFormat#1{\ifSC\textsc{#1}\else#1\fi}
+% \Italtrue
+% \ifxetex\DoTikZtrue\else
+%   \ifluatex\ifpdf\DoTikZtrue\fi
+%   \else\ifpdf\DoTikZtrue\fi\fi\fi
 %
-%\title{\textsf{nameauth} --- Name authority mechanism for consistency in text and index\thanks{This file
+% \title{\textsf{nameauth} --- Name authority mechanism for consistency in text and index\thanks{This file
 %   describes version \fileversion, last revised \filedate.}
-%}
-%\author{Charles P. Schaum\thanks{E-mail: charles dot schaum at comcast dot net}}
-%\date{Released \filedate}
+% }
+% \author{Charles P. Schaum\thanks{E-mail: charles dot schaum at comcast dot net}}
+% \date{Released \filedate}
 %
-%\maketitle
+% \maketitle
 % 
 % \begin{abstract}
 % \noindent The \textsf{nameauth} package automates the formatting and indexing of names. This aids the use of a \textbf{name authority} and the process of textual reordering and revision without needing to retype name references.
@@ -448,67 +448,75 @@
 % \end{abstract}
 %
 % {\small\tableofcontents}
-% \setlength{\parskip}{0.15\baselineskip plus .15\baselineskip minus .15\baselineskip}
+% \setlength{\parskip}{0.1\baselineskip plus .05\baselineskip minus .05\baselineskip}
 %
 % \section{Introduction}
 %
-% \subsection{Summary Overview}
+% \subsection{Preliminary Information}
 %
+% \begin{center}\large\bfseries Disclaimer\end{center}
+% This manual uses names of living and dead historical figures because users refer to real people. At no time do I intend any disrespect or statement of bias regarding any particular person, culture, or tradition. All names herein are used only for teaching purposes. Especially in the index, fictional names have an asterisk (*), Eastern names with Western index forms have a dagger (\dag), and names that use the older syntax have a double dagger (\ddag).
+%
+% \begin{center}\large\bfseries Design\end{center}
 % When publications use hundreds of names, it takes time and money to check them. This package automates much of that work:
 % \begin{itemize}
-% \item \textbf{Context} determines name forms unless otherwise modified.
-% \item The macros \textbf{reduce retyping of names} when editing a document.
-% \item You can implement a \textbf{name authority}, a master list of names that permits known name variants.
-% \item \textbf{Consistent index entries} work with these variants.
-% \item Some \textbf{cross-cultural naming conventions} are possible.
-% \item \textbf{index automatic sort keys and tags} aid cross-cultural work.
-% \end{itemize}
-%
-% This package grew from generalized needs for translating old German and Latin texts. Design principles include:
-% \begin{enumerate}\small
-% \item Format and vary name forms according to standard syntax in the body text, independent of the index, following English standards:
-% \begin{itemize}[noitemsep]
+% \item \textbf{Automation} of name forms in the text aids professional writing and allows the arbitrary replacement of text without retyping names.
+% \begin{itemize}\small
 %   \item Default to long name references first, then shorter ones.
 %   \item Use alternate names only in the body text, not the index.
 %   \item Perform name caps and reversing only in the body text.
 % \end{itemize}
-% \item Post-process names only in the body text. Reflect English conventions by default, but only \emph{after} syntactic formatting is complete.
-% \item Enable Continental and non-English standards through modularized post-processing, whose English-standard defaults may be bypassed and modified (Sections~\ref{sec:accents}, \ref{sec:formatting}, \ref{sec:IndexSort}, and~\ref{sec:Hooksc}).
-% \item Reduce keystrokes while accommodating the broadest set of names.
-% \end{enumerate}
+% \item Name variants in the text still produce \textbf{consistent index entries}.
+% \item One can design \textbf{complex name formatting.}
+% \item One can \textbf{automate information retrieval} about names.
+% \item One can implement and automate a \textbf{name authority,} a master list of names that permits known name variants.
+% \item Some \textbf{cross-cultural naming conventions} are possible.
+% \item \textbf{Automatic sort keys and tags} aid indexing.
+% \item Provide \textbf{automatic name presentation} that could work in a \LaTeX\ backend for a document transform, database report, etc.
+% \end{itemize}
 %
-% \subsection{Milestone Changes}
+% This package grew from generalized needs for translating old German and Latin texts into English. One can enable Continental and non-English standards via control sequences in the macro arguments or through bypassing and reformatting the post-processing modules (Sections~\ref{sec:accents}, \ref{sec:nonenglish}, \ref{sec:IndexSort}, and~\ref{sec:Hooksc}).
 %
-% With version 2.5 the \textsf{nameauth} package turns a corner to a new period of cross-cultural use. No formatting is selected by default. Now you can have one format for first uses of names in the main matter, another for first uses in the front matter, and one each for subsequent uses in the main and front matter. This allows for greater customization, depending on individual needs.
+% Indexing generally conforms to the standard in Nancy C. Mulvany, \emph{Indexing Books} (Chicago: University of Chicago Press, 1994). This should be suitable for a very wide application across a number of disciplines.
+% \clearpage
 %
-% \subsection{Technical Notes}
-% This manual performs something of a ``torture test'' on this package. You might want to avoid doing that if you are a beginner. It is designed to be compatible with A4 and US letter. Macro references are minimized for a ``clean'' index, showing how \textsf{nameauth} handles indexing.
+% \begin{center}\large\bfseries Technical Notes\end{center}
+% \begin{itemize}
+% \item We take an ``easy stuff first'' approach and indicate when the number or complexity of concepts might be confusing.
+% \item When this\marginpar{\small\raggedleft\dbend} manual touches on some of the more esoteric points of this package that require more caution, it uses the ``dangerous bend.''
+% \item This manual uses package macros and internals in special ways to isolate and show its examples. In some cases we point that out, while in others we assume that the reader understands this.
+% \item With\marginpar{\small\raggedleft\dbend} version 2.5 no formatting is selected by default. To implement formatting, see Sections~\ref{sec:nonenglish}, \ref{sec:CustomHooks}, and~\ref{sec:Hooksa}ff. These sections can be more complex than others.
+% \item Version 2.6 fixes several issues with the \texttt{comma} option and with the old syntax. The \texttt{comma} option no longer affects Eastern and ancient names. The old and new syntax are interchangeable, save with \cmd{\AKA} and its derivatives. See Sections~\ref{sec:obsolete}, \ref{sec:Affix}, and~\ref{sec:AKA}.
+% \item This package really should be rewritten at some point. The author offers his humble apologies for any current shortcomings.\footnote{Future possibilities include: \cmd{\RevName} and friends force long name references; \cmd{\RevComma} and friends work only on Western names, independent of the present reversing system; a better way of parsing names and setting values will be implemented.}
+% \item This manual is designed to be compatible with both A4 and US letter stock size formats.
+% \item Macro references are minimized for a ``clean'' index, showing how \textsf{nameauth} ``normally'' handles indexing.
+%   \item The \textsf{nameauth} package requires \textsf{etoolbox}, \textsf{ifxetex}, \textsf{ifluatex}, \textsf{suffix}, \textsf{trimspaces}, and \textsf{xargs}.
+%   \item With each release, this documentation is tested with dvi-mode \texttt{latex,} \texttt{pdflatex,} \texttt{lualatex,} and \texttt{xelatex} using \texttt{makeindex.} This is done by running the GNU Makefile with the ENGINE=\meta{engine} option.
+%   \item Only the \texttt{pdflatex} version is released with the package.
+%   \item The package also works with \texttt{xindy,} although \cmd{\PretagName} may not be necessary in that case. Using \texttt{xindy} is best for languages that have sort orders for letters that cannot map to English. German \emph{does} map to English: Ä, Ö, Ü, and ß are AE, OE, UE, and SS. Norwegian \emph{does not} map to English: Æ, Ø, and Å come after Z in that order.
+%   \item This manual was typeset with \ifxetex\texttt{xelatex}\else
+%     \ifluatex\ifpdf\texttt{lualatex} in \texttt{pdf} mode\else
+%     \texttt{lualatex} in \texttt{dvi} mode\fi
+%     \else\ifpdf\texttt{pdflatex}\else
+%     \texttt{latex}\fi\fi\fi
+%     \ using \texttt{makeindex} and \texttt{gind.ist.} (This item changes, depending on the \LaTeX\ engine).
+% \end{itemize}
 %
-% \textsf{Nameauth} depends on \textsf{etoolbox}, \textsf{ifxetex}, \textsf{ifluatex}, \textsf{suffix}, \textsf{trimspaces}, and \textsf{xargs}. It was tested with \texttt{latex,} \texttt{lualatex,} \texttt{pdflatex,} and \texttt{xelatex,} along with \texttt{makeindex} and \texttt{texindy.} This manual was typeset with \ifxetex\texttt{xelatex}\else\ifluatex\ifpdf\texttt{lualatex} in \texttt{pdf} mode\else\texttt{lualatex} in \texttt{dvi} mode\fi\else\ifpdf\texttt{pdflatex}\else\texttt{latex}\fi\fi\fi{} using \texttt{makeindex} and \texttt{gind.ist.}
+% \begin{center}\large\bfseries Thanks\end{center}
+% {\def\NamesFormat{\bfseries} Thanks to \Name[Marc van]{Dongen}, \Name[Enrico]{Gregorio}, \Name[Philipp]{Stephani}, \Name[Heiko]{Oberdiek}, \Name[Uwe]{Lueck}, and \Name[Robert]{Schlicht} for their assistance in the early versions of this package. Thanks also to the users of this package, whose feedback has helped me do a better job than I could have done otherwise.}
+% \clearpage
 %
-% Indexing generally conforms to the standard in Nancy C. Mulvany, \emph{Indexing Books} (Chicago: University of Chicago Press, 1994). This should be suitable for a very wide application across a number of disciplines. 
-%
-% \subsection{Thanks}
-%
-% Thanks to \Name[Marc van]{Dongen}, \Name[Enrico]{Gregorio}, \Name[Philipp]{Stephani}, \Name[Heiko]{Oberdiek}, \Name[Uwe]{Lueck}, and \Name[Robert]{Schlicht} for their assistance in the early versions of this package.
-%
-%
-% \subsection{Disclaimer}
-%
-% This documentation uses names of living and historical figures because users refer to real people. At no time do I intend any disrespect or statement of bias regarding any particular person, culture, or tradition. All names are used only for teaching purposes.
-%\clearpage
-%
 % \subsection{What's In A Name?}
 % \label{sec:NameTypes}
 %
-% Name forms are ambiguous apart from historical and cultural contexts. The \textsf{nameauth} package helps you encode names from as many contexts as possible. In this manual we refer to three classes of names, shown below. Professional writing often calls for the full form of a person's name to be used in its first occurrence, with shorter forms used thereafter. This package adapts that principle to the classes of names below.
+% Name forms are ambiguous apart from historical and cultural contexts. The \textsf{nameauth} package uses this ambiguity to help you encode names from many contexts. In this manual we refer to three classes of names, shown below. Section~\ref{sec:start} shows how these classes are implemented.
 %
-%  In each class there is a required ``surnames'' argument, \meta{SNN}. This can be a Western surname, an Eastern family name, or the personal name of an ancient, medieval, or royal person.\footnote{Some professional literature speaks of forenames and optional surnames. See Mulvany, \emph{Indexing Books}, pages 152--82, which I used as a guide along with the \emph{Chicago Manual of Style}. That approach does not work in \LaTeX, where we use optional forenames for the same effect.}
-% Other naming systems can be adapted to these categories, \emph{e.g.}, Icelandic, Hungarian, etc.
+% Professional writing often calls for the full form of a person's name to be used in its first occurrence, with shorter forms used thereafter. This package implements that principle as a central part of its design. In each class there is a required name and optional name elements.\footnote{Some professional literature speaks of forenames and optional surnames. See Mulvany, \emph{Indexing Books}, pages 152--82, which I used as a guide along with the \emph{Chicago Manual of Style}. That approach does not work in \LaTeX, where we use optional forenames for the same effect.}
+% Other naming systems can be adapted to these general categories, \emph{e.g.}, Icelandic, Hungarian, etc.
 %
-%\begin{enumerate}[noitemsep]
-%\item Western name:\\[1ex]
-%\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
+% \begin{enumerate}[noitemsep]
+% \item Western name:\\[1ex]
+% \ifDoTikZ\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
 %  \node [matrix] (macro) at (0,1)
 %  {
 %    \node(space){\qquad\qquad\qquad}; &
@@ -521,32 +529,32 @@
 %    \node[align=left](a1)
 %    {
 %      Personal name(s):\\
-%      \textit{baptismal name}\\
-%      \textit{Christian name}\\
-%      \textit{first and middle}\\\quad\textit{names}\\
-%      \textit{praenomen}
+%      \small\textit{baptismal name}\\
+%      \small\textit{Christian name}\\
+%      \small\textit{first and middle}\\\quad\textit{names}\\
+%      \small\textit{praenomen}
 %    }; &
 %    \node[align=left](a2)
 %    {
 %      Family designator:\\
-%      \textit{father's family}\\
-%      \textit{mother's family}\\
-%      \textit{ancestor}\\
-%      \textit{occupation}\\
-%      \textit{place of origin}\\
-%      \textit{territory}\\
-%      \textit{nomen/cognomen}\\
-%      \textit{patronym}
+%      \small\textit{father's family}\\
+%      \small\textit{mother's family}\\
+%      \small\textit{ancestor}\\
+%      \small\textit{occupation}\\
+%      \small\textit{place of origin}\\
+%      \small\textit{territory}\\
+%      \small\textit{nomen/cognomen}\\
+%      \small\textit{patronym}
 %    }; &
 %    \node[align=left](a3)
 %    {
 %      Sobriquet / title:\\
-%      \textit{senior, junior, III\dots}\\
-%      \textit{notable feature}\\
-%      \textit{notable attribute}\\
-%      \textit{place of origin}\\
-%      \textit{territory}\\
-%      \textit{agnomen}
+%      \small\textit{Sr., Jr., III\dots}\\
+%      \small\textit{notable feature}\\
+%      \small\textit{notable attribute}\\
+%      \small\textit{place of origin}\\
+%      \small\textit{territory}\\
+%      \small\textit{agnomen}
 %    }; \\
 %  };
 %  \begin{scope}[every path/.style=line]
@@ -554,9 +562,9 @@
 %    \path (arg2) -- (a2);
 %    \path (arg3) -- (a3);
 %  \end{scope}
-%\end{tikzpicture}
-%\item Eastern name:\\[1ex]
-%\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
+% \end{tikzpicture}\else\vfill\fi
+% \item Eastern name:\\[1ex]
+% \ifDoTikZ\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
 %  \node [matrix] (macro) at (0,1)
 %  {
 %    \node(spacei){\qquad\qquad\qquad}; &
@@ -572,7 +580,7 @@
 %    }; &
 %    \node[align=left](a2)
 %    {
-%      (Multiple names are rare, but multi-\\character names do exist.)
+%      Multiple names are rare, but multi-\\character names do exist.
 %    };\\
 %  };
 %  \begin{scope}[every path/.style=line]
@@ -579,9 +587,9 @@
 %    \path (arg1) -- (a1);
 %    \path (arg2) -- (a2);
 %  \end{scope}
-%\end{tikzpicture}
-%\item Ancient name:\\[1ex]
-%\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
+% \end{tikzpicture}\else\vfill\fi
+% \item Ancient name:\\[1ex]
+% \ifDoTikZ\begin{tikzpicture}[line/.style={draw,thick}]\normalsize
 %  \node [matrix] (macro) at (0,1)
 %  {
 %    \node(spacei){\qquad\qquad\qquad}; &
@@ -598,11 +606,11 @@
 %    \node[align=left](a2)
 %    {
 %      Sobriquet / title:\\
-%      \textit{senior, junior, III\dots}\\
-%      \textit{notable feature}\\
-%      \textit{notable attribute}\\
-%      \textit{place of origin}\\
-%      \textit{territory}
+%      \small\textit{senior, junior, III\dots}\\
+%      \small\textit{notable feature}\\
+%      \small\textit{notable attribute}\\
+%      \small\textit{place of origin}\\
+%      \small\textit{territory}
 %    }; \\
 %  };
 %  \begin{scope}[every path/.style=line]
@@ -609,34 +617,8 @@
 %    \path (arg1) -- (a1);
 %    \path (arg2) -- (a2);
 %  \end{scope}
-%\end{tikzpicture}
-%\end{enumerate}
-%
-% Another way to think about these classes of names is to pretend that you know \emph{nothing at all} about names. How would you make sense out of the following?
-% \begin{quote}\small\setstretch{1.2}
-% \begin{tabular}{lll}\toprule
-% Longer Name & Shorter Name & Indexed Name\\\midrule
-% \Wash & \Wash\ForgetName[George]{Washington} & Washington, George\\
-% \JRII & \JRII\ForgetName[John David]{Rockefeller, II} & Rockefeller, John David, II\\
-% \Name*[Clive Staples]{Lewis} & \LLewis & Lewis, Clive Staples\\
-% \Name*[Clive Staples]{Lewis} & \LJack\ForgetName[Clive Staples]{Lewis} & Lewis, Clive Staples\\
-% \Yamt & \Yamt\ForgetName{Yamamoto, Isoroku} & Yamamoto Isoroku\\
-% \Aris & \Aris\ForgetName{Aristotle} & Aristotle\\
-% \Eliz & \Eliz\ForgetName{Elizabeth, I} & Elizabeth I\\
-% \Attil & \Attil\ForgetName{Attila, the Hun} & Attila the Hun\\\bottomrule
-% \end{tabular}
-% \end{quote}
-%
-% The position of a name alone does not reveal whether it is a personal name or a family name. Nevertheless, if you notice a few consistent relationships, that will help you work out how the \textsf{nameauth} package encodes names:
-% \begin{enumerate}\small
-% \item The long form of a name corresponds with the reordered indexed form. That means the long forms of names must be the macro arguments.
-% \item All Western index forms have surname(s) first, followed by a comma, then the forename(s), then a comma if needed, then the affix if it exists. That means Western names handle suffixes and name ordering differently than other names.
-% \item All Western name forms have both forename(s) and surname(s). The forename(s) can change/drop in the text, but not in the index. That means the presence of an optional forename denotes a Western name instead of another name form.
-% \item Eastern name forms \meta{Surname(s)} \meta{Forename(s)}, with royal and ancient name forms \meta{Name(s)} \meta{Affix}, should not have commas in their index entries. The forename(s) and affixes cannot change (in this package), but they can drop in the text, but not the index. All these name forms basically work the same, except that an ancient or medieval personal name has the same position that an Eastern family name has. Their arguments, therefore, have much the same syntax.
+% \end{tikzpicture}\else\vfill\fi
 % \end{enumerate}
-%
-% All this being said, the publisher's way of handling things may trump the (arguably) canonical way. This package allows some ``borderline'' options and name forms to accommodate that.\footnote{Some publishers not only use commas with Eastern forms in the index, but sometimes the forms are just wrong. For example, one sees \Name{Sun, Yat-sen}\ForgetName{Sun, Yat-sen} indexed as ``Yat-sen, Sun'' (instead of either ``Sun, Yat-sen'' or ``Sun Yat-sen'') in Immanuel Geiss, \emph{Personen: Die biographische Dimension der Weltgeschichte}, Geschichte Griffbereit vol. 2 (Munich: Wissen Media Verlag, 2002), 720. The six-volume series is otherwise a helpful resource.}
-% The most prominent example includes the ``non-native'' Eastern names discussed in Sections~\ref{sec:options} and~\ref{sec:Eastern}.
 % \clearpage
 % \section{Usage}
 %
@@ -650,119 +632,117 @@
 % \item Enable or disable features (formatting, indexing, index sorting) 
 % \item Affect the syntax of names (commas, capitalization, and reversing)
 % \item Typographic display of names (formatted or not, and how)
-% \end{enumerate}
+% \end{enumerate}\smallskip
 %
-% \noindent\begin{tabular}{p{0.97\textwidth}}\toprule\hfil\bfseries Default options are in boldface.\hfil\\\bottomrule\end{tabular}
+% \noindent\begin{tabular}{p{0.96\textwidth}}\toprule\hfil\bfseries Default options are in boldface.\hfil\\\bottomrule\end{tabular}
 %
-% \begin{center}\Large\bfseries Choose Features\end{center}
-%
-% \noindent{\large\bfseries Choose Formatting}\\[2ex]
+% \begin{center}\large\bfseries Choose Features\end{center}
+% {\bfseries Choose Formatting}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
-% \quad\bfseries\texttt{mainmatter} & \bfseries Start with ``main-matter names'' and formatting hooks (see page ~\pageref{page:PostProcess}).\\[1ex]
+% \quad\bfseries\texttt{mainmatter} & \bfseries Start with ``main-matter names'' and formatting hooks (page~\pageref{page:PostProcess}).\\[1ex]
 % \quad\texttt{frontmatter} & Start with ``front-matter names'' and hooks.\\[1ex]
 % \quad\texttt{alwaysformat} & Use only respective ``first use'' formatting hooks.\\[1ex]
 % \quad\texttt{formatAKA} & Format names declared by \cmd{\AKA} like other main- and front-matter names.\\[2ex]
 % \end{tabular}\\
-% The default |mainmatter| option and the |frontmatter| option enable two different systems of formatting and first/subsequent use. \cmd{\NamesActive} starts the main matter system when |frontmatter| is used. See Section~\ref{sec:FrontFormat}.
+% The default \texttt{mainmatter} option and the \texttt{frontmatter} option enable two different systems of name use and formatting. They are mutually exclusive. \cmd{\NamesActive} starts the main matter system when \texttt{frontmatter} is used. See Section~\ref{sec:FrontFormat}.
 %
-% The \texttt{alwaysformat} option disables ``subsequent use'' hooks globally. Using \texttt{formatAKA} lets \cmd{\AKA} use ``first-use'' hooks for one time and ``subsequent-use'' hooks thereafter, without needing \texttt{alwaysformat.}\bigskip
+% The \texttt{alwaysformat} option forces ``first use'' hooks globally. The \texttt{formatAKA} option affects ``first-use'' formatting and \cmd{\AKA} (Section~\ref{sec:AKA}). Both \texttt{alwaysformat} and \texttt{formatAKA} can be used with either \texttt{mainmatter} or \texttt{frontmatter.}\bigskip
 %
-% \noindent{\large\bfseries Enable/Disable Indexing}\\[2ex]
+% \noindent{\bfseries Enable/Disable Indexing}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
 % \quad\bfseries\texttt{index} & \bfseries Create index entries in place with names.\\[1ex]
 % \quad\texttt{noindex} & Suppress indexing of names.\\[2ex]
 % \end{tabular}\\
-% The default |index| option enables name indexing right away. The |noindex| option disables the indexing of names until \cmd{\IndexActive} enables it. That can affect the use of index tags. This applies only to naming and indexing macros in the \textsf{nameauth} package. See Section~\ref{sec:SectionIndex}.\bigskip
+% These apply only to the \textsf{nameauth} package macros. The default \texttt{index} option enables name indexing right away. The \texttt{noindex} option disables the indexing of names until \cmd{\IndexActive} enables it. {\bfseries Both \texttt{noindex} and \cmd{\IndexInactive} suppress index tags.} See Section~\ref{sec:SectionIndex}.\bigskip
 %
-% \noindent{\large\bfseries Enable/Disable Index Sorting}\\[2ex]
+% \noindent{\bfseries Enable/Disable Index Sorting}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
 % \quad\bfseries\texttt{pretag} & \bfseries Create sort keys used with \texttt{makeindex}.\\[1ex]
 % \quad\texttt{nopretag} & Do not create sort keys. \\[2ex]
 % \end{tabular}\\
-% The default allows \cmd{\PretagName} to create sort keys used in \texttt{makeindex} / \texttt{texindy}. Seldom would one change this option. See Section~\ref{sec:IndexSort}.\clearpage
+% The default allows \cmd{\PretagName} to create sort keys used with NFSS or \texttt{makeindex} and its analogues. Seldom would one change this option unless a document is designed to work with both \texttt{makeindex} and \texttt{xindy}. See Section~\ref{sec:IndexSort}.
+% \clearpage
 %
-% \begin{center}\Large\bfseries Affect the Syntax of Names\end{center}
-%
-%\noindent{\large\bfseries Show/Hide Affix Commas}\\[2ex]
+% \begin{center}\large\bfseries Affect the Syntax of Names\end{center}
+% {\bfseries Show/Hide Affix Commas}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
 % \quad\bfseries\texttt{nocomma} & \bfseries Suppress commas between surnames and affixes, following the \emph{Chicago Manual of Style} and other conventions.\\[1ex]
 % \quad\texttt{comma} & Retain commas between surnames and affixes.\\[2ex]
 % \end{tabular}\\
-% This option is set at load time. If you use \emph{modern standards} or Eastern names, choose the default |nocomma| option to get, \emph{e.g.}, \Name[James Earl]{Carter, Jr.}.
-%
-% If you need to adopt \emph{older standards} that use commas between surnames and affixes, you have two choices:
+% This option is set at load time. If you use \emph{modern standards}, choose the default \texttt{nocomma} option to get, \emph{e.g.}, {\def\NamesFormat{\bfseries} \Name[James Earl]{Carter, Jr.}.} If you need to adopt \emph{older standards} that use commas between surnames and affixes, you have two choices:
 % \begin{enumerate}
-% \item The \texttt{comma} option produces, \emph{e.g.}, \ForgetName[James Earl]{Carter, Jr.}\ShowComma\Name[James Earl]{Carter, Jr.}. Yet it limits the use of macros like \cmd{\AKA} and \cmd{\PName} and it prevents the use of Eastern and ancient names with the new syntax.\footnote{Before version 0.9 the \textsf{nameauth} package assumed the \texttt{comma} option by default and used the old syntax to encode names. Newer versions are backward-compatible.}
-% \item Section~\ref{sec:Affix} shows how one can use \cmd{\ShowComma} with the |nocomma| option to get similar results, but with more flexibility.
+% \item The \texttt{comma} option produces, \emph{e.g.}, \ForgetName[James Earl]{Carter, Jr.}{\def\NamesFormat{\bfseries}\ShowComma\Name[James Earl]{Carter, Jr.}.}
+% \item Section~\ref{sec:Affix} shows how one can use \cmd{\ShowComma} with the \texttt{nocomma} option and \cmd{\NoComma} with the \texttt{comma} option to get per-name results.
 % \end{enumerate}\medskip
 %
-% \noindent{\large\bfseries Capitalize Entire Surnames}\\[2ex]
+% \noindent{\bfseries Capitalize Entire Surnames}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
 % \quad\bfseries\texttt{normalcaps} & \bfseries Do not perform any special capitalization.\\[1ex]
 % \quad\texttt{allcaps} & Capitalize entire surnames, such as romanized Eastern names.\\[2ex]
 % \end{tabular}\\
-% This only affects names printed in the body text. One of the design principles of this package keeps it consistent with English typography and syntax. Thus no syntactic or typographic changes are propagated into the index by default.
+% This only capitalizes names printed in the body text. English standards usually do not propagate typographic changes into the index.
 %
-% Still, you can use this package with different conventions that involve both syntax and formatting. You can type in capitalized family names directly to get that effect. See also Section~\ref{sec:formatting} on how to use macros to get caps (\cmd{\uppercase}) or small caps (\cmd{\textsc}) in both the body text and the index. This becomes easy with the simplified interface.
+% Still,\marginpar{\small\raggedleft\dbend} you can use this package with non-English conventions. You can add, \emph{e.g.}, uppercase or small caps in surnames, formatting them also in the index. See also Sections~\ref{sec:nonenglish} and ~\ref{sec:Hooksc} The simplified interface aids the embedding of control sequences in names. Section~\ref{sec:Eastern} deals with capitalization on a section-level and per-name basis.\bigskip
 %
-% Section~\ref{sec:Eastern} deals with capitalization on a section-level and per-name basis.\bigskip
-%
-% \noindent{\large\bfseries Reverse Name Order}\\[2ex]
+% \noindent{\bfseries Reverse Name Order}\\[2ex]
 % \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
 % \quad\bfseries\texttt{notreversed} & \bfseries Print names in the order specified by \cmd{\Name} and the other macros.\\[1ex]
 % \quad\texttt{allreversed} & Print all name forms in ``smart'' reverse order.\\[1ex]
 % \quad\texttt{allrevcomma} & Print all names in ``Surname, Forenames'' order, meant for Western names.\\[2ex]
 % \end{tabular}\\
-% See Section~\ref{sec:Eastern} for related macros to control name reversing by section or by name. This also affects how Eastern names will appear in the index.
+% These options, along with th macros in Sections~\ref{sec:Eastern} and~\ref{sec:LastFirst}, assume that you are using long name references. Usually, the best approach is to use \cmd{\RevName} and \cmd{\RevComma} with \cmd{\Name*} and equivalents on a per-name basis.
 %
-% So-called ``last-comma-first'' lists of names via \texttt{allrevcomma} (Section~\ref{sec:LastFirst}) are \emph{not} the same as the \texttt{comma} option. They are designed for Western names.\clearpage
+% See Section~\ref{sec:Eastern} for related macros to control name reversing by section or by name. Reversing can have unwanted results with short name references or ancient/medieval names.
 %
-% \begin{center}\Large\bfseries Name Post-Processing\end{center}
+% So-called ``last-comma-first'' lists of names via \texttt{allrevcomma} and the macros \cmd{\ReverseCommaActive} and \cmd{\RevComma} (Section~\ref{sec:LastFirst}) are \emph{not} the same as the \texttt{comma} option. They are designed for Western names.
+% \clearpage
+%
+% \begin{center}\large\bfseries Name Post-Processing\end{center}
 % \label{page:PostProcess}
+% Sections~\ref{sec:nonenglish},\marginpar{\small\raggedleft\dbend} \ref{sec:CustomHooks}, and~\ref{sec:Hooksa}ff. explain this topic in greater detail, but are more advanced regarding technical details. Post-processing does not affect the index and comes after ``syntactic formatting'' (control sequences always present in the \textsf{nameauth} macro arguments).\footnote{This package was designed with type hierarchies in mind, although it has become more flexible. See Robert Bringhurst, \emph{The Elements of Typographic Style}, version 3.2 (Point Roberts, Washington: Hartley \& Marks, 2008), 53--60.}
 %
-% Sections~\ref{sec:CustomHooks}, \ref{sec:formatting}, and~\ref{sec:Hooksa}ff. explain this topic in greater detail. Post-processing follows syntactic formatting and does not affect the index.\footnote{This package was designed with type hierarchies in mind, although it has become more flexible. See Robert Bringhurst, \emph{The Elements of Typographic Style}, version 3.2 (Point Roberts, Washington: Hartley \& Marks, 2008), 53--60.}
-%
-% As of version 2.4, ``typographic formatting'' has become a generalized concept of ``name post-processing'' via these hook macros:
+% As of version 2.4, what was ``typographic formatting'' has become a generalized concept of ``name post-processing'' via these hook macros:
 % \begin{itemize}
 % \item \cmd{\NamesFormat} formats first uses of main-matter names.
 % \item \cmd{\MainNameHook} formats subsequent uses of main-matter names.
 % \item \cmd{\FrontNamesFormat} formats first uses of front-matter names.
 % \item \cmd{\FrontNameHook} formats subsequent uses of front-matter names.
-% \end{itemize}
+% \end{itemize}\smallskip
 %
 % Sections~\ref{sec:CustomHooks} and~\ref{sec:Hooksa}ff. offer substantially more complex possibilities for such hooks.\footnote{I drew some inspiration from the typography in Bernhard Lohse, \emph{Luthers Theologie} (G\"ottingen: Vandenhoeck \& Ruprecht, 1995) and the five-volume series by Jaroslav J. Pelikan Jr., The Christian Tradition: A History of the Development of Doctrine (Chicago: Chicago UP, 1971--89). Each volume in the series has its own title.}
 % By default, they do nothing.
 %
-% English typography has been the default design choice for this package. Still, one can use German, French, and similar standards, which I group as ``Continental.'' Sections~\ref{sec:formatting} and~\ref{sec:Hooksc} have more on the topic, as well as the use of sort tags in Section~\ref{sec:IndexSort}. Continental standards format surnames only, both in the text and in the index. This conflicts with some deliberately ambiguous name forms in \textsf{nameauth}.\footnote{Ancient, Eastern, and suffixed name forms have the same pattern.}
-% To get formatting in the index one must add it in the macro arguments. The simplified interface aids this process. Continental users also may lose some capitalization features; see Section~\ref{sec:standards}.\bigskip
+% English typography has been the default design choice for this package. Still, one can use German, French, and similar standards, which I group as ``Continental.'' Sections~\ref{sec:nonenglish} and~\ref{sec:Hooksc} have more on the topic, as well as the use of sort tags in Section~\ref{sec:IndexSort}. Continental standards format surnames only, both in the text and in the index. This conflicts with some deliberately ambiguous name forms in \textsf{nameauth}.\footnote{Ancient, Eastern, and suffixed name forms have the same pattern.}
+% To get formatting in the index one must add it in the macro arguments. The simplified interface aids this process. Continental users may have to implement their own capitalization features; see Sections~\ref{sec:standards} and~\ref{sec:Hooksc}.\medskip
 %
-% \noindent{\large\bfseries Formatting Attributes}\\[2ex]
-% \begin{tabular}{p{0.22\textwidth}p{0.6\textwidth}}
-% \quad\texttt{smallcaps} & Set the first use of an entire name in small caps.\\[1ex]
+% \noindent{\bfseries Formatting Attributes}\\[2ex]
+% \begin{tabular}{ll}
+% \quad\texttt{smallcaps} & Set the first use of an entire name in small caps.\footnotemark\\[1ex]
 % \quad\texttt{italic} & Set the first use of an entire name in italic.\\[1ex]
 % \quad\texttt{boldface} & Set the first use of an entire name in boldface.\\[1ex]
 % \quad\bfseries\texttt{noformat} & \bfseries Do not define a default format.\\[2ex]
-% \end{tabular}\\
-% The options that assign a font change are intended for ``quick'' solutions based on English typography. They change only \cmd{\NamesFormat}, the macro that formats first instances of names in the main matter.\\
+% \end{tabular}
+% \footnotetext{Many users will not be affected by these changes. Many prefer the \texttt{noformat} option. If you did use the default option in the past, you can recover that behavior with the \texttt{smallcaps} option.}
 %
-% \noindent\begin{tabular}{p{0.97\textwidth}}\toprule\hfil\bfseries Versions 2.5 and onward assign no default formatting to names.\hfil\\\bottomrule\end{tabular}\bigskip
+% The options that assign a font change are intended for ``quick'' solutions based on English typography. They change only \cmd{\NamesFormat}, the macro that formats first instances of names in the main matter.\bigskip
 %
-% Many users will not be affected by these changes because many prefer the |noformat| option. If you did use the default option in the past, you can recover that behavior with the |smallcaps| option.
+% \noindent\begin{tabular}{p{0.96\textwidth}}\toprule\hfil\bfseries Versions 2.5 and onward assign no default formatting to names.\hfil\\\bottomrule\end{tabular}
 % \clearpage
 %
 % \subsection{Quick Start Guide}
 % \label{sec:start}
 %
-%\subsubsection{Main Interface}
-% See Section~\ref{sec:Naming} for a proper description of \cmd{\Name}. Here we see briefly how to work with the classes of names in Section~\ref{sec:NameTypes}. We abbreviate the macro arguments \meta{forename(s)} with \meta{FNN} and \meta{surname(s)} with \meta{SNN}. Use the |nocomma| option especially when using Eastern names and ancient names.\bigskip
+% \subsubsection{Main Interface}
+% Here we see how \textsf{nameauth} implements the classes of names in Section~\ref{sec:NameTypes}, using \cmd{\Name} as an example (see Section~\ref{sec:Naming}). The required name for each class is the \meta{Surname(s)} argument (\meta{SNN}). Optional name arguments include \meta{Forename(s)} (\meta{FNN}), \meta{Alternate names} and \meta{affix}.\bigskip
 %
-% \noindent{\large\bfseries Western Names}
-% \begin{quote}
+% \noindent{\bfseries Western Names}
+% \ifDoTikZ
+% \begin{center}
 % \begin{tikzpicture}[line/.style={draw,thick}]
 %   \node [matrix,column sep=2.5cm] (tipsi) at (1.5,2.5)
 %   {
 %     \node(opt){\small Add to force full name.}; &
-%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[ ]| follows.}; \\
+%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[|\,|]| follows.}; \\
 %   };
 %   \node [matrix] (macro) at (1.1,1)
 %   {
@@ -777,15 +757,15 @@
 %   {
 %     \node[align=center](a1)
 %     {
-%       Forename(s)\\used in index
+%       \small Forename(s)\\\small used in index
 %     }; & & &
 %     \node[align=center](a2)
 %     {
-%       Surname(s)\\Surname(s)|,| affix\\``required name''
+%       \small Surname(s)\\\small Surname(s)|,| affix\\ \small``required name''
 %     }; & &
 %     \node[align=center](a3)
 %     {
-%       \meta{empty}\\Nickname(s)\\Full forenames, etc.
+%       \meta{empty}\\\small Nickname(s)\\\small Full forenames, etc.
 %     }; \\
 %   };
 %   \begin{scope}[every path/.style=line]
@@ -795,27 +775,32 @@
 %     \path (arg2) -- (a2);
 %     \path (arg3) -- (a3);
 %   \end{scope}
-% \end{tikzpicture}\\
-% Usual forms:\\[2ex]\small
-% \cmd{\Name}\oarg{FNN}\marg{SNN}\hfill|\Name[George]{Washington}|\IndexName[George]{Washington}\\[1ex]
-% \cmd{\Name}\oarg{FNN}\marg{SNN|,| affix}\hfill|\Name[John David]{Rockefeller, II}|\IndexName[John David]{Rockefeller, II}\\[2ex]
-% You must include the \meta{FNN} field with alternate forenames. The \meta{Alternate names} are swapped with the \meta{FNN}, but only in the body text:\\[1ex]
-% \cmd{\Name}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\\\hbox{}\hfill |\Name[Bob]{Hope}[Leslie Townes]|\IndexName[Bob]{Hope}\\\hbox{}\hfill |\Name[Clive Staples]{Lewis}[C.S.]|\IndexName[Clive Staples]{Lewis}\\[1ex]
-% \cmd{\Name}\oarg{FNN}\marg{SNN|,| affix}\oarg{Alternate names}\\\hbox{}\hfill |\Name[John David]{Rockefeller, IV}[Jay]|\IndexName[John David]{Rockefeller, IV}\\[2ex]\normalsize
-% The older syntax is \cmd{\Name}\marg{SNN}\oarg{affix}. See Section~\ref{sec:obsolete} for its usage and its shortcomings. It remains for backward compatibility.
-% \end{quote}\medskip
+% \end{tikzpicture}
+% \end{center}\vspace{-2ex}
+% \else\vfill\fi
+% \textbf{Usual forms:}\\[1ex]
+% {\small Forenames and affixes are in optional arguments and comma-delimited suffixes so they can drop in the text. Yet they always are included for consistent index entries.\\[1ex]
+% \cmd{\Name}\oarg{FNN}\marg{SNN}\dotfill|\Name[George]{Washington}|\IndexName[George]{Washington}\\
+% \cmd{\Name}\oarg{FNN}\marg{SNN|,| affix}\dotfill|\Name[John David]{Rockefeller, II}|\IndexName[John David]{Rockefeller, II}\\[1ex]
+% When using \meta{Alternate names}, the \meta{FNN} argument must have a name in it. The \meta{Alternate names} are swapped with the \meta{FNN}, but only in the body text:\\[1ex]
+% \cmd{\Name}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\\
+% \hbox{}\dotfill |\Name[Bob]{Hope}[Leslie Townes]|\IndexName[Bob]{Hope}\\
+% \hbox{}\dotfill |\Name[Clive Staples]{Lewis}[C.S.]|\IndexName[Clive Staples]{Lewis}\\
+% \cmd{\Name}\oarg{FNN}\marg{SNN|,| affix}\oarg{Alternate names}\\\hbox{}\dotfill |\Name[John David]{Rockefeller, IV}[Jay]|\IndexName[John David]{Rockefeller, IV}\\[1ex]
+% Western names cannot use the older syntax for affixes; see Sections~\ref{sec:obsolete} and~\ref{sec:Affix}.}\bigskip
 %
-% \noindent{\large\bfseries Eastern Names in the Text, Western-style Index}
-% \begin{quote}
+% \noindent{\bfseries Eastern Names in the Text, Western Index Entry}
+% \ifDoTikZ
+% \begin{center}
 % \begin{tikzpicture}[line/.style={draw,thick}]
 %   \node [matrix,column sep=1.5cm] (tipsi) at (0.5,2)
 %   {
 %     \node(opt){\small Add to force full name.}; &
-%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[ ]| follows.}; \\
+%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[|\,|]| follows.}; \\
 %   };
 %   \node [matrix] (macro) at (0,1)
 %   {
-%     \node(cmd){\bfseries\cmd{\Name}}; &
+%     \node(cmd){\bfseries\cmd{\RevName} \cmd{\Name}}; &
 %     \node(star){\bfseries\texttt{*}}; &
 %     \node(arg1){\bfseries\oarg{FNN}}; &
 %     \node(arg2){\bfseries\marg{SNN}}; &
@@ -825,11 +810,11 @@
 %   {
 %     \node(a1)
 %     {
-%       \quad Given name
+%       \strut\quad\small Given name
 %     }; &
 %     \node(a2)
 %     {
-%       \quad Family name
+%       \strut\quad\small Family name
 %     }; \\
 %   };
 %   \begin{scope}[every path/.style=line]
@@ -838,18 +823,20 @@
 %     \path (arg1) -- (a1);
 %     \path (arg2) -- (a2);
 %   \end{scope}
-% \end{tikzpicture}\\
-% Technically, these are Western name forms without affixes. The reversing macros (Section~\ref{sec:Eastern}) cause them to display in Eastern order in the body text only. The index entries are Western in fashion: \meta{SNN}, \meta{FNN}. This ``non-native'' form of Eastern names excludes both comma-delimited forms and the old syntax.
-% \end{quote}
+% \end{tikzpicture}
+% \end{center}\vspace{-2ex}
+% \else\vfill\fi
+% {\small Technically, these are Western name forms without affixes. The reversing macros, such as \cmd{\RevName} (Section~\ref{sec:Eastern}) cause them to display in Eastern order in the body text only. The index entries are Western in fashion: \meta{SNN}, \meta{FNN}. This ``non-native'' form of Eastern names conflicts with both comma-delimited forms and the old syntax.}
 % \clearpage
 %
-% \noindent{\large\bfseries Eastern Names in the Text, Eastern-style Index}
-% \begin{quote}
+% \noindent{\bfseries Eastern Names in the Text, Eastern Index Entry}
+% \ifDoTikZ
+% \begin{center}
 % \begin{tikzpicture}[line/.style={draw,thick}]
 %   \node [matrix,column sep=1cm] (tipsi) at (0.5,2)
 %   {
 %     \node(opt){\small Add to force full name.}; &
-%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[ ]| follows.}; \\
+%     \node[text width=3.5cm,align=left](grp){\small Add only if text in brackets |[|\,|]| follows.}; \\
 %   };
 %   \node [matrix] (macro) at (0,1)
 %   {
@@ -875,21 +862,23 @@
 %     \path (arg1) -- (a1);
 %     \path (arg1) -- (a2);
 %   \end{scope}
-% \end{tikzpicture}\\
-% Usual form:\\[2ex]\small
-% \cmd{\Name}\marg{SNN, FNN}\hfill|\Name{Yamamoto, Isoroku}|\IndexName{Yamamoto, Isoroku}\\[2ex]
-% These names truly are Eastern names. They take the form \meta{SNN FNN} in the index even if the reversing macros (Section~\ref{sec:Eastern}) put the names in Western order in the body text. We call this the ``native'' Eastern form.\\[2ex]\normalsize
-% The old form of Eastern names is \cmd{\Name}\marg{SNN}\oarg{FNN}. Again, this is retained only for backward compatibility. Cf. Section~\ref{sec:obsolete}.
-% \end{quote}\medskip
+% \end{tikzpicture}
+% \end{center}\vspace{-2ex}
+% \else\vfill\fi
+% \textbf{Usual form:}\\[1ex]
+% {\small The striking feature of Eastern, ancient, and medieval name forms is the use of the comma-delimited suffix for the personal name. These forms have the same syntax, but different meanings. For example, you would use \cmd{\RevName} only with the Eastern form.\\[1ex]
+% \cmd{\Name}\marg{SNN, FNN}\dotfill|\Name{Yamamoto, Isoroku}|\IndexName{Yamamoto, Isoroku}\\[1ex]
+% These names truly are Eastern names. They take the form \meta{SNN FNN} in the index even if the reversing macros (Section~\ref{sec:Eastern}) put the names in Western order in the body text. We call this the ``native'' Eastern form. The old syntax for  Eastern names is \cmd{\Name}\marg{SNN}\oarg{FNN}, retained for backward compatibility (Section~\ref{sec:obsolete}).}\bigskip
 %
-% \noindent{\large\bfseries Ancient Names}
-% \begin{quote}
+% \noindent{\bfseries Ancient Names}
+% \ifDoTikZ
+% \begin{center}
 % \begin{tikzpicture}[line/.style={draw,thick}]
-%   \node [matrix,column sep=1em] (tipsi) at (2,2)
+%   \node [matrix,column sep=0.9em] (tipsi) at (2,2)
 %   {
 %     \node(opt){\quad\small Add to force full name.}; &
 %     \node[text width=2.6cm,align=left](a1){\small Mononym\hfil\break Mononym, affix}; &
-%     \node[text width=3.3cm,align=left](grp){\small Add only if text in brackets |[ ]| follows.}; \\
+%     \node[text width=3.3cm,align=left](grp){\small Add only if text in brackets |[|\,|]| follows.}; \\
 %   };
 %   \node [matrix] (macro) at (1,1)
 %   {
@@ -897,7 +886,7 @@
 %     \node(star){\bfseries\texttt{*}}; &
 %     \node(arg1){\bfseries\marg{SNN}};  &
 %     \node(braces){\bfseries|{}|}; \\
-%   };\\
+%   };
 %   \begin{scope}[every path/.style=line]
 %     \path (opt) -- (star);
 %     \path (grp) -- (braces);
@@ -904,21 +893,20 @@
 %     \path (arg1) -- (a1);
 %   \end{scope}
 % \end{tikzpicture}
-% Usual form:\\[2ex]\small
-% \cmd{\Name}\marg{SNN}\hfill|\Name{Aristotle}|\IndexName{Aristotle}\\[1ex]
-% \cmd{\Name}\marg{SNN, affix}\hfill|\Name{Elizabeth, I}|\IndexName{Elizabeth, I}\\
-% \hbox{}\hfill|\Name{Attila, the Hun}|\IndexName{Attila, the Hun}\\[2ex]\normalsize
-% These forms are used for royalty, ancient figures, and other monomyms with or without suffixes.\footnote{Technically, the native Eastern forms and the \meta{Mononym, affix} forms are identical, although used in different contexts. You would not wish to reverse a royal name, for example.}
-% The older syntax takes the form \cmd{\Name}\marg{Mononym}\oarg{affix}. Cf. Section~\ref{sec:obsolete}.
-% \end{quote}
-%
-% Many commands in the main interface are variants of a base pattern, where \meta{prefix macro} consist of one or more of \cmd{\CapThis,} \cmd{\CapName,} \cmd{\RevName,} \cmd{\RevComma,} \cmd{\ShowComma,} and \cmd{\KeepAffix:}
-%
+% \end{center}\vspace{-2ex}
+% \else\vfill\fi
+% \textbf{Usual form:}\\[1ex]
+% {\small These forms are used for royalty and ancient figures. They have one or more personal names that may or may not have suffixes.\\[1ex]
+% \cmd{\Name}\marg{SNN}\dotfill|\Name{Aristotle}|\IndexName{Aristotle}\\
+% \cmd{\Name}\marg{SNN, affix}\dotfill|\Name{Elizabeth, I}|\IndexName{Elizabeth, I}\\
+% \hbox{}\dotfill|\Name{Attila, the Hun}|\IndexName{Attila, the Hun}\\[1ex]
+% The older syntax takes the form \cmd{\Name}\marg{Mononym}\oarg{affix}. Cf. Section~\ref{sec:obsolete}.}
+% \begin{center}\bfseries Many macros in the main interface form a pattern, \emph{e.g.}:\end{center}% 
 % \begin{center}\small\setstretch{1.1}
-% \begin{tabular}{r@{\,}r@{}c@{\,}c@{ }l}\toprule
-% \meta{prefix macro} & \cmd{\Name} & & \meta{arguments} \\
-% \meta{prefix macro} & \cmd{\Name} & |*| & \meta{arguments} \\
-% \meta{prefix macro} & \cmd{\FName} & & \meta{arguments} \\\midrule
+% \begin{tabular}{l@{\,}r@{}c@{\,}c@{ }l}\toprule
+% \meta{prefix macros}\footnotemark & \cmd{\Name} & & \meta{arguments} \\
+% \meta{prefix macros} & \cmd{\Name} & |*| & \meta{arguments} \\
+% \meta{prefix macros} & \cmd{\FName} & & \meta{arguments} \\\midrule
 % & \cmd{\IndexName} & & \meta{arguments} \\
 % & \cmd{\ForgetName} & & \meta{arguments} \\
 % & \cmd{\SubvertName} & & \meta{arguments} \\
@@ -928,6 +916,7 @@
 % & \cmd{\ExcludeName} & & \meta{arguments} \\\bottomrule
 % \end{tabular}
 % \end{center}
+% \footnotetext{The \meta{prefix macros} include one or more of \cmd{\CapThis,} \cmd{\AccentCapThis,} \cmd{\CapName,} \cmd{\RevName,} \cmd{\RevComma,} \cmd{\ShowComma,} \cmd{\NoComma,} and \cmd{\KeepAffix.}}
 % \clearpage
 %
 % \subsubsection{Simplefied Interface}
@@ -938,16 +927,16 @@
 %
 % The simplified interface produces control sequences that are fully compatible with the main interface. Although not required, |nameauth| is best used in the document preamble to avoid undefined control sequences.\footnote{The |nameauth| environment uses \cmd{\ignorespaces} to mitigate the need for trailing \texttt{\%.}} The italicized comments at right are not part of the example proper, but are there for explanation. Macro fields have uniform widths only to help compare argument types.
 %
-% \begin{quote}\small\setstretch{1.2}
+% \begin{quote}\small\setstretch{1.1}
 % |\begin{nameauth}|\\
-% |  \<| \meta{cseq1} |&| \meta{FNN} |&| \meta{SNN}\hphantom{\textit{affix, }} |& >|\hfill\emph{Western}\footnote{This is also the form used with ``non-native'' Eastern names using reversing macros, but leaving them in Western form in the index.}\\
-% |  \<| \meta{cseq2} |&| \meta{FNN} |&| \meta{SNN, affix} |& >|\hfill\emph{Western}\\
-% |  \<| \meta{cseq3} |&| \meta{FNN} |&| \meta{SNN}\hphantom{\textit{affix, }} |&| \meta{Alt. names} |>|\hfill\emph{W. nickname}\footnote{When the \meta{Alt. names} is used, \meta{FNN} never appears in the body text, but only in the index. See Section \ref{sec:Fname} to avoid possible difficulties. You could use \cmd{\AKA} to create a \emph{see} reference for the \AKA[John David]{Rockefeller, IV}[Jay]{Rockefeller} example on the next page; see Section~\ref{sec:AKA}.}\\
-% |  \<| \meta{cseq4} |&| \meta{FNN} |&| \meta{SNN, affix} |&| \meta{Alt. names} |>|\hfill\emph{W. nickname}\\
-% |  \<| \meta{cseq5} |&| \hphantom{\meta{FNN}} |&| \meta{SNN}\hphantom{\textit{affix, }} |& >|\hfill\emph{ancient/mono}\\
-% |  \<| \meta{cseq6} |&| \hphantom{\meta{FNN}} |&| \meta{SNN, affix} |& >|\hfill\emph{royal/ancient}\\
-% |  \<| \meta{cseq7} |&| \hphantom{\meta{FNN}} |&| \meta{SNN, FNN} |& >|\hfill\emph{Eastern}\footnote{``Native'' Eastern names can be reversed to use Western order in the body text, but they will always have an Eastern form in the index.}\\
-% |  \<| \meta{cseq8} |&| \hphantom{\meta{FNN}} |&| \meta{SNN}\hphantom{\textit{affix, }} |&| \meta{FNN/affix} |>|\hfill\emph{old syntax}\footnote{This is the old syntax for Eastern and royal names.}\\
+% |  \<| \meta{cseq1} |&| \meta{FNN} |&| \meta{SNN}\hphantom{\textit{affix, }} \,|& >|\hfill\emph{Western}\footnote{This is also the form used with ``non-native'' Eastern names using reversing macros, but leaving them in Western form in the index.}\\
+% |  \<| \meta{cseq2} |&| \meta{FNN} |&| \meta{SNN, affix} \,|& >|\hfill\emph{Western}\\
+% |  \<| \meta{cseq3} |&| \meta{FNN} |&| \meta{SNN}\hphantom{\textit{affix, }} \,|&| \meta{Alt. names} |>|\hfill\emph{W. nickname}\footnote{When the \meta{Alt. names} is used, \meta{FNN} never appears in the body text, but only in the index. See Section \ref{sec:Fname} to avoid possible difficulties. You could use \cmd{\AKA} to create a \emph{see} reference for the \AKA[John David]{Rockefeller, IV}[Jay]{Rockefeller} example on the next page; see Section~\ref{sec:AKA}.}\\
+% |  \<| \meta{cseq4} |&| \meta{FNN} |&| \meta{SNN, affix} \,|&| \meta{Alt. names} |>|\hfill\emph{W. nickname}\\
+% |  \<| \meta{cseq5} |&| \hphantom{\meta{FNN}} |&| \meta{SNN}\hphantom{\textit{affix, }} \,|& >|\hfill\emph{ancient/mono}\\
+% |  \<| \meta{cseq6} |&| \hphantom{\meta{FNN}} |&| \meta{SNN, affix} \,|& >|\hfill\emph{royal/ancient}\\
+% |  \<| \meta{cseq7} |&| \hphantom{\meta{FNN}} |&| \meta{SNN, FNN}\,|& >|\hfill\emph{Eastern}\footnote{``Native'' Eastern names can be reversed to use Western order in the body text, but they will always have an Eastern form in the index.}\\
+% |  \<| \meta{cseq8} |&| \hphantom{\meta{FNN}} |&| \meta{SNN}\hphantom{\textit{affix, }} \,|&| \meta{FNN/affix} |>|\hfill\emph{old syntax}\footnote{This is the old syntax for Eastern and royal names.}\\
 % |\end{nameauth}|
 % \end{quote}
 %
@@ -956,19 +945,17 @@
 % \begin{itemize}\small
 % \item In this context, ``|\<|'' is an escape character and a control sequence. If you forget it or just use |<| without the backslash, you will get errors.
 % \item There \emph{must} be four argument fields (three ampersands) per line. Leaving out an ampersand will cause an error. Think ``holy hand grenade of Antioch'' from \emph{Monty Python and the Holy Grail}.
-% \item Leading and trailing spaces in each |&|-delimited field are stripped, as is also the case in the main interface.
-% \item As in the main interface, medial spaces do not affect first-use control sequences, but they will affect name forms in the body text and index.
+% \item Extra spaces in each |&|-delimited field are stripped, as is also the case in the main interface (Section~\ref{sec:tolerance}).
 % \item In the document text, as with the main interface, include trailing braces |{|\,|}|, control spaces, or the like if text in brackets |[|\,|]| follows any of the shorthands, \emph{e.g.}, |\LWash{} [\emph{sic}].|
-% \item The old syntax (Section~\ref{sec:obsolete}), triggered by an empty \meta{FNN} field, causes the \meta{Alt. names} field to be interpreted as either Eastern \meta{FNN} or an \meta{affix}. Due to its limitations and potential confusion, you are encouraged to avoid it unless you are using the \texttt{comma} option.
+% \item The old syntax (Section~\ref{sec:obsolete}), triggered by an empty \meta{FNN} field, causes the \meta{Alt. names} field to be interpreted as either \meta{Eastern FNN} or an \meta{affix}.
 % \end{itemize}
 % \clearpage
 %
-%  The example below illustrates a fairly complete set of names, apart from some special cases covered elsewhere in the manual:
-%
+%  This example of the \texttt{nameauth} environment uses a fairly complete set of names, apart from some special cases. See how one can choose to line up the ampersands with extra spaces or not. Following that are examples of shorthand use in the body text. One may compare the forms in the text with the index.
 % \begin{quote}\small\setstretch{1.1}
 % |\begin{nameauth}|\\[0.2ex]
-% |  \< Wash & George & Washington & >|\hfill\emph{Western}\\
-% |  \< Soto & Hernando & de Soto & >|\hfill\emph{particle}\\
+% |  \< Wash & George     & Washington      & >|\hfill\emph{Western}\\
+% |  \< Soto & Hernando   & de Soto         & >|\hfill\emph{particle}\\
 % |  \< JRII & John David & Rockefeller, II & >|\hfill\emph{affix}\\
 % |  \< JRIV & John David & Rockefeller, IV & >|\hfill\emph{affix}\\
 % |  \< JayR & John David & Rockefeller, IV & Jay >|\hfill\emph{nickname}\\
@@ -982,89 +969,92 @@
 % |\end{nameauth}|
 % \end{quote}
 %
-% Now we see how this works in the body text, which you can compare with the index. A dagger (\dag) indicates an Eastern name with a Western index form.
+% Below, ``non-native'' Eastern name forms are shown with a dagger (\dag). Please see Section~\ref{sec:Eastern} to avoid pitfalls with the reversing macros. We show first uses of names in italic type.
+% \begin{center}\footnotesize\setstretch{1.1}\def\NamesFormat{\itshape}
+% \begin{tabular}{ll}
+% \noindent\textbf{Western:}        & \textbf{Ancient\,/\,Mononym}\\
+% |\Wash|\dotfill  \Wash            & |\Aris|\dotfill \Aris\\
+% |\LWash|\dotfill \LWash           & |\Aris|\dotfill \Aris\\
+% |\Wash|\dotfill \Wash             & \\
+% |\SWash|\dotfill \SWash           & \textbf{Medieval/Royal:}\\
+% |\RevComma\LWash|                 & |\Eliz|\dotfill \Eliz\\
+% \dotfill \RevComma\LWash          & |\Eliz|\dotfill \Eliz\\
+%                                   & |\Attil|\dotfill \Attil\\
+% \textbf{Particles:}               & |\Attil|\dotfill \Attil\\
+% |\Soto|\dotfill \Soto             & \\
+% |\Soto|\dotfill \Soto             & \textbf{Western / Western Index:}\\
+% |\CapThis\Soto|\dotfill \CapThis\Soto & |\Konoe|\dotfill \Konoe\\
+%                                   & |\LKonoe|\dotfill \LKonoe\\
+% \textbf{Affixes:}                 & |\Konoe|\dotfill \Konoe\\
+% |\JRII|\dotfill \JRII             & \\
+% |\LJRII|\dotfill \LJRII           & \textbf{Eastern / Western Index:}\\
+% |\JRII|\dotfill \JRII             & |\CapName\RevName\LKonoe|\\
+% |\SJRII|\dotfill \SJRII           & \dotfill\CapName\RevName\LKonoe\dag\\
+%                                   & |\CapName\Konoe|\dotfill \CapName\Konoe\dag\\
+% \textbf{Nicknames:} (Section~\ref{sec:Fname}) \\
+% |\JRIV|\dotfill \JRIV             & \textbf{Eastern / Eastern Index:}\\
+% |\LJRIV[Jay]|\dotfill \LJRIV[Jay] & |\CapName\Yamt|\\
+% |\SJRIV[Jay]|\dotfill \SJRIV[Jay] & \dotfill \CapName\Yamt\\
+% |\SJRIV[Jay]| |\JRIV| \SJRIV[Jay] \JRIV & |\CapName\LYamt|\\
+% |\LJayR|\dotfill \LJayR           & \dotfill \CapName\LYamt\\
+% |\SJayR|\dotfill \SJayR           & |\CapName\Yamt|\dotfill \CapName\Yamt\\
+% |\SJayR\ \JayR|\dotfill \SJayR\ \JayR & \\
+% |\Lewis|\dotfill \Lewis           & \textbf{Western / Eastern Index:}\\
+% |\Lewis|\dotfill \Lewis           & |\RevName\LYamt|\\
+% |\LJack|\dotfill \LJack           & \dotfill \RevName\LYamt\\
+% |\SJack|\dotfill \SJack           & |\Yamt|\dotfill \Yamt\\
+% \end{tabular}
+% \end{center}
+% \clearpage
 %
-% \begin{multicols}{2}\small\setstretch{1.1}
-% \noindent\textbf{Basic Uses:}\\
-% |\Wash|\hfill  \Wash \\
-% |\LWash|\hfill \LWash \\
-% |\Wash|\hfill \Wash \\
-% |\SWash|\hfill \SWash \\[1ex]
-% \textbf{Western Reversed with Comma:}\\
-% |\RevComma\LWash|\hfill \RevComma\LWash \\[1ex]
-% \textbf{Particles:}\\
-% |\Soto|\hfill \Soto \\
-% |\Soto|\hfill \Soto \\
-% |\CapThis\Soto|\hfill \CapThis\Soto \\[1ex]
-% \textbf{Affixes:}\\
-% |\JRII|\hfill \JRII \\
-% |\LJRII|\hfill \LJRII \\
-% |\JRII|\hfill \JRII \\[1ex]
-% \textbf{Nicknames:} (See Section~\ref{sec:Fname})\\
-% |\JRIV|\hfill \JRIV \\
-% |\LJRIV[Jay]|\hfill \LJRIV[Jay] \\
-% |\SJRIV[Jay]|\hfill \SJRIV[Jay] \\
-% |\SJRIV[Jay] \JRIV|\hfill \SJRIV[Jay] \JRIV\\
-% |\LJayR|\hfill \LJayR \\
-% |\SJayR|\hfill \SJayR \\
-% |\SJayR\ \JayR|\hfill \SJayR\ \JayR\\
-% |\Lewis|\hfill \Lewis\\
-% |\Lewis|\hfill \Lewis\\
-% |\LJack|\hfill \LJack\\
-% |\SJack|\hfill \SJack\columnbreak\\
-% \textbf{Ancient:}\\
-% |\Aris|\hfill \Aris \\
-% |\Aris|\hfill \Aris \\[3.2ex]
-% \textbf{Medieval/Royal:}\\
-% |\Eliz|\hfill \Eliz \\
-% |\Eliz|\hfill \Eliz \\
-% |\Atil|\hfill \Attil \\
-% |\Atil|\hfill \Attil \\[3.3ex]
-% \textbf{Western / Western Index:}\\
-% |\Konoe|\hfill \Konoe \\
-% |\LKonoe|\hfill \LKonoe \\
-% |\Konoe|\hfill \Konoe \\[3.3ex]
-% \textbf{Eastern / Western Index:}\\
-% |\CapName\RevName\LKonoe|\\\hbox{}\hfill \indent\dag\CapName\RevName\LKonoe \\
-% |\CapName\Konoe|\hfill \dag\CapName\Konoe \\[3.2ex]
-% \textbf{Eastern / Eastern Index:}\\
-% |\CapName\Yamt|\hfill \CapName\Yamt \\
-% |\CapName\LYamt|\hfill \CapName\LYamt \\
-% |\CapName\Yamt|\hfill \CapName\Yamt \\[3.3ex]
-% \textbf{Western / Eastern Index:}\\
-% |\RevName\LYamt|\hfill \RevName\LYamt \\
-% |\Yamt|\hfill \Yamt
-% \end{multicols}
+% Sections~\ref{sec:standards},\marginpar{\small\raggedleft\dbend} \ref{sec:accents}, and~\ref{sec:IndexSort} deal with the pitfalls of accents and capitalization, as well as why you should use \cmd{\PretagName} for any name with control sequences or extended Unicode under NFSS. This becomes very important when authors and publishers use medieval names as Western names.
 %
-% Sections~\ref{sec:standards}, \ref{sec:accents}, and~\ref{sec:IndexSort} deal with the pitfalls of accents and capitalization, as well as why you should use \cmd{\PretagName} for any name with control sequences or extended Unicode under NFSS. This becomes very important when authors and publishers use medieval names as Western names.
+% When index tagging or pre-tagging names, the \meta{Alternate names} field has no effect on index tags because it appears only in the text. \cmd{\JRIV} and \cmd{\JayR} need only one tag, as do \cmd{\Lewis} and \cmd{\Jack}:
+% \begin{quote}\small\setstretch{1.1}
+% |\TagName[John David]{Rockefeller, IV}{|\meta{something}|}|\\
+% |\TagName[Clive Staples]{Lewis}{|\meta{something}|}|
+% \end{quote}
 %
-% When index tagging or pre-tagging names (Section~\ref{sec:IndexSort}), the \meta{Alternate names} field has no effect on index tags. \cmd{\JRIV} and \cmd{\JayR} need only one tag:\\[1ex] \hbox{}\qquad|\TagName[John David]{Rockefeller, IV}{|\meta{something}|}|\\[1ex] Likewise, \cmd{\Lewis} and \cmd{\Jack} need only one tag:\\[1ex]\hbox{}\qquad|\TagName[Clive Staples]{Lewis}{|\meta{something}|}|
-%
 % \subsubsection{Older Syntax}
 % \label{sec:obsolete}
 %
-% An ``obsolete'' syntax remains for backward compatibility with early versions of \textsf{nameauth} and with the \texttt{comma} option. Please avoid mixing the older and newer forms to avoid possible confusion and error. For example, the older syntax causes the \meta{Alternate names} field in the index tagging functions to become as significant as \meta{FNN}, including the need to pretag such names.
+% An older syntax remains for backward compatibility with early versions of \textsf{nameauth}. The old syntax limits the use of \cmd{\AKA} and its derivatives. Section~\ref{sec:error} and other places offer cautions about the old syntax. The form is:
 %
-% The \texttt{comma} option causes Western names with affixes to have a comma. Yet that also causes Eastern and ancient names, or any names using a pattern like \meta{SNN, affix} or \meta{SNN, FNN} to display a comma where it should not occur. The old form lacks some error checking and robustness contained in the new syntax and limits the use of several macros, including \cmd{\AKA.} Section~\ref{sec:error} offers some cautions about the old syntax, as do many places in this manual. The form is:
-%
-% \begin{quote}
+% \begin{quote}\setstretch{1.1}
 % |\Name{Dagobert}[I]|\hfill\emph{royal name}\\
 % |\Name{Yoshida}[Shigeru]|\hfill\emph{Eastern name}\\
 % |\begin{nameauth}|\\[0.5ex]
 % |  \< Dagb & & Dagobert & I >|\hfill\emph{royal name}\\
 % |  \< Yosh & & Yoshida & Shigeru >|\hfill\emph{Eastern name}\\
-% |\end{nameauth}|\\[2ex]
-% Here the \meta{FNN} fields are empty. That changes the final field from \meta{Alternate names} to \meta{affix/Eastern FNN}.
+% |\end{nameauth}|
+% \end{quote}
+% Here the \meta{FNN} fields are empty. Because that is the case, the final field changes its meaning from \meta{Alternate names} to \meta{affix} or \meta{FNN}. That means the final field will appear in the index. With this example, we have:
 %
-% |\Dagb| gives \Dagb, then \Dagb. In similar fashion, we see |\LDagb| \LDagb, |\CapName\Yosh| \CapName\Yosh, and |\CapName\RevName\LYosh| \CapName\RevName\LYosh.
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\Name{Henry}[VIII]| & \Name{Henry}[VIII]\\
+% |\Name{Henry}[VIII]| & \Name{Henry}[VIII]\\
+% |\Name{Chiang}[Kai-shek]| & \Name{Chiang}[Kai-shek]\\
+% |\Name{Chiang}[Kai-shek]| & \Name{Chiang}[Kai-shek]\\\midrule
+% |\Dagb| & \Dagb\\
+% |\Dagb| & \Dagb\\
+% |\CapName\Yosh| & \CapName\Yosh\\
+% |\CapName\RevName\LYosh| & \CapName\RevName\LYosh\\\bottomrule
+% \end{tabular}
+% \end{center}
+%
+% \noindent{\bfseries Additional Notes}\medskip
+%
+% \noindent|\Name{Henry}[VIII]|\marginpar{\small\raggedleft\dbend} (old syntax) will share name occurrences, tags, and index entries with |\Name{Henry, VIII}| (new syntax), as we see below. Yet we do not recommend the random admixture of these forms.
+% \begin{quote}\small\setstretch{1.1}
+% \NameAddInfo{Henry}[VIII]{ (\emph{Defensor Fidei})}|\NameAddInfo{Henry}[VIII]{ (\emph{Defensor Fidei})}|\\
+% \texttt{\dots}\\
+% |\Name*{Henry, VIII}\NameQueryInfo{Henry, VIII}|\\
+% \Name*{Henry, VIII}\NameQueryInfo{Henry, VIII}
 % \end{quote}
 %
-% In the old syntax, |\Name{Henry}[VIII]| prints ``\Name{Henry}[VIII]'' and ``\Name{Henry}[VIII].'' If you mix |\Name{Henry}[VIII]| with the newer |\Name{Henry, VIII}| they both print \Name{Henry, VIII} and \Name{Henry, VIII} in the body text. Yet they generate different control sequences for both first/subsequent uses and index tags.\footnote{Technically you can mix the two, as I do here. You must force first and subsequent uses with \cmd{\ForgetName} and \cmd{\SubvertName}. You must make common index tags, \emph{e.g.}: \cmd{\TagName}\texttt{\{Henry, VIII\}\{, king\}} and \cmd{\TagName}\texttt{\{Henry\}[VIII]\{, king\}}. That undermines the time-saving features offered by this package.}
-%
 % \IndexInactive%
-% Avoid |\Name{Henry, VIII}[Tudor]| unless you want ``\Name*{Henry, VIII}[Tudor]'' and ``\Name{Henry, VIII}[Tudor]'' in the body text and ``Henry VIII Tudor'' in the index.
-% \IndexActive%
-% One solution adds ``Tudor'' as needed in the text after |\Name{Henry, VIII}| and uses a tag in the index: |\TagName{Henry, VIII}{ Tudor}| (see Section \ref{sec:TagName}).
+% Avoid\marginpar{\small\raggedleft\dbend} blending old and new syntax forms together in one name reference. |\Name{Henry, VIII}[Tudor]| prints ``\Name*{Henry, VIII}[Tudor]'' and ``\Name{Henry, VIII}[Tudor]'' in the body text and ``Henry VIII Tudor'' in the index. Sections~\ref{sec:tagtext} and~\ref{sec:TagName} offer more elegant solutions that add ``Tudor'' either as a text tag or an index tag.
 %
 % \clearpage
 %
@@ -1075,9 +1065,8 @@
 % 
 % \DescribeMacro{\Name}
 % \DescribeMacro{\Name*}
-% This macro generates two forms of the name: a printed form in the text and a form of the name that occurs in the index.
-% The general syntax is:
-% \begin{quote}
+% This macro generates an index entry, a name in the body text, and another index entry for that name in case it spans a page break. \cmd{\FName} (next page) handles index entries in the same manner. The general syntax is:
+% \begin{quote}\small\setstretch{1.1}
 % \cmd{\Name}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\\
 % \cmd{\Name*}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
@@ -1084,7 +1073,7 @@
 %
 % \noindent Here we see how the syntax works:
 %
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{ll}\toprule
 % |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
 % |\Name*[Albert]{Einstein}| & \Name*[Albert]{Einstein}\\
@@ -1099,25 +1088,23 @@
 % |\Name*{Charles, the Bald}| & \Name*{Charles, the Bald}\\
 % |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
 % \cmd{\Name} displays and indexes names, as illustrated in Section~\ref{sec:PatRef}. It always prints the \meta{SNN} field. \cmd{\Name} prints the ``full name'' at the first occurrence, then the partial form thereafter. \cmd{\Name*} always prints the full name.
 %
 % The \meta{Alternate names} field replaces the \meta{FNN} field in the body text only. It does this if the \meta{FNN} field is not empty; see ``\Name[M.T.]{Cicero}[Marcus Tullius]'' above. Regarding their index entries, |\Name[M.T.]{Cicero}[Marcus Tullius]| and |\Name[M.T.]{Cicero}| are equivalent. This lets one use a nickname while keeping the indexed form constant. If the \meta{FNN} is empty, you get the old syntax for Eastern and royal names (Section~\ref{sec:obsolete}).
 %
-% \begin{quote}
-%|\begin{nameauth}|\\
-%|  \< Einstein & Albert & Einstein & >|\\
-%|  \< Cicero & M.T. & Cicero & >|\\
-%|  \< Confucius & & Confucius & >|\\
-%|  \< CBald & & Charles, the Bald & >|\\
-%|\end{nameauth}|
-%\end{quote}
+% \begin{quote}\small\setstretch{1.1}
+% |\begin{nameauth}|\\
+% |  \< Einstein & Albert & Einstein & >|\\
+% |  \< Cicero & M.T. & Cicero & >|\\
+% |  \< Confucius & & Confucius & >|\\
+% |  \< CBald & & Charles, the Bald & >|\\
+% |\end{nameauth}|
+% \end{quote}
 %
 % \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}%
-% Here we have the equivalent with the simplified interface. |\Einstein,| |\LEinstein,| and |\Einstein| produce \Einstein, \LEinstein, and \Einstein. |\CBald| and |\CBald| give \CBald\ and \CBald. |\Confucius| yields \Confucius.
-%
-% |\Cicero| prints \Cicero\ and \Cicero, while |\LCicero[Marcus Tullius]| gives \LCicero[Marcus Tullius]. The next page explains why this form may be preferable in some cases for name variants when using the simplified interface.
+% Here we have the equivalent with the simplified interface. |\Einstein,| |\LEinstein,| and |\Einstein| produce \Einstein, \LEinstein, and \Einstein. |\CBald| and |\CBald| give \CBald\ and \CBald. |\Confucius| yields \Confucius. |\Cicero| prints \Cicero\ and \Cicero. The preferred way to get alternate names is |\LCicero[Marcus Tullius]|: \LCicero[Marcus Tullius].
 % \clearpage
 %
 % \subsubsection{Forenames: \texttt{\textbackslash FName}}
@@ -1127,13 +1114,13 @@
 % \DescribeMacro{\FName*}
 % \cmd{\FName} and its synonym \cmd{\FName*} print just forenames, but only in subsequent name uses.\footnote{The two macros are the same in case you edit \cmd{\Name*} by adding an |F| to get a first reference, just as you might edit \cmd{\Name} the same way to get the same result.}
 % They are intended for Western-style names. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\FName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
-% This macro always prints a full name when a name is first used. That prevents a first-name reference before a person has been introduced.\footnote{One can force a short name by using \cmd{\SubvertName}\oarg{FNN}\marg{SNN} \cmd{\makeatletter} \cmd{\@nameauth at FirstFormattrue} \cmd{\makeatother} \cmd{\FName}\oarg{FNN}\marg{SNN}. Nevertheless, this seems to be overkill. It would be easier to type the name manually, then use \cmd{\IndexName.}}
-% By design, \cmd{\FName} \emph{never} prints Eastern personal names, so that ancient names also work (cf. Section~\ref{sec:PatRef}). Examples of general use include: \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}%
+% This macro prints a full name, not a short name, when a name is first used. That prevents a first-name reference before a person has been introduced. Section~\ref{sec:Tweaks} has more on this. By design, \cmd{\FName} \emph{never} prints Eastern personal names, so that ancient names also work (cf. Section~\ref{sec:PatRef}). Examples of general use include: %
 %
-% \begin{quote}\small\setstretch{1.2}
+% \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}%
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{ll}\toprule
 % |\FName[Albert]{Einstein}| & \FName[Albert]{Einstein}\\
 % |\FName[Albert]{Einstein}| & \FName[Albert]{Einstein}\\\midrule
@@ -1143,12 +1130,12 @@
 % |\FName[M.T.]{Cicero}[Marcus Tullius]| & \FName[M.T.]{Cicero}[Marcus Tullius]\\\midrule
 % |\FName{Charles, the Bald}| & \FName{Charles, the Bald}\\
 % |\FName{Charles, the Bald}| & \FName{Charles, the Bald}\\\bottomrule
-% \end{tabular}\\
-% \end{quote}
+% \end{tabular}
+% \end{center}
 %
 % With the simplified interface example from the previous page, |\SEinstein,| |\SConfucius,| |\SCicero,| and |\SCBald| give us \SEinstein, \SConfucius, \SCicero, and \SCBald. |\SCicero[Marcus Tullius]| gives \SCicero[Marcus Tullius]. However, with the macro |\FName[Chesley B.]{Sullenberger, III}[Sully]| we have ``\FName[Chesley B.]{Sullenberger, III}[Sully]'' and ``\FName[Chesley B.]{Sullenberger, III}[Sully].'' Please use caution!
 %
-%\ForgetName[Clive Staples]{Lewis} This may not always be a ``bug.'' Remembering Section~\ref{sec:simplestart}, you can use \Lewis\ or ``\SJack.'' |\FName[Clive Staples]{Lewis}[C.S.]| or \cmd{\Lewis} gives the first form, while |\FName[Clive Staples]{Lewis}[Jack]| or \cmd{\Jack} gives the second.   |\SJayR| gave \ForgetName[John David]{Rockefeller, IV}\SJayR\ and \SJayR, but the index entry remains ``Rockefeller, John David, IV.''
+% \ForgetName[Clive Staples]{Lewis} This may not always be a ``bug.'' Remembering Section~\ref{sec:simplestart}, you can use \Lewis\ or ``\SJack.'' |\FName[Clive Staples]{Lewis}[C.S.]| or \cmd{\Lewis} gives the first form, while |\FName[Clive Staples]{Lewis}[Jack]| or \cmd{\Jack} gives the second.   |\SJayR| gave \ForgetName[John David]{Rockefeller, IV}\SJayR\ and \SJayR, but the index entry remains ``Rockefeller, John David, IV.''
 %
 % Using ``default nicknames'' in the simplified interface has some caveats:
 %
@@ -1156,7 +1143,7 @@
 % \< Ches & Chesley B. & Sullenberger, III & >%
 % \< Sully & Chesley B. & Sullenberger, III & Sully >%
 % \end{nameauth}%
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\begin{nameauth}|\\
 % |  \< Ches & Chesley B. & Sullenberger, III & >|\\
 % |  \< Sully & Chesley B. & Sullenberger, III & Sully >|\\
@@ -1163,8 +1150,8 @@
 % |\end{nameauth}|
 % \end{quote}
 %
-% \ForgetName[Chesley B.]{Sullenberger, III} The first use \cmd{\Ches} prints ``\Ches.'' Later, \cmd{\SChes} and \cmd{\SSully} print ``\SChes'' and ``\SSully.'' While |\SChes[Sully]| always gives ``\SChes[Sully],'' |\SSully[Chesley B.]| prints ``\SSully[Chesley B.].'' The \meta{Alternate names} field is always occupied when using \cmd{\Sully,} etc. Thus, the final |[Chesley B.]| is not a macro argument.
-%\clearpage
+% \ForgetName[Chesley B.]{Sullenberger, III} The\marginpar{\small\raggedleft\dbend} first use \cmd{\Ches} prints ``\Ches.'' Later, \cmd{\SChes} and \cmd{\SSully} print ``\SChes'' and ``\SSully.'' While |\SChes[Sully]| always gives ``\SChes[Sully],'' |\SSully[Chesley B.]| prints ``\SSully[Chesley B.].'' The \meta{Alternate names} field is always occupied when using \cmd{\Sully,} etc. Thus, the final |[Chesley B.]| is not a macro argument.
+% \clearpage
 %
 %
 % \subsection{Affixes and Eastern Names}
@@ -1172,9 +1159,9 @@
 % \subsubsection{Affixes Need Commas}
 % \label{sec:Affix}
 %
-% Comma-delimited affixes handle several different name types. \emph{Always include a comma as an affix delimiter}, even when the |nocomma| option does not print the comma. Extra spaces between the comma and affix are ignored. Extra commas have no effect. Other name types include royal, medieval, and Eastern names:
+% Comma-delimited affixes handle several different name types. \emph{Always include a comma as an affix delimiter}, even when the \texttt{nocomma} option does not print the comma. Extra spaces between the comma and affix are ignored. Other name types include royal, medieval, and Eastern names:
 %
-% \begin{quote}\small\ForgetName{Sun, Yat-sen}\setstretch{1.2}
+% \begin{center}\small\ForgetName{Sun, Yat-sen}\setstretch{1.1}
 % \begin{tabular}{ll}\toprule
 % |\Name[Oskar]{Hammerstein, II}| & \Name[Oskar]{Hammerstein, II}\\
 % |\Name[Oskar]{Hammerstein, II}| & \Name[Oskar]{Hammerstein, II}\\\midrule
@@ -1183,140 +1170,138 @@
 % |\Name{Sun, Yat-sen}| & \Name{Sun, Yat-sen}\\
 % |\Name{Sun, Yat-sen}| & \Name{Sun, Yat-sen}\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
-% You cannot use the old syntax with the \Name[Oskar]{Hammerstein, II} example. One must use comma-delimited suffixes when cross-referencing affixed Western names, royal names, some medieval names, and Eastern names with \cmd{\AKA}; see Section~\ref{sec:AKA}.\medskip
+% One\marginpar{\small\raggedleft\dbend} cannot use the old syntax with the \Name[Oskar]{Hammerstein, II} example. If you tried to use \IndexInactive|\Name[Oskar]{Hammerstein}[II]| you would get ``\Name[Oskar]{Hammerstein}[II].'' \IndexActive Western names with suffixes must use the new, comma-delimited syntax. Also, one must use comma-delimited suffixes to cross-reference all name forms with \cmd{\AKA}. For a full description see Section~\ref{sec:AKA}.\medskip
 %
 % \DescribeMacro{\KeepAffix}
-% Put \cmd{\KeepAffix} before \cmd{\Name} or \cmd{\AKA} if a line break or page break divides a \meta{SNN, affix} pair. This puts a non-breaking space between \meta{SNN} and \meta{affix} in the body text, but not in the index. Other options to fix bad breaks include using \cmd{\hbox}, kerning and spacing in the \textsf{microtype} package, etc.\medskip
+% Put \cmd{\KeepAffix} before \cmd{\Name} or \cmd{\AKA} if a \meta{SNN, affix} pair is split: ``\Name*{Louis, XIV}'' by a line break or page break. |\KeepAffix\Name*{Louis, XIV}| prevents that break by inserting a non-breaking space between \meta{SNN} and \meta{affix} (or \meta{SNN} and \meta{Eastern FNN}) in the body text, but not in the index. Spaces between multiple names in each name field are not affected. This works with all name types handled by \textsf{nameauth}, including the old syntax.\medskip
 %
 % \DescribeMacro{\ShowComma}
-% The \texttt{comma} option is restrictive and used to reproduce older texts. \cmd{\ShowComma} gets the same results on a per-name basis while using the default |nocomma| option. With |\ShowComma\Name[Louis]{Gossett, Jr.}| one gets \ShowComma\Name[Louis]{Gossett, Jr.}. One must use \cmd{\ShowComma} consistently or risk errors in the body text and index.\bigskip
+% If you do not want to use the \texttt{comma} option, \cmd{\ShowComma} gets the same results on a per-name basis for Western names while using the default \texttt{nocomma}. There is no affect on index entries. For example:
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\Name*[Louis]{Gossett, Jr.}| & \Name*[Louis]{Gossett, Jr.}\\
+% |\ShowComma\Name*[Louis]{Gossett, Jr.}| & \ShowComma\Name*[Louis]{Gossett, Jr.}\\\bottomrule
+% \end{tabular}
+% \end{center}\medskip
 %
-% \noindent{\large\bfseries Compare Older Syntax}\\[2ex]
-% Avoid using the older syntax, shown below, except with the \texttt{comma} option. The older syntax causes Eastern and ancient names that use the \meta{SNN, affix} pattern to have unwanted commas in them with the \texttt{comma} option or with \cmd{\ShowComma.} \cmd{\AKA} and \cmd{\PName} cannot create cross-references to these forms:
+% \DescribeMacro{\NoComma}
+% If you do wish to use the \texttt{comma} option, \cmd{\NoComma} can suppress a comma between the surname and affix on a per-name basis.\marginpar{\small\raggedleft\dbend} For example, we simulate the \texttt{comma} option for the two tables below:
+% \makeatletter\@nameauth at AlwaysCommatrue\makeatother
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\Name*[Louis]{Gossett, Jr.}| & \Name*[Louis]{Gossett, Jr.}\\
+% |\NoComma\Name*[Louis]{Gossett, Jr.}| & \NoComma\Name*[Louis]{Gossett, Jr.}\\\bottomrule
+% \end{tabular}
+% \end{center}
 %
-% \begin{quote}\small\ForgetName{Henry}[VIII]\setstretch{1.2}
+% This might be useful when making a comma-reversed form (Section~\ref{sec:LastFirst}) under the \texttt{comma} option, where you do not want the form \meta{SNN}|,| \meta{affix}|,| \meta{FNN}:
+% \begin{center}\footnotesize\setstretch{1.1}
 % \begin{tabular}{ll}\toprule
-% |\Name{Henry}[VIII]| & \Name{Henry}[VIII]\\
-% |\Name{Henry}[VIII]| & \Name{Henry}[VIII]\\\midrule
-% |\Name{Chiang}[Kai-shek]| & \Name{Chiang}[Kai-shek]\\
-% |\Name{Chiang}[Kai-shek]| & \Name{Chiang}[Kai-shek]\\\bottomrule
+% |\RevComma\Name*[Louis]{Gossett, Jr.}| & \RevComma\Name*[Louis]{Gossett, Jr.}\\
+% |\RevComma\NoComma\Name*[Louis]{Gossett, Jr.}| & \RevComma\NoComma\Name*[Louis]{Gossett, Jr.}\\\bottomrule
 % \end{tabular}
-% \end{quote}
-% These older forms work because no \meta{FNN} are present. Otherwise you would get weird nicknames. Again, to avoid potential frustration, please avoid using the older syntax unless you need it.
+% \end{center}
+% \makeatletter\@nameauth at AlwaysCommafalse\makeatother
+% One can switch freely among name forms, but remember that consistent use of \cmd{\ShowComma} and \cmd{\NoComma} is important when implementing name forms. The simplified interface can help with that.\medskip
+%
 % \clearpage
 %
 % \subsubsection{Eastern Names}
 % \label{sec:Eastern}
 %
-% The \textsf{nameauth} package offers ``non-native'' and ``native'' ways to handle romanized Eastern names. \cmd{\RevName}\cmd{\Name}\oarg{Eastern FNN}\marg{Eastern SNN} will produce an Eastern name in the body text and the Western form \meta{SNN}, \meta{FNN} in the index, including the comma. We call this ``non-native'' mode.
+% The reversing macros assume that you will be using long-name references, especially with ``native'' Eastern names. Please bear this in mind.
 %
-% In contrast, both \cmd{\Name}\marg{Eastern SNN, Eastern FNN} and the older syntax \cmd{\Name}\marg{Eastern SNN}\oarg{Eastern FNN} produce an Eastern name form in the body text: \meta{SNN} \meta{FNN} as well as in the index. This form has no comma in the index. We call this ``native'' mode.\medskip
+% The\marginpar{\small\raggedleft non-native} \textsf{nameauth} package offers ``non-native'' and ``native'' ways to handle romanized Eastern names. The ``non-native'' form really is a Western name (and it is indexed as such) that is made to look Eastern in the body text:
+% \begin{quote}\small
+%   \cmd{\RevName}\cmd{\Name*}\oarg{Eastern FNN}\marg{Eastern SNN}
+% \end{quote}
+% The index entry of this name form looks like \meta{SNN}, \meta{FNN} (including the comma). This type of entry is a Western form. Pick non-native Eastern names when you need to have Western name forms in the index entries.
 %
+% In\marginpar{\small\raggedleft non-native} contrast, there are two ways to make ``native'' Eastern name forms, which are indexed as such and appear in Eastern name order in the body text:
+% \begin{quote}\small\setstretch{1.1}
+% \cmd{\Name}\marg{Eastern SNN, Eastern FNN}\\
+% \cmd{\Name}\marg{Eastern SNN}\oarg{Eastern FNN}	(old syntax)
+% \end{quote}
+% The index entry of this name form looks like \meta{SNN} \meta{FNN} (no comma). This type of entry bears similarity with ancient and medieval forms. Pick native Eastern names when you want to use Eastern forms in the index.\medskip
+%
 % \DescribeMacro{\ReverseActive}
 % \DescribeMacro{\ReverseInactive}
 % \DescribeMacro{\RevName}
-% The ``smart'' reverse output mechanism converts between Western and Eastern forms in the text, but not the index. Pick non-native mode for Western-format index entries. Pick native mode for Eastern forms in the index. In addition to the class options described in Section~\ref{sec:options}, \cmd{\ReverseActive} and \cmd{\ReverseInactive} toggle reversing on a larger scale, while \cmd{\RevName} is used once per \cmd{\Name}.
+% In addition to the class options (Section~\ref{sec:options}), the macros \cmd{\ReverseActive} and \cmd{\ReverseInactive} toggle reversing on a larger scale, while \cmd{\RevName} is used once per name. The reverse output mechanism is designed to reverse full names only. Nevertheless, it does not force full names. Results vary, based on the type of Eastern name forms being used. Non-native forms are shown by a dagger (\dag):
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{lll}\toprule
+%  & \emph{unchanged} & |\RevName|\\\midrule
+% |\LKonoe|\dag & \LKonoe\dag & \RevName\LKonoe\dag\\
+% |\Konoe|\dag & \Konoe\dag & \RevName\Konoe\dag\\
+% |\LYamt| & \LYamt & \RevName\LYamt\\
+% |\Yamt| & \Yamt & \RevName\Yamt\\\bottomrule
+% \end{tabular}
+% \end{center}
 %
+% A striking feature above is that reversing a short native Eastern form will produce a personal name. This seems bad, especially when |\SYamt| \emph{does not} produce a first name ``\SYamt,'' while |\RevName\Attil| does. Yet |\RevName\Attil| can be used to get only the affix in \Attil\ ``\RevName\Attil'' instead of using the preferred method of text and index tags (Sections~\ref{sec:tagtext} and~\ref{sec:TagName}).\footnote{Name reversing is a design point that really needs review.}
+%
+% Creating ``last-comma-first'' listings by surname (Section~\ref{sec:LastFirst}) only makes sense with Western names and maybe non-native Eastern names, but not with native Eastern names or ancient forms.  
+%
 % Please\marginpar{\small\raggedleft\cmd{\global}} note that \cmd{\ReverseActive} and \cmd{\ReverseInactive} can be used explicitly as a pair. They also can be used singly within an explicit scope, where the effects cease after leaving that scope. Use \cmd{\global} to force a global effect.
+% \clearpage
 %
-% This list of Japanese music artists shows \cmd{\RevName} in action. Names in Western order, then non-native Eastern order are marked with a dagger ({\dag}). All other names are in native Eastern, then Western order. Forms using the old syntax are in parentheses:
+% Consider this list of Japanese music artists. All the name references are long names (\cmd{\Name*}). Names in Western order, then non-native Eastern order are marked with a dagger ({\dag}). All other names are in native Eastern, then Western order. Old-syntax forms have a double dagger(\ddag):
 %
-% 
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{lll}\toprule
 %  & \emph{unchanged} & |\RevName|\\\midrule
-% \dag|\Name*[Aiko]{Nakano}| & \dag\Name*[Aiko]{Nakano} & \dag\RevName\Name*[Aiko]{Nakano}\\
+% |\Name*[Aiko]{Nakano}|\dag & \Name*[Aiko]{Nakano}\dag & \RevName\Name*[Aiko]{Nakano}\dag\\
 % |\Name*{Arai, Akino}| & \Name*{Arai, Akino} & \RevName\Name*{Arai, Akino}\\
-% (|\Name*{Ishida}[Yoko]|) & (\Name*{Ishida}[Yoko]) & (\RevName\Name*{Ishida}[Yoko])\\
+% |\Name*{Ishida}[Yoko]|\ddag & \Name*{Ishida}[Yoko]\ddag & \RevName\Name*{Ishida}[Yoko]\ddag\\
 % |\Name*{Yohko}| & \Name*{Yohko} & \RevName\Name*{Yohko}\\\bottomrule
 % \end{tabular}
-% \end{quote}\smallskip
+% \end{center}\smallskip
 %
+%
 % \DescribeMacro{\AllCapsActive}
 % \DescribeMacro{\AllCapsInactive}
 % \DescribeMacro{\CapName}
-% Use \cmd{\AllCapsActive}, \cmd{\AllCapsInactive}, and \cmd{\CapName} for fully-capitalized family names in the body text. These macros are analogous to the reversing macros above and may be used alone or with those and other state-toggling macros, \emph{e.g.} \cmd{\CapName}\cmd{\RevName}\cmd{\Name}\marg{SNN, Affix}.
+% The \textsf{nameauth} package allows one to capitalize entire family names in the body text while keeping them in standard English form in the index. This capitalization is designed to work with Eastern name forms.
+% Use \cmd{\AllCapsActive}, \cmd{\AllCapsInactive}, and \cmd{\CapName} for fully-capitalized family names in the body text. These macros are analogous to the reversing macros above and may be used alone or with those and other prefix macros, \emph{e.g.}:
+% \begin{quote}\small
+%   \cmd{\CapName}\cmd{\RevName}\cmd{\Name*}\marg{SNN, Affix}.
+% \end{quote}
 %
 % Both\marginpar{\small\raggedleft\cmd{\global}} \cmd{\AllCapsActive} and \cmd{\AllCapsInactive} have the same local restrictions as the other state-changing macros. Use \cmd{\global} to force a global effect.
 %
-% In the example below, names in Western order, then non-native Eastern order are marked with a dagger ({\dag}). All other names are in native Eastern, then Western order. Forms using the old syntax are in parentheses:
+% In the example below, names in Western order, then non-native Eastern order are marked with a dagger ({\dag}). All other names are in native Eastern, then Western order. Old-syntax forms have a double dagger(\ddag):
 %
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{l@{ }l@{ }l}\toprule
 %  & \emph{unchanged} & |\CapName\RevName|\\\midrule
-% \dag|\Name*[Yoko]{Kanno}| & \dag\CapName\Name*[Yoko]{Kanno} & \dag\CapName\RevName\Name*[Yoko]{Kanno}\\
+% |\Name*[Yoko]{Kanno}|\dag & \CapName\Name*[Yoko]{Kanno}\dag & \CapName\RevName\Name*[Yoko]{Kanno}\dag\\
 % |\Name*{Shikata, Akiko}| & \CapName\Name*{Shikata, Akiko} & \CapName\RevName\Name*{Shikata, Akiko}\\
-% (|\Name*{Nogawa}[Sakura]|) & (\CapName\Name*{Nogawa}[Sakura]) & (\CapName\RevName\Name*{Nogawa}[Sakura])\\
+% |\Name*{Nogawa}[Sakura]|\ddag & \CapName\Name*{Nogawa}[Sakura]\ddag & \CapName\RevName\Name*{Nogawa}[Sakura]\ddag\\
 % |\Name*{Yohko}| & \CapName\Name*{Yohko} & \CapName\RevName\Name*{Yohko}\\\bottomrule
 % \end{tabular}
-% \end{quote}\smallskip
+% \end{center}\smallskip
 %
-% Capitalization and reversing precede post-processing. The reversing and capitalization macros also work with \cmd{\AKA}. They affect only the text, not the index. For caps in the text and index see Section~\ref{sec:formatting}.
-%
-% \subsection{Other Naming Topics}
-% {\hfill\large\bfseries\emph{Language-Related Issues}\hfill}\vspace{-2ex}
-%
-% \subsubsection{Particles}
-% \label{sec:standards}
-%
-% According to the \emph{Chicago Manual of Style}, English names with the particles \emph{de}, \emph{de\ la}, \emph{d'}, \emph{von}, \emph{van}, and \emph{ten} generally keep them with the last name, using varied capitalization. \emph{Le}, \emph{La}, and \emph{L'} always are capitalized unless preceded by \emph{de}.\medskip
-%
-% \DescribeMacro{\CapThis}
-% In English, these particles go in the \meta{SNN} field of \cmd{\Name}, \emph{e.g.}, \ForgetName[Walter]{de la Mare}\Name[Walter]{de la Mare}. |\CapThis\Name[Walter]{de la Mare}| lets you capitalize \emph{de} when at the beginning of a sentence. \CapThis\Name[Walter]{de la Mare} will think it fair. \CapThis\Soto\ (using |\CapThis\Soto| from Section~\ref{sec:simplestart}) would agree.
-%
-% It is a good idea to put |~| or \cmd{\nobreakspace} between particles and surnames to avoid bad breaks. This also prevents \cmd{\CapThis} from eating the space between a one-character particle and the surname (Section \ref{sec:Unicode}).
-%
-% The Continental style of handling surnames (Section~\ref{sec:formatting}) does not work with the capitalization macros. In the case of names like \Name[Catherine]{\textsc{de'~Medici}} use |\Name[Catherine]{\textsc{de'~Medici}}| and, instead of the capping macros, |\textsc{De'~Medici}\IndexName[Catherine]{\textsc{de'~Medici}}.|\medskip
-%
-% \DescribeMacro{\AccentCapThis}
-% With \texttt{pdflatex} and \textsf{inputenc}, use \cmd{\CapThis} when the first character of the particle is \texttt{A--z} (basic Latin). Use \cmd{\AccentCapThis} when the first character is extended Latin or other Unicode (see Section \ref{sec:Unicode}). Otherwise, with \texttt{pdflatex} \cmd{\CapThis} will fail if an extended Unicode character is the first letter of a particle.
-%
-% For example, \emph{L'} and \emph{d'} are two separate glyphs each, while \emph{Ľ} and \emph{ď} are one Unicode glyph each. Even with \texttt{xelatex} and \texttt{lualatex}, you would put a non-breaking space between the particle and the name because the particle is only one character. With \texttt{pdflatex} you also must use \cmd{\AccentCapThis.}
-%
-% Another example deals with particles and name forms:
-% \begin{quote}\small
-% |\PretagName{Thomas, à~Kempis}{Thomas a Kempis}|\hfill\emph{medieval}\\
-% |\PretagName[Thomas]{à~Kempis}{Thomas a Kempis}|\hfill\emph{Western}\\
-% |\begin{nameauth}|\\[0.2ex]
-% |  \< KempMed & & Thomas, à~Kempis & >|\hfill\emph{medieval}\\
-% |  \< KempW & Thomas & à~Kempis & >|\hfill\emph{Western}\\
-% |\end{nameauth}|
-% \end{quote}
-% The medieval forms \KempMed\ and \KempMed\ use the particle as the first part of an affix. Please do not confuse the medieval forms with the Western forms. Otherwise you will get similar names with different index entries.\footnote{Properly speaking, ``à~Kempis'' and ``Aquinas'' are not surnames but suffixed place names. They create different index entries from Western names and look different in the text.}
-%
-% \IndexInactive
-% Many people use medieval affixes as Western surnames: \SubvertName[Thomas]{à~Kempis}``\AccentCapThis\KempW.''\footnote{This treatment of medieval names, along with the handling of Eastern names, seems to be one of the most frequently ``abused'' issues in the academic literature that I know. In order to achieve simplicity in work flow or conformity, authors and publishers will take some fairly ethnocentric or heavy-handed approaches to names. The \textsf{nameauth} package will accommodate those approaches, even if I personally disagree with them.}
-% To get that form, use |\AccentCapThis\KempW.|
+% Capitalization and reversing precede post-processing. The reversing and capitalization macros also work with \cmd{\AKA}. They affect only the text, not the index. For caps in the text and index see Sections~\ref{sec:nonenglish} and~\ref{sec:Hooksc}.
 % \clearpage
 %
-% Section~\ref{sec:Unicode} explains in detail why the following problems can occur:
-% \begin{itemize}\small
-% \item |\CapThis\KempW| halts execution with \texttt{Argument of \textbackslash UTFviii at two@ octets has an extra \}.} 
-% \item |\AccentCapThis\Name[Thomas]{à Kempis}| gives ``\AccentCapThis\Name[Thomas]{à Kempis}'' (space removed). Instead, use |\AccentCapThis\Name[Thomas]{à~Kempis}.| 
-% \item Under \texttt{pdflatex} \cmd{\AccentCapThis} fails with particles like |lé|\,---\, use \cmd{\CapThis} in that case to avoid breaking the \emph{second} character.
-% \item |\AccentCapThis\Soto| gives \AccentCapThis\Soto. Only use it with accented first letters.
-% \end{itemize}
-% \IndexActive
+% \subsection{Other Naming Topics}\medskip
 %
-% You\marginpar{\small\raggedleft Alternates} could use name forms with braces, like |\Name[Thomas]{{à}~Kempis}|, and control sequences, like |\Name[Thomas]{\`a~Kempis}|. Using those forms consistently, with \cmd{\PretagName,} would require you to use \cmd{\CapThis,} never \cmd{\AccentCapThis}. See Section~\ref{sec:Unicode} for more details.
+% \begin{center}\large\bfseries Language-Related Issues\vspace{-2ex}\end{center}
 %
-% Non-English contexts do not necessarily bind particles to surnames. Using \cmd{\Name} and \cmd{\FName} with alternate forenames helps address this and may skirt the particle capitalization issue. See also Section~\ref{sec:Particles}.
-%
 % \subsubsection{Formatting Initials}
 %
-% Omit spaces between initials if possible; see also Bringhurst's \emph{Elements of Typographic Style}. If your publisher wants spaces between initials, try putting thin spaces |\,| between them. Use \cmd{\PretagName} to get the correct index sorting:
-% \begin{quote}
-% |\PretagName[E.\,B.]{White}{White, E. B.}|\\
+% Omit spaces between initials if possible; see also Bringhurst's \emph{Elements of Typographic Style}. If your publisher wants spaces between initials, try putting thin spaces |\,| between them. Use \cmd{\PretagName} to get the correct index sorting:\bigskip
+%
+% \leavevmode\begin{minipage}[c]{0.4\textwidth}\footnotesize\setstretch{1.1}
+% |\PretagName[E.\,B.]{White}%|\\
+% |  {White, E. B.}|\\
 % |\begin{nameauth}|\\
 % |  \< White & E.\,B. & White & >|\\
 % |\end{nameauth}|
-% \begin{nameauth}
-%   \< White & E.\,B. & White & >
-% \end{nameauth}
-% \end{quote}
-% \begin{quote}
+% \end{minipage}
+% \begin{minipage}[c]{0.4\textwidth}\footnotesize
 % \def\sep{\vrule width0.5pt\kern-0.5pt}%
 % \begin{tabular}{ll}\hline
 % & \hphantom{E.}\sep\,\sep\hphantom{B.}\sep\hphantom{\ }\sep\hphantom{White}\\
@@ -1326,36 +1311,38 @@
 % Normal text:\hfill & {E. B. White}\\
 % & \hphantom{E.}\sep\ \sep\hphantom{B.}\sep\ \sep\hphantom{White}\\\hline
 % \end{tabular}
-% \end{quote}
+% \end{minipage}
 %
 % \subsubsection{Hyphenation}
 %
-% The simplified interface trivializes the insertion of optional hyphens in names, but such hyphens must be used consistently in all the naming macros:
+% In English, some names come from other cultures. These names can break badly with standard hyphenation. The simplified interface trivializes the insertion of optional hyphens in names, but such hyphens must be used consistently:
 %
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\begin{nameauth}|\\
 % |  \< Bier & Johann & Bier\-mann & >|\\
-% |\end{nameauth}|
+% |\end{nameauth}|\\[2ex]
+% \texttt{\dots}|\IndexName[Johann]{Bier\-mann}|\IndexName[Johann]{Bier\-mann}
 % \end{quote}
-% We get \Bier\ and \Bier. English hyphenation can break ie-pairs and maybe others. One also can fix bad breaks with the \textsf{babel} or \textsf{polyglossia} packages. This moves the solution from ``quick and dirty'' to elegant. \Name[John]{Strietelmeier} can break badly in English, as you see. Using \textsf{babel}, we get:
-% \begin{quote}
-% \newcommand{\de}[1]{\foreignlanguage{ngerman}{#1}}%
-% |\newcommand{\de}[1]{\foreignlanguage{ngerman}{#1}}|\\
-% |\de{\Name*[John]{Strietelmeier}}|\\
-% \de{\Name*[John]{Strietelmeier}}
+%
+%  One also can fix bad breaks with the \textsf{babel} or \textsf{polyglossia} packages. This moves the solution from ``quick and dirty'' to elegant. We force a bad break: \Name[John]{Strietelmeier}. We can stop that using \textsf{babel}:
+% \begin{quote}\small\setstretch{1.1}
+% \newcommand\de[1]{\foreignlanguage{ngerman}{#1}}%
+% |\newcommand\de[1]{\foreignlanguage{ngerman}{#1}}|\\
+% |\de{\Name*[John]{Strietelmeier}}|
 % \end{quote}
 %
 % \subsubsection{Listing by Surname}
 % \label{sec:LastFirst}
 %
-%\DescribeMacro{\ReverseCommaActive}
-%\DescribeMacro{\ReverseCommaInactive}
-%\DescribeMacro{\RevComma}
-% The reversing macros \cmd{\ReverseCommaActive}, \cmd{\ReverseCommaInactive}, and \cmd{\RevComma}\ allow the easy generation of name lists ordered as \meta{SNN}, \meta{FNN} or \meta{SNN}, \meta{Alt. names}. The first two are broad toggles, while the third works on a per-name basis.
+% \DescribeMacro{\ReverseCommaActive}
+% \DescribeMacro{\ReverseCommaInactive}
+% \DescribeMacro{\RevComma}
+% The reversing macros \cmd{\ReverseCommaActive}, \cmd{\ReverseCommaInactive}, and \cmd{\RevComma}\ let us reorder long Western names (via \cmd{\Name*} and the like). The first two are broad toggles, while the third works on a per-name basis.
+%
 % Both\marginpar{\small\raggedleft\cmd{\global}} \cmd{\ReverseCommaActive} and \cmd{\ReverseCommaInactive} have the same local restrictions as the other state-changing macros unless you use \cmd{\global.}
-% Eastern, medieval, and royal names do not work with these macros:
+% Eastern, medieval, and royal names do not work with these macros.\footnote{Name reversing with commas is a design point that really needs review.}
 %
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{lll}\toprule
 % \Name*[J.S.]{Mill}[John Stuart] & \RevComma\Name*[J.S.]{Mill}[John Stuart] & OK\\
 % \Name*[Oskar]{Hammerstein, II} & \RevComma\Name*[Oskar]{Hammerstein, II} & OK\\
@@ -1363,52 +1350,66 @@
 % \Name*{Mao}[Tse-tung] & \RevComma\Name*{Mao}[Tse-tung] & incompatible\\
 % \Name*{Anaximander} & \RevComma\Name*{Anaximander} & OK\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
+% \clearpage
 %
-% {\hfill\large\bfseries\emph{Technical-Related Issues}\hfill}\vspace{-2ex}
-% \subsubsection{Fault Tolerance}
+% \subsubsection{Particles}
+% \label{sec:standards}
 %
-% The \textsf{nameauth} package protects against some typing errors and malformed input. Several macros ignore leading and trailing spaces, but not medial spaces as illustrated by the variations below that are automatically corrected:
+% According to the \emph{Chicago Manual of Style}, English names with the particles \emph{de}, \emph{de\ la}, \emph{d'}, \emph{von}, \emph{van}, and \emph{ten} generally keep them with the last name, using varied capitalization. \emph{Le}, \emph{La}, and \emph{L'} always are capitalized unless preceded by \emph{de}. This subsection deals mainly with accented names in English contexts.\medskip
 %
-% \begin{quote}\small\ForgetName[Martin Luther]{King, Jr.}\setstretch{1.2}
-% \begin{tabular}{ll}\toprule
-% \textit{Macro Example} & \textit{Resulting Text}\\\midrule
-% |\Name*[ Martin Luther]{King, Jr.}| & \Name*[ Martin Luther]{King, Jr.}\\
-% |\Name*[Martin Luther ]{King, Jr.}| & \Name*[Martin Luther ]{King, Jr.}\\
-% |\Name*[ Martin Luther ]{King, Jr.}| & \Name*[ Martin Luther ]{King, Jr.}\\
-% |\Name*[Martin Luther]{ King, Jr.}| & \Name*[Martin Luther]{ King, Jr.}\\
-% |\Name*[Martin Luther]{King, Jr. }| & \Name*[Martin Luther]{King, Jr. }\\
-% |\Name*[Martin Luther]{ King, Jr. }| & \Name*[Martin Luther]{ King, Jr. }\\\bottomrule
-% \end{tabular}
+% \DescribeMacro{\CapThis}
+% In English, these particles go in the \meta{SNN} field of \cmd{\Name}, \emph{e.g.}, \ForgetName[Walter]{de la Mare}\Name[Walter]{de la Mare}.\marginpar{\small\raggedleft\dbend} |\CapThis\Name[Walter]{de la Mare}| lets you capitalize \emph{de} when at the beginning of a sentence. \CapThis\Name[Walter]{de la Mare} will think it fair. \CapThis\Soto\ (using |\CapThis\Soto| from Section~\ref{sec:simplestart}) would agree.
+%
+% It is a good idea to put |~| or \cmd{\nobreakspace} between particles and surnames to avoid bad breaks. This also prevents \cmd{\CapThis} from eating the space between a one-character particle and the surname (Section \ref{sec:Unicode}).
+%
+% The Continental style for surnames (Sections~\ref{sec:nonenglish} and~\ref{sec:Hooksc}) does not work with the capitalization macros. For names like \Name[Catherine]{\textsc{de'~Medici}} use |\Name[Catherine]{\textsc{de'~Medici}}| and, instead of the capping macros, |\textsc{De'~Medici}\IndexName[Catherine]{\textsc{de'~Medici}}.| Otherwise you will have to modify the examples from Section~\ref{sec:Hooksc}. Those examples can help you implement an alternate method of capitalization.\medskip
+%
+% \DescribeMacro{\AccentCapThis}
+% With \texttt{pdflatex} and \textsf{inputenc}, use \cmd{\CapThis} when the first character of the particle is \texttt{A--z} (basic Latin).\marginpar{\small\raggedleft\dbend} Use \cmd{\AccentCapThis} when the first character is extended Latin or other Unicode (see Section \ref{sec:Unicode}). Otherwise, with \texttt{pdflatex} \cmd{\CapThis} will fail if an extended Unicode character is the first letter of a particle.
+%
+% For example, \emph{L'} and \emph{d'} are two separate glyphs each, while \emph{Ľ} and \emph{ď} are one Unicode glyph each. Even with \texttt{xelatex} and \texttt{lualatex}, you would put a non-breaking space between the particle and the name because the particle is only one character. With \texttt{pdflatex} you also must use \cmd{\AccentCapThis.}
+%
+% Medieval names present some interesting difficulties, often based on the expected standards of the context in which they are used:
+% \begin{quote}\small\setstretch{1.1}
+% |\PretagName{Thomas, à~Kempis}{Thomas a Kempis}|\hfill\emph{medieval}\\
+% |\PretagName[Thomas]{à~Kempis}{Thomas a Kempis}|\hfill\emph{Western}\\
+% |\begin{nameauth}|\\[0.2ex]
+% |  \< KempMed & & Thomas, à~Kempis & >|\hfill\emph{medieval}\\
+% |  \< KempW & Thomas & à~Kempis & >|\hfill\emph{Western}\\
+% |\end{nameauth}|
 % \end{quote}
+% The medieval forms \KempMed\ and \KempMed\ use the particle as the first part of an affix. Please do not confuse the medieval forms with the Western forms. Otherwise you will get similar names with different index entries.\footnote{Properly speaking, ``à~Kempis'' and ``Aquinas'' are not surnames but suffixed place names. They create different index entries from Western names and look different in the text.}
+% \IndexInactive
+% Many people still use medieval affixes as Western surnames: \SubvertName[Thomas]{à~Kempis}``\AccentCapThis\KempW.''\footnote{Ethnocentric treatment of names still occurs in academic literature. This is due to simplicity in work flow or conformity to name authorities. The \textsf{nameauth} package will accommodate those approaches, even if I personally disagree with them.}
+% \clearpage
+% The Western form is |\AccentCapThis\KempW.| One might run into problems unless one considers the following caveats, as Section~\ref{sec:Unicode} explains:
+% \begin{itemize}\small
+% \item |\CapThis\KempW| halts execution with |Argument| |of| |\UTFviii at two@| |octets| |has| |an| |extra| |\| when using \texttt{latex} or \texttt{pdflatex} and NFSS.
+% \item |\AccentCapThis\Name[Thomas]{à| |Kempis}| produces ``\AccentCapThis\Name[Thomas]{à Kempis}'' (space removed). Instead, use |\AccentCapThis\Name[Thomas]{à~Kempis}.|
+% \item With \texttt{latex} or \texttt{pdflatex} \cmd{\AccentCapThis} fails for particles like |lé|\,---\,use \cmd{\CapThis} in that case to avoid breaking the \emph{second} character.
+% \item |\AccentCapThis\Soto| gives \AccentCapThis\Soto, but only with \texttt{latex} or \texttt{pdflatex}. Only use it with accented first letters.
+% \end{itemize}
+% \IndexActive
 %
-% \subsubsection{Detecting Punctuation}
+% All this being said, the publisher's way of handling names may differ from the standard way. This package allows for such variations. Yet even some publishers fall afoul of confusion regarding name forms.\footnote{An example of a true error is the index entry ``Yat-sen, Sun'' (as if Sun were a forename) in Immanuel Geiss, \emph{Personen: Die biographische Dimension der Weltgeschichte}, Geschichte Griffbereit vol. 2 (Munich: Wissen Media Verlag, 2002), 720. Still, the six-volume set is good.}
+% Developing a good rapport with the publisher will help you apply this package to the company's style.
 %
-% In Western names, affixes like ``Jr.'' (junior), ``Sr.'' (senior), ``d.\,J.'' (\textit{der J\"ungere}), and ``d.\,\"A.'' (\textit{der \"Altere}) can collide with the full stop in a sentence. \cmd{\Name}, \cmd{\FName}, and \cmd{\AKA} detect this in a name and gobble the subsequent full stop as needed:
+% You\marginpar{\small\raggedleft Alternates} could use name forms with braces, like |\Name[Thomas]{{à}~Kempis}|, and control sequences, like |\Name[Thomas]{\`a~Kempis}|. Using those forms consistently, with \cmd{\PretagName,} would require you to use \cmd{\CapThis,} never \cmd{\AccentCapThis}. See Section~\ref{sec:Unicode} for more details.
 %
-% \begin{quote}\footnotesize\ForgetName[Martin Luther]{King, Jr.}\setstretch{1.2}
-% \begin{tabular}{r@{\hbox to 1em{\hfil}}c@{\hbox to 1em{\hfil}}l}\toprule
-% \textit{Macro Example\hfill} & \textit{periods} & \textit{Resulting Text}\\\midrule
-% |\Name[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name[Martin Luther]{King, Jr.}.\\
-% |\Name[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name[Martin Luther]{King, Jr.}.\\
-% |\Name[Martin Luther]{King, Jr.}|\texttt{\textvisiblespace} & $1\rightarrow0$ & \Name[Martin Luther]{King, Jr.}\\
-% |\Name*[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name*[Martin Luther]{King, Jr.}.\\
-% |\Name*[Martin Luther]{King, Jr.}|\texttt{\textvisiblespace} & $1\rightarrow1$ & \Name*[Martin Luther]{King, Jr.}\\\bottomrule
-% \end{tabular}
-% \end{quote}   
-% Grouping tokens can frustrate this: |{\Name*[Martin Luther]{King, Jr.}}.| produces ``{\Name*[Martin Luther]{King, Jr.}}.'' (two periods). Enclosing |{Jr.}| within braces or a macro will do the same. If you must format the affix, leave the period outside: |\Name[Martin Luther]{\textsc{King}, \textsc{Jr}.}| Cf. Section~\ref{sec:formatting}.
+% Non-English contexts do not necessarily bind particles to surnames. Using \cmd{\Name} and \cmd{\FName} with alternate forenames helps address this and may skirt the particle capitalization issue. See also Section~\ref{sec:Particles}.
 %
 % \subsubsection{Accented Names}
 % \label{sec:accents}
 % 
-% For names that contain accented characters, using \texttt{xelatex} or \texttt{lualatex} with \texttt{xindy} (\texttt{texindy}) is recommended. Section~\ref{sec:engines} shows how you can work with multiple engines.
+% For names that contain accented characters, using \texttt{xelatex} or \texttt{lualatex} with \texttt{xindy} (\texttt{texindy}) is recommended. Section~\ref{sec:engines} shows how you can work with multiple engines using the same document.
 %
-% If the leading character of \meta{SNN} is accented and lowercase (usually only in a particle), then you must use \cmd{\AccentCapThis} if you are using \texttt{pdflatex.} Sections~\ref{sec:standards} and~\ref{sec:Unicode} give more details about \cmd{\CapThis} and \cmd{\AccentCapThis}.
+% If the leading character of \meta{SNN} is accented and lowercase (usually only in a particle), then you must use \cmd{\AccentCapThis} if you are using NFSS. Sections~\ref{sec:standards} and~\ref{sec:Unicode} give more details about \cmd{\CapThis} and \cmd{\AccentCapThis}.
 %
-% Accented characters act like control sequences. In \texttt{pdflatex} use \cmd{\PretagName} with all names with extended Unicode characters (Sections~\ref{sec:IndexSort} and~\ref{sec:Unicode}).\footnote{This is true especially in NFSS while using \texttt{makeindex}. With \texttt{xindy} one can make custom sorting alphabets that are more powerful than \cmd{\PretagName}.}
+% Accented characters act like control sequences. In NFSS use \cmd{\PretagName} for all names with extended Unicode characters (Sections~\ref{sec:IndexSort} and~\ref{sec:Unicode}).\footnote{This is true especially in NFSS while using \texttt{makeindex}. With \texttt{xindy} one can make custom sorting alphabets that are more powerful than \cmd{\PretagName}.}
 %
-% Nevertheless, Unicode characters and ``regular'' control sequences are not interchangeable. The example below shows this difference because the names are all long (thus, different). The names are not long, then short (were they the same):
-% \begin{quote}
+% Unicode\marginpar{\small\raggedleft\dbend} characters and ``regular'' control sequences are not interchangeable. The example below shows that the names are all long (thus, different). Were the control sequences identical, the names would be long, then short:
+% \begin{quote}\small\setstretch{1.1}
 % \IndexInactive%
 % |\Name[Johann]{Andre\"a}|\hfill \Name[Johann]{Andre\"a}\\
 % \IndexActive%
@@ -1419,101 +1420,27 @@
 % |\Name{Æthelred, II}|\hfill \Name{Æthelred, II} instead of \Name{Æthelred, II}
 % \end{quote}
 %
-% See Section~\ref{sec:Unicode} on how to add additional Unicode glyphs to the default set under NFSS, \textsf{inputenc}, and \textsf{fontenc}. One may use expandable control sequences in names (thanks \Name*[Robert]{Schlicht}). Also, you can use \cmd{\edef} and \cmd{\noexpand} in names (Section~\ref{sec:Hooksc}). Since \textsf{nameauth} version 2.0, helpful concerns of \Name[Patrick]{Cousot} have been addressed.
-% 
-% \subsubsection{Format: Hooks}
-% \label{sec:CustomHooks}
+% See Section~\ref{sec:Unicode} on how to add additional Unicode glyphs to the default set under NFSS, \textsf{inputenc}, and \textsf{fontenc}. One may use expandable control sequences in names (thanks \Name*[Robert]{Schlicht}). Also, you can use \cmd{\edef} and \cmd{\noexpand} in names (Section~\ref{sec:Hooksc}, thanks \Name[Patrick]{Cousot}).
+% \clearpage
 %
-% There are two kinds of formatting at work:
-% \begin{enumerate}\small
-% \item \textbf{Syntactic Formatting:} This includes reversing names, capitalizing the first letter in the \meta{SNN} field in the body text, and capitalizing the root when \meta{SNN} is a \meta{root, suffix} pair.
-% \item \textbf{Name Post-Processing:} This happens in the hook macros after a name has been parsed into the final form it will take in the text.
-% \end{enumerate}
+% \subsubsection{Non-English Format}
+% \label{sec:nonenglish}
 %
-% \DescribeMacro{\NamesFormat}
-% \DescribeMacro{\FrontNamesFormat}
-% \DescribeMacro{\MainNameHook}
-% \DescribeMacro{\FrontNameHook}
-% Starting with version 2.5, the ``main-matter'' and ``front-matter'' systems are fully qualified and independent systems of formatting and first/subsequent name use. The main-matter system uses \cmd{\NamesFormat} to post-process first occurrences of names and \cmd{\MainNameHook} to post-process subsequent uses. The front-matter system uses \cmd{\FrontNamesFormat} to post-process first occurrences of names and \cmd{\FrontNameHook} to post-process subsequent uses. The \texttt{alwaysformat} option causes every name to be formatted as a ``first-use.''
+% See\marginpar{\small\raggedleft\dbend} Sections~\ref{sec:FrontFormat}, \ref{sec:CustomHooks},  and~\ref{sec:Hooksc} in addition to this section. We place this section here because it has a language-based element.
 %
-% Section~\ref{sec:FrontFormat} offers more about how to switch the systems and what that implies. For now, we focus on custom formatting at work:
-% \begin{quote}\small
-% |\renewcommand*{\NamesFormat}{\scshape}|\\
-% |\renewcommand*{\FrontNamesFormat}{\bfseries}|
-% \end{quote}
+% By default, name post-processing\marginpar{\small\raggedleft Continental\\ small caps} only affects the text. Also by default, you cannot post-process Continental formatting because it occurs in both the text and the index via control sequences in the \textsf{nameauth} macro arguments. That usually requires \cmd{\PretagName} for index sorting (Section~\ref{sec:IndexSort}). Section ~\ref{sec:Hooksc} explains how to implement post-processing via \cmd{\noexpand} and other steps.
 %
-% We leave \cmd{\MainNameHook} and \cmd{\FrontNameHook} unchanged so that the resulting names are not formatted. Here we have text in the front matter. It has the \cmd{\bfseries} formatting.
-% \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}
-% \begin{quote}\small\setstretch{1.2}
-% \NamesInactive\renewcommand*{\NamesFormat}{\scshape}\renewcommand*{\FrontNamesFormat}{\bfseries}
-% \begin{tabular}{ll}\toprule
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\\midrule
-% |\Name{Confucius}| & \Name{Confucius}\\
-% |\Name{Confucius}| & \Name{Confucius}\\\midrule
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\\midrule
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
-% \end{tabular}
-% \end{quote}
-%
-% Next we have text in the main matter. It has the \cmd{\scshape} formatting.
-% \begin{quote}\small\setstretch{1.2}
-% \renewcommand*{\NamesFormat}{\scshape}\renewcommand*{\FrontNamesFormat}{\bfseries}
-% \begin{tabular}{ll}\toprule
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\\midrule
-% |\Name{Confucius}| & \Name{Confucius}\\
-% |\Name{Confucius}| & \Name{Confucius}\\\midrule
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\\midrule
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
-% \end{tabular}
-% \end{quote}
-%
-% Finally we simulate the \texttt{alwaysformat} option for text in both the main matter and the front matter:
-% \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}
-% \begin{quote}\small\setstretch{1.2}
-% \makeatletter\@nameauth at AlwaysFormattrue\makeatother
-% \renewcommand*{\NamesFormat}{\scshape}\renewcommand*{\FrontNamesFormat}{\bfseries}
-% \begin{tabular}{ll}\toprule
-% \textit{Front Matter}\global\NamesInactive\\\midrule
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
-% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\\midrule
-% |\Name{Confucius}| & \Name{Confucius}\\
-% |\Name{Confucius}| & \Name{Confucius}\\\midrule
-% \textit{Main Matter}\global\NamesActive\\\midrule
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\
-% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\\midrule
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\
-% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
-% \end{tabular}
-% \makeatletter\@nameauth at AlwaysFormatfalse\makeatother
-% \end{quote}
-%
-% The process of modularizing this post-processing began in version 2.4. Sections~\ref{sec:Hooksb}ff. discuss more on how one can redefine the formatting hooks.
-% \clearpage
-%
-% \subsubsection{Format: Continental}
-% \label{sec:formatting}
-%
-% Name post-processing\marginpar{\small\raggedleft Continental\\ small caps} does not affect the index. Control sequences in the name arguments themselves do affect the index. Section~\ref{sec:IndexSort} describes how to use \cmd{\PretagName} to get proper index sorting with names containing control sequences and extended Unicode characters.
-%
-% In this example, you get something that corresponds with the Continental system. The surname is formatted in both the body text and the index. It is always formatted, everywhere:
-% \begin{quote}
+% Here we have a very basic attempt at Continental formatting of the surname in both the body text and the index. One cannot alter this formatting:
+% \begin{quote}\small\setstretch{1.1}
 % \indent|\PretagName[Greta]{\textsc{Garbo}}{Garbo, Greta}|\\
 % \indent|\Name[Greta]{\textsc{Garbo}}|
 % \end{quote}
-% You get \Name[Greta]{\textsc{Garbo}}, then \Name[Greta]{\textsc{Garbo}}\,---\,even in the front matter. Section~\ref{sec:Hooksc} shows a more advanced example that will suppress the small caps except for first uses, but will retain the small caps in the index.
+% You get \Name[Greta]{\textsc{Garbo}}, then \Name[Greta]{\textsc{Garbo}}\,---\,even in the front matter. In order to get an unformatted reference to the name ``Garbo,''\IndexName[Greta]{\textsc{Garbo}} one must type something like |``Garbo''\IndexName[Greta]{\textsc{Garbo}}.|
 %
-% Of course, one could always create a manual reference if desired. For example, one can type |``Garbo''\IndexName\Name[Greta]{\textsc{Garbo}}| for a ``Garbo'' reference.
-%
-% Some interesting things can happen when you put control sequences in the naming macro arguments. |\Name[\normalfont{Greta}]{\textsc{Garbo}}| will produce a name in the text and in the index that looks exactly like name above. Regardless of its looks, however, it is a a different name with different first/subsequent uses and a different index entry.
+% As with accented names, different control sequences produce different names. |\Name[\normalfont{Greta}]{\textsc{Garbo}}| looks exactly like name above, but it will create a different index entry and have different first\,/\,subsequent uses.
 % 
-% A comma delimiter will split the macro argument, potentially causing unbalanced braces. Avoid this by formatting the name and suffix separately:
-% \begin{quote}\small
+% A comma delimiter will split the macro argument into a root and an affix. This could halt typesetting and generate an error regarding unbalanced braces. Avoid this by formatting the name and suffix separately. Here we manually format Continental and Eastern names that contain root\,/\,affix pairs:
+% \begin{quote}\small\setstretch{1.1}
 % |\PretagName{\uppercase{Fukuyama},| |Takeshi}{Fukuyama,| |Takeshi}|\\
 % |\PretagName[Thurston]{\textsc{Howell},\textsc{III}}%|\\
 % |  {Howell, Thurston 3}|\\[1ex]
@@ -1522,54 +1449,51 @@
 % |  \< Howell & Thurston & \textsc{Howell},\textsc{III} & >|\\
 % |\end{nameauth}|
 % \end{quote}
+% \cmd{\Fukuyama} produces \Fukuyama\ and \Fukuyama. Of course, you could type all-capital surnames without control sequences. Likewise, \cmd{\Howell} generates \Howell\ and \Howell.
 %
-% \cmd{\Fukuyama} produces \Fukuyama\ and \Fukuyama. Of course, you could type all-capital surnames without control sequences. Likewise, \cmd{\Howell} generates \Howell\ and \Howell.\medskip
+% The old syntax cannot be used with \LHowell. For \LFukuyama, the old syntax would be:
+% \begin{quote}\small\setstretch{1.1}
+% |\PretagName{\uppercase{Fukuyama}}[Takeshi]{Fukuyama Takeshi}|\\
+% |\begin{nameauth}|\\
+% |  \< OFukuyama & & \uppercase{Fukuyama} & Takeshi >|\\
+% |\end{nameauth}|
+% \end{quote}
+% \cmd{\LOFukuyama} produces \LOFukuyama. \cmd{\OFukuyama} yields \OFukuyama. This form works with the new syntax form and is not distinct from it. It is the same as |\Name{\uppercase{FUKUYAMA}}[Takeshi]|. The caps macros will not work on it, apart from the examples in Section~\ref{sec:Hooksc}.
+% \clearpage
 %
-% \subsubsection{Format: Engine}
-% \label{sec:NewEngine}
+% \begin{center}\large\bfseries Other Technical Issues\end{center}
+% \subsubsection{Fault Tolerance}
+% \label{sec:tolerance}
 %
-% Assuming that redefining hooks and adding control sequences is insufficient to your task, you could modify the core naming macros and hook those modifications back into the \textsf{nameauth} package without needing to continuously track and patch the style file itself. 
+% The \textsf{nameauth} package protects against some typing errors. Adding extra spaces \emph{normally} does not produce unique names. The simplified interface also is fault-tolerant with spaces. The variations below illustrate this point:
 %
-% \DescribeMacro{\NameauthName}
-% \DescribeMacro{\NameauthLName}
-% \DescribeMacro{\NameauthFName}
-% These macros are set by default to \cmd{\@nameauth at Name}, the internal name parser. The main and simplified interfaces call them as respective synonyms for \cmd{\Name,} \cmd{\Name*,} and \cmd{\FName.} Should you desire to create your own naming macros, you can redefine them. Here is the minimal working example:
-% \begin{quote}
-% |\makeatletter|\\
-% |\newcommandx*\MyName[3][1=\@empty, 3=\@empty]{|\meta{Name}|}%|\\
-% |\newcommandx*\MyLName[3][1=\@empty, 3=\@empty]%|\\
-% |  {|\meta{Long name}|\@nameauth at FullNamefalse}%|\\
-% |\newcommandx*\MyFName[3][1=\@empty, 3=\@empty]%|\\
-% |  {|\meta{Short name}|\@nameauth at FirstNamefalse}%|\\
-% |\makeatother|
-% \end{quote}
+% \begin{center}\small\setstretch{1.1}\ForgetName[Martin Luther]{King, Jr.}
+% \begin{tabular}{ll}\toprule
+% \textit{Macro Example} & \textit{Resulting Text}\\\midrule
+% |\Name*[Martin Luther]{King, Jr.}| & \Name*[Martin Luther]{King, Jr.}\\
+% \cmd{\Name*}\texttt{[\textvisiblespace\textvisiblespace Martin Luther]\{\textvisiblespace\textvisiblespace King, Jr.\}} & \Name*[  Martin Luther]{  King, Jr.}\\
+% \cmd{\Name*}\texttt{[Martin Luther\textvisiblespace\textvisiblespace]\{King, Jr.\textvisiblespace\textvisiblespace\}} & \Name*[Martin Luther  ]{King, Jr.  }\\
+% \cmd{\Name*}\texttt{[\textvisiblespace Martin Luther\textvisiblespace]\{\textvisiblespace King, Jr.\textvisiblespace\}} & \Name*[ Martin Luther ]{ King, Jr. }\\
+% \cmd{\Name*}\texttt{[Martin\textvisiblespace\textvisiblespace\textvisiblespace Luther]\{King\textvisiblespace,\textvisiblespace\textvisiblespace Jr.\}} & \Name*[Martin   Luther]{King ,  Jr.}\\\bottomrule
+% \end{tabular}
+% \end{center}
 %
-% The macros above do not really work together with the rest of \textsf{nameauth} package, so be careful! You can hook these macros into the user interface thus:
-% \begin{quote}
-% \makeatletter%
-% \newcommandx*\MyName[3][1=\@empty, 3=\@empty]{\meta{Name}}%
-% \newcommandx*\MyLName[3][1=\@empty, 3=\@empty]{\meta{Long name}\@nameauth at FullNamefalse}%
-% \newcommandx*\MyFName[3][1=\@empty, 3=\@empty]{\meta{Short name}\@nameauth at FirstNamefalse}%
-% \makeatother%
-% |\renewcommand*{\NameauthName}{\MyName}|\\
-% |\renewcommand*{\NameauthLName}{\MyLName}|\\
-% |\renewcommand*{\NameauthFName}{\MyFName}|\\
-% |\begin{nameauth}|\\
-% |  \< Silly & No Particular & Name & >|\\
-% |\end{nameauth}|\\
-% |This is \Silly, \LSilly, and \SSilly.|\\
-% \renewcommand*{\NameauthName}{\MyName}%
-% \renewcommand*{\NameauthLName}{\MyLName}%
-% \renewcommand*{\NameauthFName}{\MyFName}%
-% \begin{nameauth}
-%   \< Silly & No Particular & Name & >
-% \end{nameauth}
-% This is \Silly, \LSilly, and \SSilly.
-% \end{quote}
-% Like\marginpar{\small\raggedleft\cmd{\global}} \cmd{\NamesFormat}, the other hook macros, and many of the state-changing and triggering macros in this package, these naming macros can be redefined or used locally within a scope without making global changes to the document unless you specifically use \cmd{\global}.
+% \subsubsection{Detecting Punctuation}
 %
-% Here we show that the macros \cmd{\NameauthName,} \cmd{\NameauthLName,} and \cmd{\NameauthFName} have reverted back to their original forms. Now \cmd{\Silly} and |\Name[No Particular]{Name}| produce \IndexInactive\Silly\ and \Name[No Particular]{Name}\IndexActive.
+% In Western names, affixes like ``Jr.'' (junior), ``Sr.'' (senior), ``d.\,J.'' (\textit{der J\"ungere}), and ``d.\,\"A.'' (\textit{der \"Altere}) can collide with the full stop in a sentence. \cmd{\Name}, \cmd{\FName}, and \cmd{\AKA} detect this in a name and gobble the subsequent full stop as needed:
 %
+% \begin{center}\footnotesize\setstretch{1.1}\ForgetName[Martin Luther]{King, Jr.}
+% \begin{tabular}{r@{\hbox to 1em{\hfil}}c@{\hbox to 1em{\hfil}}l}\toprule
+% \textit{Macro Example\hfill} & \textit{periods} & \textit{Resulting Text}\\\midrule
+% |\Name[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name[Martin Luther]{King, Jr.}.\\
+% |\Name[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name[Martin Luther]{King, Jr.}.\\
+% |\Name[Martin Luther]{King, Jr.}|\texttt{\textvisiblespace} & $1\rightarrow0$ & \Name[Martin Luther]{King, Jr.}\\
+% |\Name*[Martin Luther]{King, Jr.}.| & $2\rightarrow1$ & \Name*[Martin Luther]{King, Jr.}.\\
+% |\Name*[Martin Luther]{King, Jr.}|\texttt{\textvisiblespace} & $1\rightarrow1$ & \Name*[Martin Luther]{King, Jr.}\\\bottomrule
+% \end{tabular}
+% \end{center}   
+% Grouping tokens can frustrate this: |{\Name*[Martin Luther]{King, Jr.}}.| produces ``{\Name*[Martin Luther]{King, Jr.}}.'' (two periods). Enclosing |{Jr.}| within braces or a macro will do the same. If you must format the affix, leave the period outside: |\Name[Martin Luther]{\textsc{King}, \textsc{Jr}.}| Cf. Section~\ref{sec:nonenglish}.
+%
 % \subsubsection{Format: Systems}
 % \label{sec:FrontFormat}
 %
@@ -1579,9 +1503,22 @@
 % 
 % Please\marginpar{\small\raggedleft\cmd{\global}} note that these two macros can be used explicitly as a pair. They also can be used singly within an explicit scope, where the effects cease after leaving that scope. Use \cmd{\global} to force a global effect.
 %
-% Similar to the formatting example above, we redefine the formatting hooks to illustrate that indeed, there are two formatting systems at work. Here we switch to the ``front matter'' mode:
-% \begin{quote}\small\cmd{\NamesInactive}\NamesInactive\\[0.4ex]
-% \NamesInactive\renewcommand*{\NamesFormat}{\scshape}\renewcommand*{\FrontNamesFormat}{\bfseries}
+% By default, these two systems of names differ only between first and subsequent uses. Here we change the first-use formatting hooks (Section~\ref{sec:CustomHooks}) to show a greater distinction:
+% \begin{quote}\small\setstretch{1.1}
+% |\let\OldFormat\NamesFormat|\\
+% |\let\OldFrontFormat\FrontNamesFormat|\\
+% |\renewcommand*\NamesFormat{\scshape}|\\
+% |\renewcommand*\FrontNamesFormat{\bfseries}|
+% \end{quote}
+% \let\OldFormat\NamesFormat
+% \let\OldFrontFormat\FrontNamesFormat
+% \renewcommand*\NamesFormat{\scshape}
+% \renewcommand*\FrontNamesFormat{\bfseries}
+% \clearpage
+%
+% Here we switch to the ``front matter'' mode:
+% \begin{quote}\small\setstretch{1.1}\cmd{\NamesInactive}\NamesInactive\\[0.4ex]
+% \NamesInactive
 % \begin{tabular}{@{}ll}
 % |\Name[Rudolph]{Carnap}| & \Name[Rudolph]{Carnap}\\
 % |\Name[Rudolph]{Carnap}| & \Name[Rudolph]{Carnap}\\
@@ -1589,9 +1526,9 @@
 % |\Name[Nicolas]{Malebranche}| & \Name[Nicolas]{Malebranche}\\
 % \end{tabular}
 % \end{quote}
+%
 % Then we switch back to ``main matter'' mode:
-% \begin{quote}\small\cmd{\NamesActive}\NamesActive\\[0.4ex]
-% \renewcommand*{\NamesFormat}{\scshape}\renewcommand*{\FrontNamesFormat}{\bfseries}
+% \begin{quote}\small\setstretch{1.1}\cmd{\NamesActive}\NamesActive\\[0.4ex]
 % \begin{tabular}{@{}ll}
 % |\Name[Rudolph]{Carnap}| & \Name[Rudolph]{Carnap}\\
 % |\Name[Rudolph]{Carnap}| & \Name[Rudolph]{Carnap}\\
@@ -1600,12 +1537,10 @@
 % \end{tabular}
 % \end{quote}
 % 
-% We have two independent cases of ``first use'' above. Thus, we have two ``species'' of names: ``front-matter'' and ``main-matter.'' This is useful if you want to format names one way in the regular body text but another way somewhere else. You see above, however, that using these systems in the same document section can lead to a clash of names.
-%
-% How about we apply some of these formatting ideas to footnotes? Certainly we can redefine \cmd{\NamesFormat} to create custom effects like changing typographic formatting in footnotes:
-% \begin{quote}\small
+% This\marginpar{\small\raggedleft\dbend} illustrates the independent systems or ``species'' of names. This is most useful when you want to format names one way in the regular body text but another way somewhere else. In footnotes, for example, we could redefine \cmd{\NamesFormat} to create custom formatting:
+% \begin{quote}\small\setstretch{1.1}
 % |\makeatletter|\\
-% |\let\@oldfntext\@makefntext|\\
+% |\let\@oldfntext\@makefntext%|\hfill\texttt{save original macro}\\
 % |\long\def\@makefntext#1{%|\\
 % |  \renewcommand*\NamesFormat{\scshape}\@oldfntext{#1}}|\\
 % |\let\@makefntext\@oldfntext% just in case|\\
@@ -1615,78 +1550,139 @@
 % \let\@oldfntext\@makefntext%
 % \long\def\@makefntext#1{\renewcommand*\NamesFormat{\scshape}\@oldfntext{#1}}%
 % \makeatother%
-% Your footnote would produce names with different formatting than the body text.\footnote{This demonstrates a format change: \Name[John Maynard]{Keynes}.}
-% We change footnotes back to normal with:
+% The problem is that \Name[John Maynard]{Keynes} in the text could affect formatting in the footnotes.\footnote{You get \Name[John Maynard]{Keynes} instead of \ForgetName[John Maynard]{Keynes}\Name[John Maynard]{Keynes}.}
+% Instead of editing footnotes as needed by inserting \cmd{\ForgetName,} there is a different solution that uses the front-matter system:
+% \begin{quote}\small\setstretch{1.1}
+% |\makeatletter|\\
+% |\let\@oldfntext\@makefntext%|\hfill\texttt{save original macro}\\
+% |\long\def\@makefntext#1{%|\\
+% |  \NamesInactive\@oldfntext{#1}\NamesActive%|\\
+% |}\makeatother|
+% \end{quote}
 % \makeatletter\ignorespaces%
+% \long\def\@makefntext#1{\NamesInactive\@oldfntext{#1}\NamesActive}%
+% \makeatother%
+% Your footnotes do not affect the main body text now.\footnote{We have \Name[John Maynard]{Keynes}, then \Name[John Maynard]{Keynes}.}
+% We change footnotes back to normal with the following:
+% \makeatletter\ignorespaces%
 % \let\@makefntext\@oldfntext%
 % \makeatother%
-% \begin{quote}\small
+% \begin{quote}\small\setstretch{1.1}
 % |\makeatletter%|\\
 % |\let\@makefntext\@oldfntext%|\\
 % |\makeatother|
 % \end{quote}
 %
-% This example has something of a flaw in it. If you are in the main matter of the document, this solution can affect names in the main body text, \emph{e.g.}, ``\Name[John Maynard]{Keynes},'' because the first and subsequent references are global by design. Also, relying only on scoping to insulate any changes to \cmd{\NamesFormat} might create undesired side effects, depending on the sort of modification.
-%
-% By using the front-matter system, we can get around the limitations of the footnotes interfering with the main-matter text:
-% \begin{quote}\small
-% |\makeatletter|\\
-% |\let\@oldfntext\@makefntext|\\
-% |\long\def\@makefntext#1{%|\\
-% |  \NamesInactive\@oldfntext{#1}\NamesActive%|\\
-% |}\makeatother|
+% At this point we could restore the formatting hooks, but we will do that in the next section. We would do that by scoping or with:
+% \begin{quote}\small\setstretch{1.1}
+% |\let\NamesFormat\OldFormat|\\
+% |\let\FrontNamesFormat\OldFrontFormat|\\
 % \end{quote}
-% \makeatletter\ignorespaces%
-% \let\@oldfntext\@makefntext%
-% \long\def\@makefntext#1{\NamesInactive\@oldfntext{#1}\NamesActive}%
-% \makeatother%
-% Your footnote would produce a front-matter name.\footnote{This demonstrates a front-matter name: \Name[John Maynard]{Keynes}.}
-% Notice that the front-matter text has no formatting by default. Not only does front-matter formatting not affect the body text, but also the first/subsequent uses are independent. As above, we can change footnotes back to normal.\makeatletter\let\@makefntext\@oldfntext\makeatother
+% \clearpage
 %
+% \subsubsection{Format: Hooks}
+% \label{sec:CustomHooks}
+%
+% There are two kinds of formatting at work:
+% \begin{enumerate}\small
+% \item \textbf{Syntactic Formatting:} For the English default, this includes what the reversing and capitalizing macros do. For the alternatives, it includes any control sequences embedded in the macro arguments.
+% \item \textbf{Name Post-Processing:} This happens in the hook macros after a name has been parsed into the final form it will take in the text.
+% \end{enumerate}
+%
+% \DescribeMacro{\NamesFormat}
+% \DescribeMacro{\FrontNamesFormat}
+% \DescribeMacro{\MainNameHook}
+% \DescribeMacro{\FrontNameHook}
+% Starting with version 2.5, the ``main-matter'' and ``front-matter'' systems are fully qualified and independent systems of formatting and first/subsequent name use. The main-matter system uses \cmd{\NamesFormat} to post-process first occurrences of names and \cmd{\MainNameHook} to post-process subsequent uses. The front-matter system uses \cmd{\FrontNamesFormat} to post-process first occurrences of names and \cmd{\FrontNameHook} to post-process subsequent uses. The \texttt{alwaysformat} option causes every name to be typeset as a ``first-use.''\medskip
+%
+% \noindent{\bfseries Front Matter}
+% \ForgetName[Albert]{Einstein}\ForgetName{Confucius}\ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}
+% \begin{center}\small\setstretch{1.1}
+% \NamesInactive
+% \begin{tabular}{ll}\toprule
+% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
+% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\\midrule
+% |\Name{Confucius}| & \Name{Confucius}\\
+% |\Name{Confucius}| & \Name{Confucius}\\\midrule
+% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\
+% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\\midrule
+% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\
+% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
+% \end{tabular}
+% \end{center}\medskip
+%
+% \noindent{\bfseries Main Matter}
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\
+% |\Name[Albert]{Einstein}| & \Name[Albert]{Einstein}\\\midrule
+% |\Name{Confucius}| & \Name{Confucius}\\
+% |\Name{Confucius}| & \Name{Confucius}\\\midrule
+% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\
+% |\Name[M.T.]{Cicero}[Marcus Tullius]| & \Name[M.T.]{Cicero}[Marcus Tullius]\\\midrule
+% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\
+% |\Name{Charles, the Bald}| & \Name{Charles, the Bald}\\\bottomrule
+% \end{tabular}
+% \end{center}\medskip
+%
+% Below\marginpar{\small\raggedleft\dbend} we simulate the \texttt{alwaysformat} option by manipulating the package internals. We see that this option does not force long name forms. After the examples, we reset the formatting hooks.
+% \makeatletter\@nameauth at AlwaysFormattrue\makeatother%
+% \ForgetName[Albert]{Einstein}\ForgetName{Confucius}%
+% \ForgetName[M.T.]{Cicero}\ForgetName{Charles, the Bald}%
+% \begin{itemize}
+% \item\NamesInactive Using \texttt{alwaysformat} in the front matter will produce: \Name[Albert]{Einstein}, then  \Name[Albert]{Einstein}; \Name{Confucius}, then \Name{Confucius}.
+% \item \global\NamesActive Using \texttt{alwaysformat} in the main matter will produce: \Name[M.T.]{Cicero}[Marcus Tullius], then \Name[M.T.]{Cicero}[Marcus Tullius]; \Name{Charles, the Bald}, then \Name{Charles, the Bald}.
+% \end{itemize}
+% \makeatletter\@nameauth at AlwaysFormatfalse\makeatother
+% \let\NamesFormat\OldFormat
+% \let\FrontNamesFormat\OldFrontFormat
+% \clearpage
+%
 % \subsection{Name Decisions}
 % \subsubsection{Testing Decisions}
 % \label{sec:tests}
 %
-% The macros in this section permit conditional text that depends on the presence or absence of a name. The \cmd{\If} in this section's macro names is capitalized to be different from a regular |\if| expression. The branching of these macros is altered by using \cmd{\Name,} \cmd{\Name*,} \cmd{\FName,} \cmd{\PName,} \cmd{\AKA,} \cmd{\AKA*,} \cmd{\ForgetName,} \cmd{\SubvertName,} and \cmd{\ExcludeName.}
+% The macros in this section permit conditional text that depends on the presence or absence of a name. These macros use \cmd{\If}\textbf{\dots} because they differ from regular |\if| expressions. The following macros affect conditional branching: \cmd{\Name,} \cmd{\Name*,} \cmd{\FName,} \cmd{\PName,} \cmd{\AKA,} \cmd{\AKA*,} \cmd{\ForgetName,} \cmd{\SubvertName,} and \cmd{\ExcludeName.} One might consider some uses:
+% \begin{itemize}\small
+% \item a book where one includes a margin paragraph, mini-bio, footnote, or other information when a name is first introduced
+% \item a game book where you have to pick a game path
+% \item a presentation that can change if certain names are present
+% \item the ``text tag'' features in Section~\ref{sec:tagtext}
+% \item conditional comments using the \textsf{comment}, \textsf{pdfcomment}, and similar packages
+% \end{itemize}
 %
-% Some examples of conditional text include a ``mini-biography,'' a footnote, or a callout. These macros could be integrated with the ``text tag'' features in Section~\ref{sec:tagtext}. Authors and editors could use these macros with the \textsf{comment}, \textsf{pdfcomment}, and similar packages to make comments based on whether a name has occurred or not. That aids name management and thought development.
-%
-% If one passes control sequences to these macros instead of typing the text directly, one can get false results (see \emph{The \TeX book}, 212--15) unless:
-% \begin{itemize}
-% \item The arguments are retrieved from token registers.
-% \item Expansion is regulated via \cmd{\expandafter,} \cmd{\noexpand,} etc.
-% \item Expansion of accented characters in \texttt{pdflatex}/NFSS is regulated.
-% \item Conditional expansion within macro arguments (cf. Section~\ref{sec:Hooksc}) yields consistent results.
+% If one uses these macros inside other macros or passes control sequences to them, the expansion of control sequences can create false results (see \emph{The \TeX book}, 212--15). To get around those problems, consider using the following:
+% \begin{itemize}\small
+% \item Use token registers to retrieve the arguments.
+% \item Regulate expansion with \cmd{\expandafter,} \cmd{\noexpand,} etc.
+% \item That affects accented characters in \texttt{pdflatex}/NFSS.
 % \end{itemize}
 %
-% The formatting hooks do not employ these testing macros because two are called only for first uses anyway. By default, \cmd{\AKA} calls only the subsequent use hooks unless the \texttt{formatAKA} option is used.
+% See Sections~\ref{sec:Hooksb} and~\ref{sec:Hooksc} for related ideas about tokens and expansion. Using \cmd{\tracingmacros,} \cmd{\show,} or \cmd{\meaning} can help you.\medskip
 %
-% Using \cmd{\tracingmacros,} \cmd{\show,} or \cmd{\meaning} can help you ensure that everything is expanding properly to prevent false results.
-%
 % \DescribeMacro{\IfMainName}
 % If you want to produce output or perform a task based on whether a ``main body'' name exists, use \cmd{\IfMainName}, whose syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\IfMainName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\marg{yes}\marg{no}
 % \end{quote}
 % This is a long macro via \cmd{\newcommandx}, so you can have paragraph breaks in the \meta{yes} and \meta{no} paths. A ``main body'' name is capable of being formatted by this package, \emph{i.e.}, one created by the naming macros when the \texttt{mainmatter} option is used or after \cmd{\NamesActive}. It is distinguished from those names that occur in the front matter and those that have been used as cross-references.
 %
-% For example, we get ``\IfMainName[Bob]{Hope}{I met Bob}{I have not met Bob}'' from the following example because we have yet to invoke |\Name[Bob]{Hope}|:
-% \begin{quote}
+% For example, we get \IndexName[Bob]{Hope}``\IfMainName[Bob]{Hope}{I met Bob}{I have not met Bob}'' from the following example because we have yet to invoke |\Name[Bob]{Hope}|:
+% \begin{quote}\small
 % |\IfMainName[Bob]{Hope}{I met Bob}{I have not met Bob}|
 % \end{quote}%
-%
-% Since we have encountered \Name*[Johann]{Andreä}, we get ``\IfMainName[Johann]{Andreä}{I met Johann}{I have not met Johann}'' with a similar example:
-% \begin{quote}
+% Please note that this test is not affected by the use of \cmd{\IndexName.} Since we have encountered \Name*[Johann]{Andreä}, we get ``\IfMainName[Johann]{Andreä}{I met Johann}{I have not met Johann}'' with a similar example:
+% \begin{quote}\small\setstretch{1.1}
 % |\IfMainName[Johann]{Andreä}{I met Johann}%|\\|  {I have not met Johann}|
 % \end{quote}
+% \clearpage
 %
 % \DescribeMacro{\IfFrontName}
 % If you want to produce output or perform a task based on whether a ``front matter'' name exists, use \cmd{\IfFrontName}, whose syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\IfFrontName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\marg{yes}\marg{no}
 % \end{quote}
 % This macro works the same as \cmd{\IfMainName.} A ``front matter'' name is not capable of being formatted by this package, \emph{i.e.}, one created by the naming macros when the \texttt{frontmatter} option is used or after \cmd{\NamesInactive}. It is distinguished from those names that occur in the main matter and those that have been used as cross-references.
-% \clearpage
 %
 % \label{page:Carnap}For example, based on Section~\ref{sec:FrontFormat}, we see that ``\ignorespaces
 % \IfFrontName[Rudolph]{Carnap}%
@@ -1696,7 +1692,7 @@
 % {\IfMainName[Rudolph]{Carnap}%
 %   {\Name[Rudolph]{Carnap} is only formatted}%
 %   {\Name[Rudolph]{Carnap} is not mentioned}}'' a formatted and unformatted name with the following test:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\IfFrontName[Rudolph]{Carnap}%|\\
 % |{\IfMainName[Rudolph]{Carnap}%|\\
 % |  {\Name[Rudolph]{Carnap} is both}%|\\
@@ -1705,17 +1701,17 @@
 % |  {\Name[Rudolph]{Carnap} is only formatted}%|\\
 % |  {\Name[Rudolph]{Carnap} is not mentioned}}|
 % \end{quote}%
-% We will return to this topic of main matter and front matter names later in Sections~\ref{sec:Tweaks} and~\ref{sec:LocalNames}. There we see how \cmd{\ForgetName} and \cmd{\SubvertName} usually affect both main- and front-matter names simultaneously unless set otherwise.\medskip
+% Please refer to Sections~\ref{sec:Tweaks} and~\ref{sec:LocalNames} to understand the scope and operation of main- and front-matter names.\medskip
 %
 % \DescribeMacro{\IfAKA}
 % If you want to produce output or perform a task based on whether a ``\emph{see}-reference'' name exists, use \cmd{\IfAKA}, whose syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\IfAKA}\oarg{FNN}\marg{SNN}\oarg{Alt. names}\marg{y}\marg{n}\marg{excluded}
 % \end{quote}
 % This macro works similarly to \cmd{\IfMainName,} although it has an additional \meta{excluded} branch in order to detect those names excluded from indexing by \cmd{\ExcludeName} (Section~\ref{sec:exclude}).
 %
 % A ``\emph{see}-reference'' name is printed in the body text but only exists as a cross-reference created by \cmd{\AKA} and \cmd{\AKA*}. First, in the text we see ``\AKA[John David]{Rockefeller, IV}[Jay]{Rockefeller},'' |\AKA[John David]{Rockefeller, IV}[Jay]{Rockefeller}|. Next, we have the following example:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\IfAKA[Jay]{Rockefeller}%|\\
 % |  {\LJRIV\ has an alias}%|\\
 % |  {\LJRIV\ has no alias}%|\\
@@ -1722,9 +1718,10 @@
 % |  {\LJRIV\ is excluded}|
 % \end{quote}
 % This gives us ``\IfAKA[Jay]{Rockefeller}{\LJRIV\ has an alias}{\LJRIV\ has no alias}{\LJRIV\ is excluded}.'' If you are confident that you will not be dealing with names generated by \cmd{\ExcludeName} then you can just leave the \meta{excluded} branch as |{}.|
+% \clearpage
 %
 %  A similar use of |\IfAKA{Confucius}| tells us that ``\IfAKA{Confucius}{\Name{Confucius} is an alias}{\Name{Confucius} is not an alias}{}.'' Yet we should test that completely:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\IfAKA[|\meta{FNN}|]{|\meta{SNN}|}[|\meta{alt. names}|]%|\\
 % |{|\meta{true; it is a pseudonym}|}%|\\
 % |{%|\\
@@ -1742,7 +1739,7 @@
 % \end{quote}
 %
 % Here we test for a name used with \cmd{\ExcludeName} (Section~\ref{sec:exclude}) to get the result, ``\ExcludeName{Grinch}\IfAKA{Grinch}{\Name{Grinch} is an alias}{\Name{Grinch} is not an alias}{\Name{Grinch} is excluded}'':
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\ExcludeName{Grinch}%|\\
 % |\IfAKA{Grinch}%|\\
 % |  {\Name{Grinch} is an alias}%|\\
@@ -1749,7 +1746,7 @@
 % |  {\Name{Grinch} is not an alias}%|\\
 % |  {\Name{Grinch} is excluded}|
 % \end{quote}
-% 
+%
 % \subsubsection{Changing Decisions}
 % \label{sec:Tweaks}
 % 
@@ -1757,7 +1754,7 @@
 %
 % \DescribeMacro{\ForgetName}
 % This macro is a ``dirty trick'' of sorts that takes the same optional and mandatory arguments used by \cmd{\Name}. It handles its arguments in the same way, except that it ignores the final argument if \meta{FNN} are present. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\ForgetName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 % This macro causes \cmd{\Name} and friends globally to ``forget'' prior uses of a name. The next use of that name will print as if it were a ``first use,'' even if it is not. Index entries and cross-references are \emph{never} forgotten.\medskip
@@ -1764,21 +1761,29 @@
 % 
 % \DescribeMacro{\SubvertName}
 % This macro is the opposite of the one above. It takes the same arguments. It handles its arguments in the same manner. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\SubvertName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 % This macro causes \cmd{\Name} and friends globally to think that a prior use of a name already has occurred. The next use of that name will print as if it were a ``subsequent use,'' even if it is not.
+% \clearpage
 %
+% One use for this macro is to get around the safeguards of \cmd{\FName.} To ensure formatting consistency:
+% \begin{quote}\small\setstretch{1.1}
+% \cmd{\SubvertName}\oarg{FNN}\marg{SNN}|%|\\
+% |\makeatletter \@nameauth at FirstFormattrue \makeatother%|\\
+% \cmd{\FName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
+% \end{quote}
+%
 % The default \marginpar{\small\raggedleft Scope} behavior of these two macros changes whether a name is ``forgotten'' or ``subverted'' simultaneously for front matter and main matter names, Remember the example on page~\pageref{page:Carnap} above that gave us the answer, ``\IfFrontName[Rudolph]{Carnap}{\IfMainName[Rudolph]{Carnap}{\Name[Rudolph]{Carnap} is both}{\Name[Rudolph]{Carnap} is only non-formatted}}{\IfMainName[Rudolph]{Carnap}{\Name[Rudolph]{Carnap} is only formatted}{\Name[Rudolph]{Carnap} is not mentioned}}?'' Now watch closely: After we use \ForgetName[Rudolph]{Carnap}|\ForgetName[Rudolph]{Carnap}| we get the result,
 % ``\IfFrontName[Rudolph]{Carnap}{\IfMainName[Rudolph]{Carnap}{\Name[Rudolph]{Carnap} is both}{\Name[Rudolph]{Carnap} is only non-formatted}}{\IfMainName[Rudolph]{Carnap}{\Name[Rudolph]{Carnap} is only formatted}{\Name[Rudolph]{Carnap} is not mentioned}}.'' Both the main matter name and the front matter name were forgotten!
 %
-% This default behavior helps synchronize formatted and unformatted types of names. For example, if you wanted to use unformatted names in the footnotes and formatted names in the text (Section~\ref{sec:FrontFormat}), you could use, \emph{e.g.} \cmd{\SubvertName} right after the first use of a name in the body text, ensuring that all references in the text and notes would be short unless otherwise modified.\footnote{This manual takes advantage of that behavior at times in order to synchronize first and subsequent uses of names between formatted and unformatted sections of the body text.}
+% This default behavior helps synchronize formatted and unformatted types of names. For example, if you wanted to use unformatted names in the footnotes and formatted names in the text (Section~\ref{sec:FrontFormat}), you could use, \emph{e.g.} \cmd{\SubvertName} right after the first use of a name in the body text, ensuring that all references in the text and notes would be short unless otherwise modified.\footnote{This manual takes advantage of that behavior at times in order to synchronize first and subsequent uses of names between formatted and unformatted sections of the body text.}\medskip
 %
 % \DescribeMacro{\LocalNames}
 % \DescribeMacro{\GlobalNames}
 % If, however, this ``global'' behavior of \cmd{\ForgetName} and \cmd{\SubvertName} is not desired, you can use \cmd{\LocalNames} to change that behavior and \cmd{\GlobalNames} to restore the default behavior. Both of these macros  work globally.
 %
-% After \cmd{\LocalNames,} if you are in a ``front matter'' section via the \texttt{frontmatter} option or \cmd{\NamesInactive,} \cmd{\ForgetName} and \cmd{\SubvertName} will only affect unformatted names. If you are in a ``main matter'' section via the \texttt{mainmatter} option or \cmd{\NamesActive,} then \cmd{\ForgetName} and \cmd{\SubvertName} will only affect formatted names. Section~\ref{sec:LocalNames} offers a long example.
+% After \cmd{\LocalNames,} if you are in a ``front matter'' section (the \texttt{frontmatter} option or \cmd{\NamesInactive}) \cmd{\ForgetName} and \cmd{\SubvertName} will only affect unformatted names. If you are in a ``main matter'' section via the \texttt{mainmatter} option or \cmd{\NamesActive,} then \cmd{\ForgetName} and \cmd{\SubvertName} will only affect formatted names. Section~\ref{sec:LocalNames} offers a long example.
 %
 % \subsection{``Text Tags''}
 % \label{sec:tagtext}
@@ -1785,33 +1790,44 @@
 %
 % Sections~\ref{sec:TagName} and~\ref{sec:UntagName} deal with similar tagging features in the index. ``Text tags'' differ from index tags because they are not printed automatically with every name managed by \textsf{nameauth}. Section~\ref{sec:Hooksb} offers additional solutions that use the macros in this section.
 %
-% Instead of ``text tags,'' perhaps one should think about ``name information database entries.'' The macros in this section are named accordingly. We retain the ``text tag'' language for simplicity. 
+% Instead of ``text tags,'' perhaps one should think about ``name information database entries.'' The macros in this section are named accordingly. We retain the ``text tag'' language for simplicity.\medskip
 %
 % \DescribeMacro{\NameAddInfo}
 % Text tags are independent of any other name conditionals, similar to index tags. This \cmd{\long} macro's syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\NameAddInfo}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\marg{tag}
 % \end{quote}
 %
 % For example, |\NameAddInfo[George]{Washington}{ (1732--99)}|\NameAddInfo[George]{Washington}{ (1732--99)} will associate the text \texttt{\textvisiblespace(1732--99)} with the name \cmd{\LWash} \LWash. Note, however, that the tag did not print automatically with the name.
+% \clearpage
 %
 % \DescribeMacro{\NameQueryInfo}
 % To retrieve the information in a text tag, one uses the name as a key to the corresponding information:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\NameQueryInfo}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
-% Thus, |``\NameQueryInfo[George]{Washington}.''| expands to ``\NameQueryInfo[George]{Washington}.'' Notice the space at the beginning of the tag. This is intentional, as with index tags. Sections~\ref{sec:TagName}, \ref{sec:UntagName}, and~\ref{sec:Hooksa}ff. illustrate how this can permit tags like asterisks, daggers, and footnotes in addition to tags that do need a space or some separation between them and the name.
+% \NameAddInfo[Ulysses S.]{Grant}{ (president 1869--77)}%
+% \NameAddInfo[Schuyler]{Colfax}{\footnote{Seventeenth vice-president of the US during the first term (1869--73) of \Name[Ulysses S.]{Grant}\NameQueryInfo[Ulysses S.]{Grant}.}}%
+% Thus, |``\NameQueryInfo[George]{Washington}.''| expands to ``\NameQueryInfo[George]{Washington}.'' Notice the space at the beginning of the tag. This is intentional, as with index tags. Sections~\ref{sec:TagName}, \ref{sec:UntagName}, and~\ref{sec:Hooksa}ff. illustrate how this can permit tags like asterisks, daggers, and footnotes, such as one for%
+% \Name[Schuyler]{Colfax}.\NameQueryInfo[Schuyler]{Colfax} The source for that example looks like:
+% \begin{quote}\small\setstretch{1.1}
+% |\NameAddInfo[Ulysses S.]{Grant}{ (president 1869--77)}%|\\
+% |\NameAddInfo[Schuyler]{Colfax}%|\\
+% |{\footnote{Seventeenth vice-president of the US during%|\\
+% |the first term (1869--73) of \Name[Ulysses S.]{Grant}%|\\
+% |\NameQueryInfo[Ulysses S.]{Grant}.}}|\\
+% \texttt{\dots}\\
+% |\Name[Schuyler]{Colfax}.\NameQueryInfo[Schuyler]{Colfax}|
+% \end{quote}
+% By using these text tag macros with the conditional macros, one can display information associated with a name based on  whether or the name has occurred. As of version 2.4, this can be done either outside of \cmd{\NamesFormat} and the other general hooks or inside those macros.\medskip
 %
-% By using these text tag macros with the conditional macros, one can display information associated with a name based on  whether or the name has occurred. As of version 2.4, this can be done either outside of \cmd{\NamesFormat} and the other general hooks or inside those macros.
-%
 % \DescribeMacro{\NameClearInfo}
 % \cmd{\NameAddInfo} will replace one text tag with another text tag, but it does not delete a text tag. That is the role of \cmd{\NameClearInfo}. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\NameClearInfo}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 %
 % For example, |\NameClearInfo[George]{Washington}|\NameClearInfo[George]{Washington} will cause the macro |``\NameQueryInfo[George]{Washington}''| to produce nothing.
-% \clearpage
 %
 % \subsection{Name Variant Macros}
 % \subsubsection{\texttt{\textbackslash AKA}}
@@ -1820,116 +1836,148 @@
 % \DescribeMacro{\AKA}
 % \DescribeMacro{\AKA*}
 % \cmd{\AKA} (meaning \textit{also known as}) handles pseudonyms, stage names, \emph{noms de plume}, and so on in order to replace typing manual cross-references in the index. The syntax for \cmd{\AKA} is:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % \cmd{\AKA}\oarg{FNN}\marg{SNN}\oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names}\\
 % \cmd{\AKA*}\oarg{FNN}\marg{SNN}\oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names}
 % \end{quote}
-% Only the \meta{FNN} and \meta{SNN} arguments from \cmd{\Name} and friends may be cross-referenced. The new syntax allows \cmd{\AKA} to cross-reference all name types. Both macros create a cross-reference in the index from the \meta{Alt. FNN}, \meta{Alt. SNN}, and \meta{Alt. names} fields to a name defined by \meta{FNN} and \meta{SNN}, regardless of whether that name has been used. Please consult also Section~\ref{sec:AKAtips}, which covers a number of in-depth examples of \cmd{\AKA.} The syntactic aspects of name formatting (caps and reversing) work with \cmd{\AKA}.
+% Both macros create a cross-reference in the index from the \meta{Alt. FNN}, \meta{Alt. SNN}, and \meta{Alt. names} fields to a name defined by \meta{FNN} and \meta{SNN}, regardless of whether that name exists.
 %
-% Both macros print only the \meta{Alt. FNN} and \meta{Alt. SNN} fields in the body text. If the \meta{Alt. names} field is present, \cmd{\AKA} swaps \meta{Alt. names} with \meta{Alt. FNN} in the body text, similar to the naming macros.
+% \cmd{\AKA} prints the \meta{Alt. FNN} and \meta{Alt. SNN} fields in the body text. If the \meta{Alt. names} field is present, \cmd{\AKA} prints the \meta{Alt. names} and \meta{Alt. SNN} arguments in the body text. The caps and reversing macros work with \cmd{\AKA}.
 %
-% \cmd{\AKA*} has two functions. For Western names, where \meta{Alt. FNN} is present, \cmd{\AKA*} prints either just the \meta{Alt. FNN} or just the \meta{Alt. names} when they also are present. However, if \meta{Alt. FNN} is absent, \cmd{\AKA*} prints just \meta{Alt. names} if present, otherwise \meta{Alt. SNN}. See also Section~\ref{sec:TagName}.
+% For Western alternate names, in the body text, \cmd{\AKA*} only prints either \meta{Alt. FNN} or \meta{Alt. names}, if present. For non-Western alternate names, \cmd{\AKA*} prints either \meta{Alt. SNN} or \meta{Alt. names} if present.
 %
-% In this simple example we redefine the the default system of formatting to illustrate what happens with formatting by default:
-% \begin{quote}\small
-% \renewcommand*{\NamesFormat}{\scshape}|\renewcommand*{\NamesFormat}{\scshape}|\\
+% \begin{center}\bfseries Basic Operation\end{center}
+% \begin{quote}\small\setstretch{1.1}
+% These are the possible main-name forms before the alternate name:\\[1ex]
+% {\footnotesize\begin{tabular}{llll@{}}
+% \cmd{\AKA} & \oarg{FNN}\marg{SNN} & \dots \hphantom{\oarg{FNN}\quad\marg{SNN} \quad} & \emph{Western}\\
+% \cmd{\AKA} & \oarg{FNN}\marg{SNN, Affix} & \dots\\
+% \cmd{\AKA} & \hphantom{\oarg{FNN}}\marg{SNN} & \dots & \emph{Ancient}\\
+% \cmd{\AKA} & \hphantom{\oarg{FNN}}\marg{SNN, Affix} & \dots\\
+% \cmd{\AKA} & \hphantom{\oarg{FNN}}\marg{SNN, FNN} & \dots & \emph{Eastern}\\
+% \end{tabular}}\\[1ex]
+% These are the ``better'' alternate-name forms after the main name:\\[1ex]
+% {\footnotesize\begin{tabular}{lll@{}l@{}}
+% \cmd{\AKA} & \dots\hphantom{ \quad} & \oarg{Alt. FNN}\marg{Alt. SNN} & \emph{Western}\\
+% \cmd{\AKA} & \dots & \oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names}\\
+% \cmd{\AKA} & \dots & \oarg{Alt. FNN}\marg{Alt. SNN, Affix}\\
+% \cmd{\AKA} & \dots & \oarg{Alt. FNN}\marg{Alt. SNN, Affix}\oarg{Alt. names}\\
+% \cmd{\AKA} & \dots & \hphantom{\oarg{Alt. FNN}}\marg{Alt. SNN} & \emph{Ancient}\\
+% \cmd{\AKA} & \dots & \hphantom{\oarg{Alt. FNN}}\marg{Alt. SNN, Affix}\\
+% \cmd{\AKA} & \dots & \hphantom{\oarg{Alt. FNN}}\marg{Alt. SNN, Alt. FNN} & \emph{Eastern}\\
+% \end{tabular}}\\[1ex]
+% These alternate-name forms use the old syntax:\\[1ex]
+% {\footnotesize\begin{tabular}{llll@{}}
+% \cmd{\AKA} & \dots \hphantom{\oarg{NN}\marg{SNN}} & \marg{Alt. SNN}\oarg{Alt. names}\hphantom{ \quad} & \emph{Eastern}\\
+% \cmd{\AKA} & \dots & \marg{Alt. SNN}\oarg{Alt. names} & \emph{Ancient}\\
+% \end{tabular}}
+% \end{quote}
+% See also Sections~\ref{sec:TagName} and~\ref{sec:AKAtips}. The next example makes ``alternate name'' cross-references to \Name[Bob]{Hope}, illustrating Western names:
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\AKA[Bob]{Hope}[Leslie Townes]{Hope}| & \AKA[Bob]{Hope}[Leslie Townes]{Hope}\\
+% |\AKA*[Bob]{Hope}[Leslie Townes]{Hope}| & \AKA*[Bob]{Hope}[Leslie Townes]{Hope}\\
+% |\AKA[Bob]{Hope}%|\\|  [Leslie Townes]{Hope}[Lester T.]| & \AKA[Bob]{Hope}[Leslie Townes]{Hope}[Lester T.]\\
+% |\AKA*[Bob]{Hope}%|\\|  [Leslie Townes]{Hope}[Lester T.]| & \AKA*[Bob]{Hope}[Leslie Townes]{Hope}[Lester T.]\\\bottomrule
+% \end{tabular}
+% \end{center}
+%
+% As with nicknames and \cmd{\Name,} the alternate form ``Lester T. Hope'' does not appear in the index, but only in the body text. The next example makes ``alternate name'' cross-references to \KeepAffix\Name*{Louis, XIV}, \Name{Lao-tzu}, and \KeepAffix\Name{Gregory, I}:% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}\toprule
+% |\AKA{Louis, XIV}{Sun King}| & \AKA{Louis, XIV}{Sun King}\\
+% |\AKA*{Louis, XIV}{Sun King}| & \AKA{Louis, XIV}{Sun King}\\
+% |\AKA{Lao-tzu}{Li, Er}| & \AKA{Lao-tzu}{Li, Er}\\
+% |\AKA*{Lao-tzu}{Li, Er}| & \AKA{Lao-tzu}{Li, Er}\\\midrule
+% |\AKA{Gregory, I}{Gregory}[the Great]| & \AKA{Gregory, I}{Gregory}[the Great]\\
+% |\AKA*{Gregory, I}{Gregory}[the Great]| & \AKA*{Gregory, I}{Gregory}[the Great]\\\bottomrule
+% \end{tabular}
+% \end{center}\hbox{}
+%
+% \begin{center}\bfseries Formatting Alternate Names\end{center}
+% In this simple example we redefine the the default system of formatting to illustrate what can happen under default formatting conditions:
+% \begin{quote}\small\setstretch{1.1}
+% \renewcommand*\NamesFormat{\scshape}|\renewcommand*\NamesFormat{\scshape}|\\
 % |\Name{Jean, sans Peur}| |(\AKA{Jean,| |sans| |Peur}{Jean| |the| |Fearless})|\\ {\ttfamily was Duke of Burgundy 1404|--|1419.}
 %
 % \Name{Jean, sans Peur} (\AKA{Jean, sans Peur}{Jean the Fearless}) was Duke of Burgundy 1404--1419.
 % \end{quote}
 %
-% ``\AKA{Jean, sans Peur}{Jean the Fearless}''\marginpar{\small\raggedleft\texttt{formatAKA}} usually receives no formatting because it is post-processed by \cmd{\MainNamesHook} in the main matter text and \cmd{\FrontNamesHook} otherwise. The \texttt{alwaysformat} option causes the first-use hooks to be used all the time, while the \texttt{formatAKA} option causes the first-use hooks to be used only at the first use:
-% \ForgetName{Elizabeth, I}
-% \begin{quote}\small
-% \renewcommand*{\FrontNamesFormat}{\itshape}|\renewcommand*{\FrontNamesFormat}{\itshape}|\\
-% \renewcommand*{\NamesFormat}{\scshape}|\renewcommand*{\NamesFormat}{\scshape}|\\
-% |\LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.''|\\
-% \makeatletter\@nameauth at AKAFormattrue\makeatother
+% ``\AKA{Jean, sans Peur}{Jean the Fearless}''\marginpar{\small\raggedleft\texttt{formatAKA}} usually receives no formatting because it is post-processed by \cmd{\MainNamesHook} in the main matter text and \cmd{\FrontNamesHook} in the front matter. The \texttt{formatAKA} option causes \cmd{\AKA} to use \cmd{\NamesFormat} and \cmd{\FrontNamesFormat}, but only for the first use in the whole document. This allows name exclusion to work and avoids possible errors with index cross-references. Using the \texttt{alwaysformat} option formats all names as first uses:
 %
-% \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.''
+% \begin{quote}\small\setstretch{1.1}%
+% \begin{tabular}{@{}rl}Illustrating & |\AKA{Elizabeth, I}[Good Queen]{Bess}|\\ and & |\AKA{Elizabeth, I}{Virgin Queen}|:\\\end{tabular} \renewcommand*\FrontNamesFormat{\itshape}\renewcommand*\NamesFormat{\scshape}\ForgetName{Elizabeth, I}
 %
-% But if you switch to front matter, you will not get what you expect:\NamesInactive
+% {\makeatletter\@nameauth at AKAFormattrue\hbox{}\hfil\texttt{formatAKA}\\
+% \NamesInactive \textbf{Front matter:} \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.'' Queen \Eliz\ also was known as the ``\AKA{Elizabeth, I}{Virgin Queen}.''\\
+% \NamesActive \textbf{Main matter:} \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.'' Queen \Eliz\ also was known as the ``\AKA{Elizabeth, I}{Virgin Queen}.'' \makeatother}
 %
-% \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.''
+% {\makeatletter\@nameauth at AlwaysFormattrue\hbox{}\hfil\texttt{ alwaysformat}\\
+% \NamesInactive \textbf{Front matter:} \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.'' Queen \Eliz\ also was known as the ``\AKA{Elizabeth, I}{Virgin Queen}.''\\
+% \NamesActive \textbf{Main matter:} \LEliz\ was known as ``\AKA{Elizabeth, I}[Good Queen]{Bess}.'' Queen \Eliz\ also was known as the ``\AKA{Elizabeth, I}{Virgin Queen}.'' \makeatother}
 % \end{quote}
-% \cmd{\AKA} works with the main/front formatting systems, but its ``first use'' naming system allows only one first use per name, per document.\footnote{This is intentionally a part of the design for \cmd{\AKA}.}
-% Using \texttt{formatAKA} allows that one first-use instance to call the respective first-use formatting hooks. Of course, the \texttt{alwaysformat} option simply uses brute force to make everything call the first-use hooks.
+% \ForgetName{Elizabeth, I}%
 %
-% The following complex example has lines of source text interleaved with a point-by-point enumerated list, showing the Continental style. The small caps are a syntactic element of the name parameters themselves:
+% The following annotated example shows a simple Continental style where the surname is always in small caps, both in the text and in the index:
 % \begin{enumerate}
-% \item I tag the names for proper sorting.\\[4pt]
+% \item Tag the names for proper sorting.\\[4pt]
 % |\PretagName[Heinz]{\textsc{Rühmann}}{Ruehmann, Heinz}%|\\
 % |\PretagName[Heinrich Wilhelm]{\textsc{Rühmann}}%|\\
 % |  {Ruehmann, Heinrich Wilhelm}%|
-% \item I want ``\Name*[Heinz]{\textsc{Rühmann}}'' to be the main name of reference, so \cmd{\AKA*} uses his legal name as the cross-reference. \cmd{\AKA*} prints only ``Heinrich Wilhelm'' in the body text. Nevertheless, the index cross-reference will be complete with the surname.\\[4pt]
+% \item ``\Name*[Heinz]{\textsc{Rühmann}}'' is the main name. \cmd{\AKA*} uses ``\textsc{Rühmann}, Heinrich Wilhelm'' as the index cross-reference and prints only ``Heinrich Wilhelm'' in the body text.\\[4pt]
 % |\AKA*[Heinz]{\textsc{Rühmann}}%|\\
 % |  [Heinrich Wilhelm]{\textsc{Rühmann}} %|
-% \item \cmd{\SubvertName} causes  \cmd{\FName} to print the short version via the ``subsequent-use'' \cmd{\MainNameHook.}\\[4pt]
-% |\SubvertName[Heinz]{\textsc{Rühmann}}%|
+% \item \cmd{\SubvertName} causes \cmd{\FName} to print the short version via the ``subsequent-use'' macro \cmd{\MainNameHook.}\\[4pt]
+% |\SubvertName[Heinz]{\textsc{Rühmann}} %|
 % \item \cmd{\FName} prints ``\FName[Heinz]{\textsc{Rühmann}}.''\\[4pt]
 % |``\FName[Heinz]{\textsc{Rühmann}}'' %|
 % \item \cmd{\Name} prints ``\Name[Heinz]{\textsc{Rühmann}}.'' The small caps are syntactic, not typographic, because they are part of the argument to \cmd{\Name} itself.\\[4pt]
-% |\Name[Heinz]{\textsc{Rühmann}} %|
+% |\Name[Heinz]{\textsc{Rühmann}}| |(7| |March| |1902--3| |October| |%|\\
+% |1994)| |was| |a| |German| |actor| |in| |over| |100| |films.|
 % \end{enumerate}
 % The resulting text is:
-% \begin{quote}
-% \AKA*[Heinz]{\textsc{Rühmann}}[Heinrich Wilhelm]{\textsc{Rühmann}}
-% \SubvertName[Heinz]{\textsc{Rühmann}}``\FName[Heinz]{\textsc{Rühmann}}'' 
-% \Name[Heinz]{\textsc{Rühmann}} (7 March 1902--3 October 1994) was a German film actor who appeared in over 100 films between 1926 and 1993.
+% \begin{quote}\small
+% \AKA*[Heinz]{\textsc{Rühmann}}[Heinrich Wilhelm]{\textsc{Rühmann}} \ignorespaces%
+% \SubvertName[Heinz]{\textsc{Rühmann}}\ignorespaces%
+% ``\FName[Heinz]{\textsc{Rühmann}}'' \ignorespaces%
+% \Name[Heinz]{\textsc{Rühmann}} (7 March 1902--3 October \ignorespaces%
+% 1994) was a German actor in over 100 films.
 % \end{quote}
+% \clearpage
 %
-% Using \Name[Bob]{Hope}, \ForgetName{Louis, XIV}\Name{Louis, XIV}, \Name{Lao-tzu}, and \Name{Gregory, I} as examples, we see how \cmd{\AKA} and \cmd{\AKA*} work:
-%
-% \begin{quote}\small\setstretch{1.2}
-% \begin{tabular}{ll}\toprule
-% |\AKA[Bob]{Hope}[Leslie Townes]{Hope}| & \AKA[Bob]{Hope}[Leslie Townes]{Hope}\\
-% |\AKA*[Bob]{Hope}[Leslie Townes]{Hope}| & \AKA*[Bob]{Hope}[Leslie Townes]{Hope}\\
-% |\AKA[Bob]{Hope}%|\\|  [Leslie Townes]{Hope}[Lester T.]| & \AKA[Bob]{Hope}[Leslie Townes]{Hope}[Lester T.]\\
-% |\AKA*[Bob]{Hope}%|\\|  [Leslie Townes]{Hope}[Lester T.]| & \AKA*[Bob]{Hope}[Leslie Townes]{Hope}[Lester T.]\\\midrule
-% |\AKA{Louis, XIV}{Sun King}| & \AKA{Louis, XIV}{Sun King}\\
-% |\AKA*{Louis, XIV}{Sun King}| & \AKA{Louis, XIV}{Sun King}\\
-% |\AKA{Lao-tzu}{Li, Er}| & \AKA{Lao-tzu}{Li, Er}\\
-% |\AKA*{Lao-tzu}{Li, Er}| & \AKA{Lao-tzu}{Li, Er}\\\midrule
-% |\AKA{Gregory, I}{Gregory}[the Great]| & \AKA{Gregory, I}{Gregory}[the Great]\\
-% |\AKA*{Gregory, I}{Gregory}[the Great]| & \AKA*{Gregory, I}{Gregory}[the Great]\\\bottomrule
-% \end{tabular}
+% \begin{center}\bfseries Advanced Cross-Referencing\end{center}
+% \cmd{\AKA} will not create multiple cross-references. Handle the special case where one moniker applies to multiple people with a manual solution, \emph{e.g.}, ``Snellius'' for both \Name*[Willebrord]{Snel van Royen} and his son \Name*[Rudolph]{Snel van Royen}:
+% \begin{quote}\small\setstretch{1.1}
+% |\index{Snellius|\verb!|!{}|see{Snel|\,|van|\,|Royen,|\,|Rudolph;%|\\ |Snel|\,|van|\,|Royen,|\,|Willebrord}}|
+% \index{Snellius|see{Snel van Royen, Rudolph; Snel van Royen, Willebrord}}
 % \end{quote}
 %
-% The alternate form ``Lester T. Hope'' in the previous table does not appear in the index, but only in the body text. A possible use here could involve ``spurious'' information or opinions that one might want to mention in the text but not the index. One produces \Name*{Gregory, I} ``\AKA*{Gregory, I}{Gregory}[the Great],'' along with a \emph{see} reference from ``Gregory the Great'' to ``Gregory I,'' via:\\[1ex]
-% \indent\quad|\Name*{Gregory,| |I}| |``\AKA*{Gregory,| |I}{Gregory}[the| |Great]''|\medskip
+% Keep in mind, however, that formatting manual index entries can present some caveats; see Section~\ref{sec:IndexSort}.
 %
-% \cmd{\AKA} will not create multiple cross-references. Handle the special case where one moniker applies to multiple people with a manual solution, \emph{e.g.}, ``Snellius'' for both \Name*[Willebrord]{Snel van Royen} and his son \Name*[Rudolph]{Snel van Royen}:
-%\begin{quote}
-% |\index{Snellius|\verb!|!{}|see{Snel|\,|van|\,|Royen,|\,|Rudolph;%|\\ |Snel|\,|van|\,|Royen,|\,|Willebrord}}|
-% \index{Snellius|see{Snel van Royen, Rudolph;%
-% Snel van Royen, Willebrord}}
-%\end{quote}
-%
 % Cross-references generated by \cmd{\AKA} and \cmd{\AKA*} are meant only to be \emph{see} references, never page entries. See also Section~\ref{sec:error}. In certain cases, the alternate name might need to be indexed with page numbers and \emph{see also} references. Do not use \cmd{\AKA} in those cases, rather, consider the following:
 %
 % \label{manualxref}\label{Rambam}%
-%\begin{itemize}\small
+% \begin{itemize}\small
 % \item Refer to the person intended, \emph{e.g.}, \Name{Maimonides} (\AKA{Maimonides}{Moses ben-Maimon}):\\ |\Name{Maimonides}| |(\AKA{Maimonides}{Moses| |ben-Maimon})|
 % \item We now have a name and a \emph{see} reference. Now one must refer to the alternate name, \emph{e.g.}, \Name{Rambam}: |\Name{Rambam}|.
 % \item The alternate name must occur before making a cross-reference to the main name, in this case, \Name{Maimonides}.
 % \item Add \verb!\index{Rambam|seealso{Maimonides}}! at the end of the document to ensure that it is the last entry among the cross-references. Generally, \emph{see also} references follow \emph{see} references in an index entry.\footnote{Different standards exist for punctuating index entries and cross-references. Check with your publisher, style guide, docs for \textsf{xindy} and \textsf{makeindex}, and \textsf{http://tex.stackexchange.com}.}
-%\end{itemize}
+% \end{itemize}
 %
 % Using \cmd{\PretagName} helps avoid the need for manual index entries. Instead of doing a lot of extra work for some names, consider the following example:
 %
-% \begin{quote}\small
+% \begin{quote}\small\setstretch{1.1}
 % {\ttfamily%
-% |\PretagName{\textit{Doctor| |Angelicus}}{Doctor| |Angelicus}|\\
+% |\PretagName{\textit{Doctor| |angelicus}}{Doctor| |angelicus}|\\
 % |Perhaps| |the| |greatest| |medieval| |theologian was %|\\
 % |\Name{Thomas,| |Aquinas} %|\\
 % |(\AKA{Thomas,| |Aquinas}{Thomas| |of| |Aquino}), also known as %|\\
-% |\AKA{Thomas, Aquinas}{\textit{Doctor Angelicus}}|.}
+% |\AKA{Thomas, Aquinas}{\textit{Doctor angelicus}}|.}
 %
-% \PretagName{\textit{Doctor Angelicus}}{Doctor Angelicus}
+% \PretagName{\textit{Doctor angelicus}}{Doctor Angelicus}
 % Perhaps the greatest medieval theologian was
 % \Name{Thomas, Aquinas} %
 % (\AKA{Thomas, Aquinas}{Thomas of Aquino}), also known as %
-% \AKA{Thomas, Aquinas}{\textit{Doctor Angelicus}}.
+% \AKA{Thomas, Aquinas}{\textit{Doctor angelicus}}.
 % \end{quote}
 % We use the medieval form: |\Name{Thomas, Aquinas}| because ``Aquinas'' is not a surname, even though many people, including scholars, falsely use it as such. Section~\ref{sec:standards} talks about those unfortunate situations where one must use the Western form |\Name[Thomas]{Aquinas}.|
 % \clearpage
@@ -1937,34 +1985,39 @@
 % \subsubsection{\texttt{\textbackslash PName}}
 %
 % \DescribeMacro{\PName}
+% \DescribeMacro{\PName*}
 % \cmd{\PName} is a ``convenience macro'' meant for Western names. It generates a main name followed by a cross-reference in parentheses with the following syntax:
 % \begin{quote}\small
 % \cmd{\PName}\oarg{FNN}\marg{SNN}\oarg{other FNN}\marg{other SNN}\oarg{other alt.}
 % \end{quote}
 %
-% Although \cmd{\PName} creates an easy shortcut, its drawbacks are many. It only can use the \meta{FNN}\meta{SNN} form of \cmd{\AKA}. Neither \cmd{\AKA*}, nor \cmd{\CapName}, \cmd{\CapThis}, \cmd{\RevComma}, \cmd{\RevName}, and the related package options work with \cmd{\PName.}
-%
-% The main name comes first, followed by the name that is only a \emph{see} reference. \cmd{\PName} can generate the following examples:
-%
+% Although \cmd{\PName} creates an easy shortcut, its drawbacks are many. It only can use the \meta{FNN}\meta{SNN} form of \cmd{\AKA}. Neither \cmd{\AKA*}, nor \cmd{\CapName}, \cmd{\CapThis}, \cmd{\RevComma}, \cmd{\RevName}, and the related package options work with \cmd{\PName.} Below we see the forms that \cmd{\Pname} can handle:
 % \begin{quote}\small\setstretch{1.1}
 % |\PName[Mark]{Twain}[Samuel L.]{Clemens}|\\
-% |\PName*[Mark]{Twain}[Samuel L.]{Clemens}|\\
-% |\PName[Mark]{Twain}[Samuel L.]{Clemens}|\\[1ex]
-% \hbox{}\hfill \PName[Mark]{Twain}[Samuel L.]{Clemens}\\
-% \hbox{}\hfill \PName*[Mark]{Twain}[Samuel L.]{Clemens}\\
-% \hbox{}\hfill \PName[Mark]{Twain}[Samuel L.]{Clemens}\\[1ex]
+% \hbox{}\dotfill \PName[Mark]{Twain}[Samuel L.]{Clemens}\\
+% \hbox{}\dotfill \PName[Mark]{Twain}[Samuel L.]{Clemens}\\[1ex]
+% |\PName*[Mark]{Twain}[Samuel L.]{Clemens}[Sam]|\\
+% \hbox{}\dotfill \PName*[Mark]{Twain}[Samuel L.]{Clemens}[Sam]\\[1ex]
 % |\PName{Voltaire}[François-Marie]{Arouet}|\\
-% |\PName*{Voltaire}[François-Marie]{Arouet}|\\
-% |\PName{Voltaire}[François-Marie]{Arouet}|\\[1ex]
-% \hbox{}\hfill \PName{Voltaire}[François-Marie]{Arouet}\\
-% \hbox{}\hfill \PName*{Voltaire}[François-Marie]{Arouet}\\
-% \hbox{}\hfill \PName{Voltaire}[François-Marie]{Arouet}
+% \hbox{}\dotfill \PName{Voltaire}[François-Marie]{Arouet}\\
+% \hbox{}\dotfill \PName{Voltaire}[François-Marie]{Arouet}\\[1ex]
+% |\PretagName{\textit{Doctor mellifluus}}{Doctor mellifluus}|\\
+% |\PName{Bernard, of Clairvaux}{\textit{Doctor mellifluus}}|\\
+% \PretagName{\textit{Doctor mellifluus}}{Doctor mellifluus}
+% \hbox{}\dotfill \PName{Bernard, of Clairvaux}{\textit{Doctor mellifluus}}\\
+% \hbox{}\dotfill \PName{Bernard, of Clairvaux}{\textit{Doctor mellifluus}}
 % \end{quote}
 %
-% \cmd{\PName} can be a bit sketchy with medieval names. You get \PName{William, I}{William, the Conqueror} with |\PName{William,| |I}{William,| |the Conqueror}.| Stay away from |\PName{William, I}{William}[the Conqueror]| because that is the old syntax that can break both \cmd{\AKA} and \cmd{\PName} if used in the leading arguments instead of in the trailing arguments. The old syntax can get you confused and lead you to type |\PName{William, I}[William]{the Conqueror}.| You would get a name that looked right in the body text but wrong in the index.
+% Like \cmd{\AKA,} \cmd{\PName} cannot use the old syntax \marg{SNN}\oarg{FNN} for the main name, but it can do so for the alternate name.
 %
-% Something like |\PName{Lao-tzu}{Li, Er}| ``\PName{Lao-tzu}{Li, Er}'' works well enough, but |\PName{Gregory, I}{Gregory}[the Great]|\ForgetName{Gregory, I} ``\PName{Gregory, I}{Gregory}[the Great]'' starts moving close to the old syntax.
+% |\PName{William,| |I}{William,| |the Conqueror}| gives \PName{William, I}{William, the Conqueror}. To limit possible confusion, avoid the old syntax in the alternate name: |\PName{William, I}{William}[the Conqueror].| Nevertheless, that \emph{does} work and will produce \PName{William, I}{William}[the Conqueror]. If  \cmd{\PName*} to get \PName*{William, I}{William}[the Conqueror].
 %
+% Also choose forms like |\PName{Lao-tzu}{Li, Er}| ``\PName{Lao-tzu}{Li, Er}'' instead of |\PName{Lao-tzu}{Li}[Er]| ``\PName{Lao-tzu}{Li}[Er].'' Both forms will work, but look real confusing when interchanged.
+%
+% The\marginpar{\small\raggedleft\dbend} form |\PName{William, I}[William]{the Conqueror}| will produce  ``\IndexInactive\PName{William, I}[William]{the Conqueror}\IndexActive'' in the body text, but its index entry will be ``the Conqueror, William \emph{see} William I.'' This is a result of mixing medieval and Western forms.
+%
+% \clearpage
+%
 % \subsection{Indexing Macros}
 %
 % \subsubsection{Indexing Control}
@@ -1976,7 +2029,7 @@
 %
 % Please\marginpar{\small\raggedleft\cmd{\global}} note that these two macros can be used explicitly as a pair. They also can be used singly within an explicit scope, where the effects cease after leaving that scope. Use \cmd{\global} to force a global effect.\medskip
 %
-% \noindent\begin{tabular}{p{0.97\textwidth}}\toprule\hfil\bfseries Index tags only work when indexing is active.\hfil\\\bottomrule\end{tabular}
+% \noindent\begin{tabular}{p{0.96\textwidth}}\toprule\hfil\bfseries Index tags only work when indexing is active.\hfil\\\bottomrule\end{tabular}
 %
 % \subsubsection{Indexing and \textsf{babel}}
 % \label{sec:babel}
@@ -1983,11 +2036,9 @@
 % Using\marginpar{\small\raggedleft \textsf{texindy}} \textsf{babel} with Roman page numbers will put \cmd{\textlatin} in the index entries if one includes a language that does not use the Latin alphabet\,---\,even if the main language does. The \texttt{texindy} program will ignore such references. This issue can affect \textsf{nameauth.}
 %
 % One fairly effective workaround for \texttt{texindy} redefines \cmd{\textlatin} to produce the page number itself within a certain scope like:
-% \begin{quote}
-% |\newcommand{\fixindex}[1]{\def\textlatin##1{##1}#1}|\\\dots\\
-% |\fixindex{%|\\
-% \meta{paragraphs of running text}|%|\\
-% |}|
+% \begin{quote}\small\setstretch{1.1}
+% |\newcommand\fixindex[1]{\def\textlatin##1{##1}#1}|\\\dots\\
+% |\fixindex{| \meta{paragraphs of running text} |}|
 % \end{quote}
 % Of course, one can opt to check if \cmd{\textlatin} is defined, save its value, redefine it, then restore it, perhaps even in an environment.
 %
@@ -1995,7 +2046,7 @@
 % 
 % \DescribeMacro{\IndexName}
 % This macro creates an index entry like those created by \cmd{\Name} and friends. It prints nothing in the body text. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\IndexName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 %
@@ -2008,16 +2059,24 @@
 % \subsubsection{Index Sorting}
 % \label{sec:IndexSort}
 %
-% The general practice for sorting with \texttt{makeindex -s} involves creating your own |.ist| file (pages 659--65 in \emph{The Latex Companion}). Otherwise use the following form that works with both \texttt{makeindex} and \texttt{texindy}: |\index{|\meta{sortkey}|@|\meta{actual}|}|
-%
-%Before version 2.0 of \textsf{nameauth}, one had to sort and index names like \Name[Jan]{Łukasiewicz} and \Name*{Æthelred, II} by putting them between \cmd{\IndexInactive} and \cmd{\IndexActive} while creating manual index entries.\medskip
+% The general practice for sorting with \texttt{makeindex -s} involves creating your own |.ist| file (pages 659--65 in \emph{The Latex Companion}). Otherwise the following form works with both \texttt{makeindex} and \texttt{texindy}: |\index{|\meta{sortkey}|@|\meta{actual}|}|
 % 
+% \begin{center}\bfseries Basic Sorting (Makeindex)\end{center}
+% 
 % \DescribeMacro{\PretagName}
-% Fortunately, the current versions of \textsf{nameauth} have adopted an easier solution. The syntax of \cmd{\PretagName} is like that of \cmd{\TagName}:
-% \begin{quote}
+% Since version 2.0, \textsf{nameauth} integrates this sort of index sorting automatically by using a ``pretag.'' The syntax is:
+% \begin{quote}\small
 % \cmd{\PretagName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\marg{tag}
 % \end{quote}
 %
+% \cmd{\PretagName} creates a sort key terminated with the ``actual'' character, which is |@| by default. Do not include the ``actual'' character in the ``pretag.''
+% For example:
+% \begin{quote}\small\setstretch{1.1}
+% |\PretagName[Jan]{Łukasiewicz}{Lukasiewicz, Jan}|\\
+% |\PretagName{Æthelred, II}{Aethelred 2}|
+% \end{quote}
+% One need only ``pretag'' names once in the preamble. Every time that one refers to \Name[Jan]{Łukasiewicz} or \Name{Æthelred, II}, the proper index entry will be created. If you create a cross-reference with \cmd{\AKA} and you want to ``pretag'' it, see Section~\ref{sec:AKA}.
+%
 % Although the \cmd{\PretagName} macro might look similar to the the other tagging macros, its use and scope is quite a bit different:
 % \begin{itemize}\small
 % \item You can ``pretag'' any name and any cross-reference.
@@ -2024,17 +2083,39 @@
 % \item You can ``tag'' and ``untag'' only names, not cross-references.
 % \item There is no command to undo a ``pretag.''
 % \end{itemize}
-% \cmd{\PretagName} creates a sort key terminated with the ``actual'' character, which is |@| by default. Do not include the ``actual'' character in the pretag.
-% Here is an example of its use:
-% \begin{quote}
-% |\PretagName[Jan]{Łukasiewicz}{Lukasiewicz, Jan}|\\
-% |\PretagName{Æthelred, II}{Aethelred 2}|
+%
+% \DescribeMacro{\IndexActual}
+% If you need to change the ``actual'' character, such as with \texttt{gind.ist}, you would put |\IndexActual{=}| in the preamble before any use of \cmd{\PretagName}.
+% 
+% \begin{center}\bfseries Extra Spaces and Sorting\end{center}
+% 
+% Under\marginpar{\small\raggedleft\dbend} NFSS, extended Unicode characters expand to add one or two spaces after control sequences. See \cmd{\indexentry} and \cmd{\item} entries in your \texttt{idx} and \texttt{ind} files. For example, \texttt{ä} becomes \texttt{\cmd{\IeC\textvisiblespace}\{\cmd{\"a}\}} (one space added) and \texttt{Æ} becomes \texttt{\cmd{\IeC\textvisiblespace}\{\cmd{\AE\textvisiblespace}\}} (two spaces added).
+% Both \texttt{xelatex} and \texttt{lualatex} (using \textsf{fontspec}) avoid these issues by handling the characters natively.
+% \begin{quote}\small\setstretch{1.1}
+% NFSS: |\index{Fußball}| $\rightarrow$ \cmd{\indexentry}\ignorespaces%
+% \texttt{\{Fu\cmd{\IeC\textvisiblespace}\{\cmd{\ss\textvisiblespace}\}ball\}\{}\ignorespaces%
+% \meta{page}\texttt{\}}
+%
+% fontspec: |\index{Fußball}| $\rightarrow$ \cmd{\indexentry}\texttt{\{Fußball\}\{}\meta{page}\texttt{\}}
+%
+% cseq: |\index{Fu\ss ball}| $\rightarrow$ \cmd{\indexentry}\texttt{\{Fu\cmd{\ss\textvisiblespace}ball\}\{}\meta{page}\texttt{\}}
 % \end{quote}
 %
-% One need only pretag names once in the preamble. Every time that one refers to \Name[Jan]{Łukasiewicz} or \Name{Æthelred, II}, the proper index entry will be created. If you create a cross-reference with \cmd{\AKA} and you want to pretag it, see Section~\ref{sec:AKA}.\medskip
+% A macro with the general form below, similar to \cmd{\IndexName}, will add two spaces after \emph{some} control sequences. Those spaces only affect index sorting, not appearance. Remember this when using manual index entries with \textsf{nameauth}:
+% \begin{quote}\small\setstretch{1.1}
+% |\newcommand\IndexExample[1]{%|\\
+% \hbox{}\qquad|\protected at edef\argument{#1}\index{\argument}}%|
+% 
+% |\IndexExample{\textsc{football}}| $\rightarrow$\\ \hbox{}\qquad\ignorespaces%
+% \cmd{\indexentry}\ignorespaces%
+% \texttt{\{\cmd{\textsc\textvisiblespace\textvisiblespace}\ignorespaces%
+% \{football\}\}\{}\meta{page}\texttt{\}}
 %
-% \DescribeMacro{\IndexActual}
-% If you need to change the ``actual'' character, such as with \texttt{gind.ist}, put |\IndexActual{=}| in the preamble.
+% |\index{\textsc{football}}| $\rightarrow$\\ \hbox{}\qquad\ignorespaces%
+% \cmd{\indexentry}\ignorespaces%
+% \texttt{\{\cmd{\textsc}\ignorespaces%
+% \{football\}\}\{}\meta{page}\texttt{\}}
+% \end{quote}
 %
 % \subsubsection{\texttt{\textbackslash TagName}}
 % \label{sec:TagName}
@@ -2041,32 +2122,36 @@
 %
 % \DescribeMacro{\TagName}
 % This macro creates an index tag that will be appended to all index entries for a corresponding \cmd{\Name} from when it is invoked until the end of the document or a corresponding \cmd{\UntagName}. Both \cmd{\TagName} and \cmd{\UntagName} handle their arguments like \cmd{\IndexName}. If global tags are desired, tag names in the preamble.
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\TagName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}\marg{tag}
 % \end{quote}
 %
-% Tags are not ``pretags.'' To help sort that out, we look at what gets affected by these commands:\medskip
+% Tags are not ``pretags.'' To help sort that out, we look at what gets affected by these commands:
 %
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{r@{\,\vrule width0.5pt\,}c@{\,\vrule width0.5pt\,}c@{\,\vrule width0.5pt\,}l}
 % & \cmd{\PretagName} & \\
 % |\index{| & |Aethelred 2@| & |Æthelred II| & |, king}|\\
 % & & & \cmd{\TagName} and \cmd{\UntagName}\\
-% \end{tabular}\medskip
+% \end{tabular}
+% \end{center}
 %
 % All the tagging commands use the name arguments as a reference point. \cmd{\PretagName} generates the leading sort key while \cmd{\TagName} and \cmd{\UntagName} affect the trailing content of the index entry.
 %
 % Tags created by \cmd{\TagName} can be helpful in the indexes of history texts, as can other package features. Here \cmd{\TagName} causes the \textsf{nameauth} indexing macros to append ``\texttt{,\textvisiblespace pope}'' to the index entries for \Name*{Gregory, I} and \Name*{Leo, I}:
-% \begin{quote}\small
-% \begin{tabular}{p{0.5\textwidth}p{0.28\textwidth}}
-% |\TagName{Leo, I}{, pope}| |\TagName{Gregory, I}{, pope}| & (in the preamble)\\
-% \dots & \\
-% |\Name*{Leo,| |I}| |\Name*{Gregory,| |I}| & (first references to \ForgetName{Leo, I}\Name*{Leo, I} and \ForgetName{Gregory, I}\Name*{Gregory, I})\\
-% \dots & \\
-% |\Name*{Leo, I} was known as| |\AKA{Leo, I}{Leo}[the Great].| & \Name*{Leo, I} was known as \AKA{Leo, I}{Leo}[the Great].\\
-% \dots & \\
-% |\Name{Gregory,| |I}| |``\AKA*{Gregory,| |I}%| |{Gregory}[the Great],''| |another| |major| |pope.| & \Name{Gregory, I} ``\AKA*{Gregory, I}{Gregory}[the Great],'' another major pope.\\
+% \begin{center}\small\setstretch{1.1}
+% \begin{tabular}{ll}
+% |\TagName{Leo, I}{, pope}| & (in the preamble)\\
+% |\TagName{Gregory, I}{, pope}| \\
+% \dots\\
+% |\Name*{Leo, I} was known as| & \Name*{Leo, I} was known as \\
+% |\AKA{Leo, I}{Leo}[the Great].| & \AKA{Leo, I}{Leo}[the Great].\\
+% \dots\\
+% |\Name{Gregory,| |I}| |``\AKA*{Gregory,| |I}%| & \Name{Gregory, I} ``\AKA*{Gregory, I}{Gregory}[the Great],''\\
+% |{Gregory}[the Great],''| |also| |was| & also was a major pope.\\
+% |a| |major| |pope.| \\
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
 % Tags are literal text that can be daggers, asterisks, and even specials. For example, all fictional names in the index of this manual are tagged with an asterisk. One must add any desired spacing to the start of the tag. Tagging aids scholarly indexing and can include life/regnal dates and other information.
 %
@@ -2079,13 +2164,13 @@
 %
 % \DescribeMacro{\UntagName}
 % \cmd{\TagName} will replace one tag with another tag, but it does not remove a tag from a name. That is the role of \cmd{\UntagName}. The syntax is:
-% \begin{quote}
+% \begin{quote}\small
 % \cmd{\UntagName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 %
 %  By using \cmd{\TagName} and \cmd{\UntagName}, one can disambiguate different people with the same name. For example:
 %
-% \begin{quote}\small
+% \begin{quote}\small\setstretch{1.1}
 % \ttfamily This refers to |\Name*[John]{Smith}|.\\
 % Now another |\ForgetName[John]{Smith}%|\\
 % |\TagName[John]{Smith}{ (other)}\Name[John]{Smith}|.\\
@@ -2105,13 +2190,13 @@
 % 
 % \DescribeMacro{\ExcludeName}
 % \label{sec:exclude}
-% This macro globally prevents the indexing of a particular name or cross-reference. If you do not use it at the beginning of the document, you may not exclude any name or cross-reference that has been used already. The syntax is:
-% \begin{quote}
+% This\marginpar{\small\raggedleft\dbend} macro globally prevents the indexing of a particular name or cross-reference. If you do not use it at the beginning of the document, you may not exclude any name or cross-reference that has been used already. The syntax is:
+% \begin{quote}\small
 % \cmd{\ExcludeName}\oarg{FNN}\marg{SNN}\oarg{Alternate names}
 % \end{quote}
 %
 % Consider the following example, where you will see excluded names printed in the body text with all the formatting and other features:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\ExcludeName[Kris]{Kringle}|\ExcludeName[Kris]{Kringle}\\
 % |\Name[Kris]{Kringle}| and |\Name[Kris]{Kringle}|:\\
 % \Name[Kris]{Kringle} and \Name[Kris]{Kringle}.
@@ -2120,7 +2205,7 @@
 % Nevertheless, no matter how many times you use \Name[Kris]{Kringle} in the body text, the name will never appear in the index. Remember the \Name{Grinch} from Section~\ref{sec:tests}? He will not appear in the index either.
 %
 % \cmd{\ExcludeName} also prevents cross-references. You may see output in the body text, but no \emph{see}-reference will appear in the index:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\ExcludeName[Santa]{Claus}|\ExcludeName[Santa]{Claus}\\
 % |\AKA[Kris]{Kringle}[Santa]{Claus}|\\ \AKA[Kris]{Kringle}[Santa]{Claus}
 % \end{quote}
@@ -2130,30 +2215,122 @@
 %
 % \subsection{Longer Examples}
 %
+% \subsubsection{Variant Spellings}
+%
+% This section illustrates why this package is called ``nameauth.'' Here we get to an example where the macros work together to implement a name authority.
+%
+% Handling variant name spellings can be complicated. For example, let us assume that you are editing a collection of essays. You might settle on the form \Name[W.E.B.]{Du Bois} in your name authority. An essay in that collection might use the alternate spelling \IndexInactive\Name*[W.E.B.]{DuBois}\IndexActive. The author or publisher who owns that work might not grant you permission to alter the spelling. In that case, you could add an alternate spelling. Using the simplified interface, it would be:
+% \begin{nameauth}
+% \< DuBois & W.E.B. & Du Bois & >
+% \< AltDuBois & W.E.B. & DuBois & >
+% \end{nameauth}
+% \begin{quote}\small\setstretch{1.1}
+% |\begin{nameauth}|\\
+% |  \< DuBois & W.E.B. & Du Bois & >|\\
+% |  \< AltDuBois & W.E.B. & DuBois & >|\\
+% |\end{nameauth}|
+% \end{quote}
+%
+% If you wanted to index the alternate spelling with its own entry, the trivial use of \cmd{\AltDuBois} allows that easily. All you need do is make cross-references to each variant in the index so that the reader is aware of them.
+%
+% Nevertheless, \DuBois\ and \IndexInactive\AltDuBois\IndexActive\ differ only by spaces. For several good reasons, such as fault tolerance in typing, the first/subsequent use mechanism ignores spaces and sees them as \emph{the same name}. Use |\ForgetName[W.E.B.]{Du Bois}| to trigger the first use of \cmd{\AltDuBois} in that section.
+%
+% If you wanted to index the variants under only one name entry, it gets more complicated. You could do the following:
+%
+% \begin{enumerate}\small
+% \item Use |\ForgetName[W.E.B.]{Du Bois}| at the start of the section.
+% \item Wrap \cmd{\AltDuBois} between \cmd{\IndexInactive} and \cmd{\IndexActive}.
+% \item Call \cmd{\IndexName} with the authoritative form right after \cmd{\IndexActive}.
+% \item Create a cross-reference in the index.
+% \end{enumerate}
+% This can be automated at the start of the section with something like:
+% \begin{quote}\small\setstretch{1.1}
+% \ForgetName[W.E.B.]{DuBois}%
+% \gdef\OtherDuBois{\IndexInactive\AltDuBois\IndexActive\IndexName[W.E.B.]{Du Bois}}%
+% \index{DuBois, W.E.B.|see{Du Bois, W.E.B.}}%
+% |\ForgetName[W.E.B.]{DuBois}|\\
+% |\gdef\OtherDuBois{\IndexInactive\AltDuBois\IndexActive%|\\|  \IndexName[W.E.B.]{Du Bois}}|\\
+% \verb!\index{DuBois, W.E.B.|see{Du Bois, W.E.B.}}!
+% \end{quote}
+%
+% The alternate section mentions \cmd{\OtherDuBois} starting with a first use: \OtherDuBois. Subsequent uses of  \cmd{\OtherDuBois} print \OtherDuBois. Of course, one could get more complex than the example above. The index will only hold the standard entry for \Name*[W.E.B.]{Du Bois}: ``Du Bois, W.E.B.'' and a cross-reference from the variant ``DuBois, W.E.B.'' to the standard entry.
+% \clearpage
+%
+% \subsubsection{\texttt{\textbackslash LocalNames}}
+% \label{sec:LocalNames}
+%
+% As mentioned previously in Section~\ref{sec:Tweaks}, both \cmd{\ForgetName} and \cmd{\SubvertName} usually affect both main-matter and front-matter names. This default behavior can be quite helpful. Nevertheless, there are cases where it is undesirable. This section shows \cmd{\Localnames} and \cmd{\Globalnames} in action, limiting the behavior of the ``tweaking macros'' to either the main or front matter.
+%
+% We begin by defining a macro that will report to us whether a name exists in the main matter, front matter, both, or none:
+% \def\CheckChuck{\IfFrontName[Charlie]{Chaplin}%
+%   {\IfMainName[Charlie]{Chaplin}{both}{front}}%
+%   {\IfMainName[Charlie]{Chaplin}{main}{none}}}%
+% \begin{quote}\small\setstretch{1.1}
+% |\def\CheckChuck{%\IfFrontName[Charlie]{Chaplin}%|\\
+% |  {\IfMainName[Charlie]{Chaplin}{both}{front}}%|\\
+% |  {\IfMainName[Charlie]{Chaplin}{main}{none}}}%|
+% \end{quote}
+% Next we create a formatted name in the ``main matter'':
+% \begin{quote}\small\setstretch{1.1}
+% |\Name*[Charlie]{Chaplin}|\hfill\Name*[Charlie]{Chaplin}\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+% Now we switch to ``front-matter'' text and create a name. We use \cmd{\global} with \cmd{\NamesInactive} in order to ignore any local scoping environments:
+% \begin{quote}\small\setstretch{1.1}
+% |\global\NamesInactive|\global\NamesInactive\\
+% |\Name*[Charlie]{Chaplin}|\hfill\Name*[Charlie]{Chaplin}\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+% We now have two names. They look and behave the same, but are two different ``species'' with independent first and subsequent uses. We use \cmd{\Localnames} to make \cmd{\ForgetName} and \cmd{\SubvertName} work with only the front-matter species. Then we ``forget'' the front-matter name:
+% \begin{quote}\small\setstretch{1.1}
+% |\LocalNames|\LocalNames\\
+% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+% Next we ``subvert'' the front-matter name to ``remember'' it again and switch to the main section, again using \cmd{\global} to ignore scoping. Now \cmd{\ForgetName} and \cmd{\SubvertName} are working with the main-matter species.
+% \begin{quote}\small\setstretch{1.1}
+% |\SubvertName[Charlie]{Chaplin}|\SubvertName[Charlie]{Chaplin}\\
+% |\global\NamesActive|\global\NamesActive\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+%  We forget the main-matter name and additionally reset the default behavior so that \cmd{\ForgetName} and \cmd{\SubvertName} work with both species:
+% \begin{quote}\small\setstretch{1.1}
+% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
+% |\GlobalNames|\GlobalNames\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+% Finally, we forget everything. Even though we are in a main-matter section, the front-matter control sequence goes away:
+% \begin{quote}\small\setstretch{1.1}
+% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
+% |\CheckChuck|\hfill\CheckChuck
+% \end{quote}
+% \clearpage
+%
 % \subsubsection{Tips for \texttt{\textbackslash AKA}}
 % \label{sec:AKAtips}
 %
 % \begin{itemize}\small
 % \item \oarg{FNN}\marg{SNN} is the main name. \oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names} is the cross-reference. Forgetting this may cause errors.
-% \item The old syntax causes \cmd{\AKA} and \cmd{\AKA*} to fail: |\AKA{Louis}[XIV]{Sun King}| and |\AKA{Gregory}[I]{Gregory}[the Great]|.
+% \item The old syntax causes \cmd{\AKA} and \cmd{\AKA*} to fail:|\AKA{Louis}[XIV]{Sun| |King}| and |\AKA{Gregory}[I]{Gregory}[the| |Great]|.
 % \item The \meta{Alt. SNN} field uses comma-delimited suffixes.
 % \item The \meta{Alt. names} field does not use comma-delimited suffixes.
 % \item Eastern names work as pseudonyms, with all that entails. One can refer to \Name[Lafcadio]{Hearn} as \CapName\AKA[Lafcadio]{Hearn}{Koizumi, Yakumo}:\\\hbox{}\qquad|\CapName\AKA[Lafcadio]{Hearn}{Koizumi, Yakumo}|.
 % \item Particles work: \CapThis\AKA[Charles]{du Fresne}{du Cange} is the alternate name for \Name[Charles]{du Fresne}, which is capitalized via \cmd{\CapThis}\cmd{\AKA}. See also Section~\ref{sec:Particles}.
-% \item Reversing works, \emph{e.g.},\\\hbox{}\qquad \cmd{\RevComma}: \RevComma\AKA[Bob]{Hope}[Leslie Townes]{Hope}\\\hbox{}\qquad \cmd{\RevName}: \RevName\CapName\AKA[Lafcadio]{Hearn}{Koizumi, Yakumo}
-% \item The name fields of \cmd{\PretagName} correspond with the \oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names} fields of \cmd{\AKA}:\\[1ex]\hbox{}\qquad |\AKA{Vlad| |III,| |Dracula}{Vlad,| |Ţepeş}| matches\\\hbox{}\qquad |\PretagName{Vlad,| |Ţepeş}{Vlad| |Tepes}|\\[1ex] This form does not match: |\PretagName{Vlad}[Ţepeş]{Vlad| |Tepes}|.
-% \item With stage names like \Name[The Amazing]{Kreskin}, if you want them in the index, use |\Name[The Amazing]{Kreskin}| to get ``Kreskin, The Amazing.'' \IndexInactive Otherwise use something like |\Name[J.]{Kreskin}[The Amazing]| to get \Name[J.]{Kreskin}[The Amazing] in the text and ``Kreskin, J.'' in the index.\\[1ex] Using \cmd{\AKA} with such names looks like: |\AKA[The Amazing]{Kreskin}| |[Joseph]{Kresge}| and |\AKA[J.]{Kreskin}[Joseph]{Kresge}|.\IndexActive You get \Name*[The Amazing]{Kreskin}, a.k.a. \AKA[The Amazing]{Kreskin}[Joseph]{Kresge}.
-% \item Special cases like ``Iron Mike'' Tyson as the nickname for \Name[Mike]{Tyson} may be handled in a number of ways.
-% \begin{enumerate}\small
+% \item Reversing works, \emph{e.g.},\\\hbox{}\qquad \cmd{\RevComma}\cmd{\AKA\dots}: \RevComma\AKA[Bob]{Hope}[Leslie Townes]{Hope}\\\hbox{}\qquad \cmd{\RevName}\cmd{\AKA\dots\ }: \RevName\CapName\AKA[Lafcadio]{Hearn}{Koizumi, Yakumo}
+% \item The\marginpar{\small\raggedleft\dbend} name fields of \cmd{\PretagName} correspond with the \oarg{Alt. FNN}\marg{Alt. SNN}\oarg{Alt. names} fields of \cmd{\AKA}:\\[1ex]\hbox{}\qquad |\AKA{Vlad| |III,| |Dracula}{Vlad,| |Ţepeş}| matches\\\hbox{}\qquad |\PretagName{Vlad,| |Ţepeş}{Vlad| |Tepes}|\\[1ex]
+% This form does not match: |\PretagName{Vlad}[Ţepeş]{Vlad| |Tepes}|.
+% \item With\marginpar{\small\raggedleft\dbend} stage names like \Name[The Amazing]{Kreskin}, if you want them in the index, use |\Name[The| |Amazing]{Kreskin}| to get ``Kreskin, The Amazing.'' \IndexInactive Otherwise use something like |\Name[J.]{Kreskin}[The| |Amazing]| to get \Name[J.]{Kreskin}[The Amazing] in the text and ``Kreskin, J.'' in the index.\\[1ex] Using \cmd{\AKA} with such names looks like: |\AKA[The| |Amazing]{Kreskin}| |[Joseph]{Kresge}| and |\AKA[J.]{Kreskin}[Joseph]{Kresge}|.\IndexActive The results are \Name*[The Amazing]{Kreskin}, a.k.a. \AKA[The Amazing]{Kreskin}[Joseph]{Kresge}.
+% \item Special\marginpar{\small\raggedleft\dbend} cases like ``Iron Mike'' Tyson as the nickname for \Name[Mike]{Tyson} may be handled in a number of ways.
+% \begin{itemize}\small
 % \item Follow |``Iron Mike''| with |\IndexName[Mike]{Tyson}| and do whatever you want in the text. This may be the easiest solution.
 % \item Use |``\AKA[Mike]{Tyson}{Iron Mike}''| to create ``\AKA[Mike]{Tyson}{Iron Mike}'' in the text and a \emph{see}-type cross-reference to ``Tyson, Mike'' in the index. Be sure to have an occurrence of |\Name[Mike]{Tyson}| in the text. See also Section~\ref{sec:AKA}. This is the best solution in terms of how \textsf{nameauth} is designed.
 % \item Always get ``Iron Mike Tyson'' with something like:\\[1ex]
-% |\newcommand*{\Iron}{\SubvertName[Mike]{Tyson}%|\\
+% |\newcommand*\Iron{\SubvertName[Mike]{Tyson}%|\\
 % |\FName[Mike]{Tyson}[Iron Mike] \Name[Mike]{Tyson}}|\\[1ex]
-% \newcommand*{\Iron}{\SubvertName[Mike]{Tyson}\FName[Mike]{Tyson}[Iron Mike] \Name[Mike]{Tyson}}
+% \newcommand*\Iron{\SubvertName[Mike]{Tyson}\FName[Mike]{Tyson}[Iron Mike] \Name[Mike]{Tyson}}
 % |``\Iron''| gives you ``\Iron.''\footnote{In typesetting this manual I defined the macro \cmd{\Iron} and others like it on one continuous line because defining a macro over multiple lines with comment characters ending them in \textsf{ltxdoc} and a \texttt{.dtx} file caused extra spaces to be inserted.} You are responsible for typesetting the first use and creating a cross-reference. This solution runs somewhat contrary to the design principles of \textsf{nameauth}, but it may be helpful if you want the invariant name ``\Iron'' to recur and you want to save typing.
-% \end{enumerate}
 % \end{itemize}
+% \end{itemize}
 %
 % \subsubsection{Unicode and NFSS}
 % \label{sec:Unicode}
@@ -2160,7 +2337,7 @@
 %
 % The following subset of extended Latin Unicode characters are available ``out of the box'' using NFSS, \textsf{inputenc}, and \textsf{fontenc}:
 %
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \begin{tabular}{llll}\toprule
 % \scshape À Á Â Ã Ä Å Æ & \scshape Ç È É Ê Ë & \scshape Ì Í Î Ï Ð Ñ & \scshape small caps \\
 % À Á Â Ã Ä Å Æ & Ç È É Ê Ë & Ì Í Î Ï Ð Ñ & normal \\[1ex]
@@ -2177,10 +2354,10 @@
 % \scshape Ś Ş ş Š š Ţ ţ Ť ť & \scshape Ů ů Ű ű & \scshape Ź ź Ż ż Ž ž & \scshape small caps \\
 % Ś Ş ş Š š Ţ ţ Ť ť & Ů ů Ű ű & Ź ź Ż ż Ž ž &  normal \\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
-% Additional accents and glyphs can be used with Unicode input, NFSS, \textsf{inputenc}, and \textsf{fontenc} when using fonts with TS1 glyphs, \emph{e.g.}, |\usepackage{lmodern}| (per the table on pages 455--63 in \emph{The Latex Companion}). The following example lets you type, ``In Congreſs, July 4, 1776.''
-% \begin{quote}
+% Some\marginpar{\small\raggedleft\dbend} of these characters expand differently, which can affect index sorting. For example, \texttt{ä} becomes \texttt{\cmd{\IeC\textvisiblespace}\{\cmd{\"a}\}} and \texttt{Æ} becomes \texttt{\cmd{\IeC\textvisiblespace}\{\cmd{\AE\textvisiblespace}\}.} Additional accents and glyphs can be used with Unicode input, NFSS, \textsf{inputenc}, and \textsf{fontenc} when using fonts with TS1 glyphs, \emph{e.g.}, |\usepackage{lmodern}| (per the table on pages 455--63 in \emph{The Latex Companion}). The following example lets you type, ``In Congreſs, July 4, 1776.''
+% \begin{quote}\small\setstretch{1.1}
 % |\usepackage{newunicodechar}|\\
 % |\DeclareTextSymbolDefault{\textlongs}{TS1}|\\
 % |\DeclareTextSymbol{\textlongs}{TS1}{115}|\\
@@ -2187,12 +2364,10 @@
 % |\newunicodechar{ſ}{\textlongs}|
 % \end{quote}
 %
-% Although |\newunicodechar{ā}{\=a}| allows |\Name{Ghazāli}| to generate \IndexInactive\Name{Ghaz\=ali}\IndexActive, one must be careful with control sequences like |\=a| fail when using \texttt{makeindex} and \texttt{gind.ist}. For example, the \textsf{ltxdoc} class, with \texttt{gind.ist}, turns the default ``actual'' character |@| into |=|. Using |\index{Gh{\=a}zali}| halts execution. Using |\index{Gh\=azali}| gives an ``azali'' entry sorted under ``Gh'' (thanks \Name[Dan]{Luecking}). This issue is not specific to \textsf{nameauth}.
+% Although\marginpar{\small\raggedleft\dbend} |\newunicodechar{ā}{\=a}| allows |\Name{Ghazāli}| to generate \IndexInactive\Name{Ghaz\=ali}\IndexActive, one must be careful with control sequences like |\=a| fail when using \texttt{makeindex} and \texttt{gind.ist}. For example, the \textsf{ltxdoc} class, with \texttt{gind.ist}, turns the default ``actual'' character |@| into |=|. Using |\index{Gh{\=a}zali}| halts execution. Using |\index{Gh\=azali}| gives an ``azali'' entry sorted under ``Gh'' (thanks \Name[Dan]{Luecking}). This issue is not specific to \textsf{nameauth}.
 %
-% Such issues with \texttt{gind.ist} are not the only concerns one must have about NFSS, \textsf{inputenc}, and \textsf{fontenc} when using Unicode. Although the manner in which glyphs are handled is quite powerful, it also is fragile. Any \TeX\ macro that partitions its argument without using delimiters can break Unicode under NFSS.
-%
-% Consider the following examples with |\def\foo#1#2#3\relax{<#1#2><#3>}|:
-% \begin{quote}\setstretch{1.2}
+% Such\marginpar{\small\raggedleft\dbend} issues with \texttt{gind.ist} are not the only concerns one must have about NFSS, \textsf{inputenc}, and \textsf{fontenc} when using Unicode. Although the manner in which glyphs are handled is quite powerful, it also is fragile. Any \TeX\ macro that partitions its argument without using delimiters can break Unicode under NFSS. Consider the following examples with |\def\foo#1#2#3\relax{<#1#2><#3>}|:
+% \begin{center}\setstretch{1.1}
 % \def\foo#1#2#3\relax{<#1#2><#3>}
 % \begin{tabular}{lll}\toprule
 % Argument & Macro & Result\\\midrule
@@ -2200,10 +2375,10 @@
 % |{æ}bc| & |\foo {æ}bc\relax| & \foo {æ}bc\relax\\
 % \cmd{\ae bc} & |\foo \ae bc\relax| & \foo \ae bc\relax\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
 % The arguments in the last example always put |c| in |#3|, with the first two glyphs in |#1#2.| Now here is where things get tricky:
-% \begin{quote}\setstretch{1.2}
+% \begin{center}\setstretch{1.1}
 % \begin{tabular}{llll}\toprule
 % Argument & Macro & Engine & Result\\\midrule
 % |æbc| & |\foo æbc\relax| & \texttt{xelatex} & <æb><c>\\
@@ -2210,16 +2385,16 @@
 % |æbc| & |\foo æbc\relax| & \texttt{lualatex} & <æb><c>\\
 % |æbc| & |\foo æbc\relax| & \texttt{pdflatex} & <æ><bc>\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
-% In both \texttt{xelatex} and \texttt{lualatex} you get the same results as the previous table, where |c| is in |#3| and the first two glyphs are in |#1#2.| However, using \texttt{pdflatex} with \textsf{inputenc} and \textsf{fontenc} causes |æ| by itself to use |#1#2|.
+% In both \texttt{xelatex} and \texttt{lualatex} you get the same results as the previous table, where |c| is in |#3| and the first two glyphs are in |#1#2.| However, using \texttt{latex} or \texttt{pdflatex} with \textsf{inputenc} and \textsf{fontenc} causes |æ| by itself to use |#1#2|.
 %
 % Without digging into the details of font encoding and NFSS, we can say in simple terms that |æ| is ``two arguments wide.'' Any macro where this |#1#2| pair gets split into |#1| and |#2| will produce either the error \texttt{Unicode char \dots not set up for LaTeX} or the error \texttt{Argument of \textbackslash UTFviii at two@ octets has an extra \}.} This is not just specific to \textsf{nameauth}.
 %
 % Using \cmd{\CapThis} can trigger this kind of error when the \emph{first} character of the \meta{SNN} field is an extended-Latin or similarly accented or extended Unicode character. Using \cmd{\AccentCapThis} can trigger this kind of error when the \emph{second} character of the \meta{SNN} field is a similarly accented or extended character.
 %
-% \LaTeX\ also removes spaces in a manner that one should remember:
-% \begin{quote}\setstretch{1.2}
+% \LaTeX\marginpar{\small\raggedleft\dbend} also removes spaces between macro arguments in a manner that one should remember:
+% \begin{center}\setstretch{1.1}
 % \def\foo#1#2#3\relax{<#1#2><#3>}
 % \begin{tabular}{lll}\toprule
 % Argument & Macro & Result\\\midrule
@@ -2228,11 +2403,11 @@
 % |a bc| & |\foo a bc\relax| & \foo a bc\relax\\
 % |abc| & |\foo abc\relax| & \foo abc\relax\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 % Notice that if a space exists between the first two arguments,the space gets gobbled between the first two arguments, but retained in the third. This pertains to the way that \LaTeX\ allows for spaces after control sequences and tries to fetch the undelimited |#1#2.| Since |#3| terminates the argument list, it gets ``everything else.'' Nor would using \cmd{\obeyspaces} and \cmd{\ignorespaces} always get the desired result without a certain degree of complexity.
 %
 % Here is why using explicit spacing macros with one-character particles when using \cmd{\CapThis} and \cmd{\AccentCapThis} helps fix the issue of gobbled spaces, and why non-breaking spaces are preferred:\footnote{Given that you would not want a bad break between a particle and a name.}
-% \begin{quote}\small\setstretch{1.2}
+% \begin{center}\small\setstretch{1.1}
 % \def\foo#1#2#3\relax{<#1#2><#3>}
 % \begin{tabular}{lll}\toprule
 % Argument & Macro & Result\\\midrule
@@ -2240,28 +2415,28 @@
 % |a\nobreakspace bc| & |\foo a\nobreakspace bc\relax| & \foo a\nobreakspace bc\relax\\
 % |a\space bc| & |\foo a\space bc\relax| & \foo a\space bc\relax\\\bottomrule
 % \end{tabular}
-% \end{quote}
+% \end{center}
 %
-% Sections~\ref{sec:standards} and~\ref{sec:accents} have information related to these topics and the \textsf{nameauth} package.
+% See also Sections~\ref{sec:standards} and~\ref{sec:accents}.
 % \clearpage
 %
 % \subsubsection{\LaTeX\ Engines}
 % \label{sec:engines}
 %
-% The \textsf{nameauth} package tries to work with multiple languages and typesetting engines. The following preamble snippet from this manual illustrates how that can be done:
-% \begin{quote}
+% The\marginpar{\small\raggedleft\dbend} \textsf{nameauth} package tries to work with multiple languages and typesetting engines. The following preamble snippet from this manual illustrates how that can be done:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
+% \begin{quote}\small\setstretch{1.1}
 % |\usepackage{ifxetex}|\\
 % |\usepackage{ifluatex}|\\
-% |\ifxetex|\hfill |% uses fontspec|\\
+% |\ifxetex%|\hfill |uses fontspec|\\
 % \hbox{\quad}|\usepackage{fontspec}|\\
 % \hbox{\quad}|\defaultfontfeatures{Mapping=tex-text}|\\
 % \hbox{\quad}|\usepackage{xunicode}|\\
 % \hbox{\quad}|\usepackage{xltxtra}|\\
 % |\else|\\
-% \hbox{\quad}|\ifluatex|\hfill |% also uses fontspec|\\
+% \hbox{\quad}|\ifluatex%|\hfill | also uses fontspec|\\
 % \hbox{\quad}\hbox{\quad}|\usepackage{fontspec}|\\
 % \hbox{\quad}\hbox{\quad}|\defaultfontfeatures{Ligatures=TeX}|\\
-% \hbox{\quad}|\else|\hfill |% traditional NFSS|\\
+% \hbox{\quad}|\else%|\hfill | traditional NFSS|\\
 % \hbox{\qquad}|\usepackage[utf8]{inputenc}|\\
 % \hbox{\qquad}|\usepackage[TS1,T1]{fontenc}|\\
 % \hbox{\quad}|\fi|\\
@@ -2268,11 +2443,11 @@
 % |\fi|
 % \end{quote}
 %
-% This arrangement worked best for this manual, which has been tested with all three engines. This example is not meant to be the only possible way to check which engine you are using and how to set things up.
+% This arrangement worked best for this manual, which is tested with all of the \LaTeX\ engines above. This example is not meant to be the only possible way to check which engine you are using and how to set things up.
 %
 % The following can be used in the text itself to allow for conditional processing that helps one to document work under multiple engines:
 %
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % |\ifxetex| \meta{xelatex text}|%|\\
 % |\else|\\
 % \hbox{\quad}|\ifluatex|\\
@@ -2288,61 +2463,11 @@
 % \end{quote}
 % \clearpage
 %
-% \subsubsection{\texttt{\textbackslash LocalNames}}
-% \label{sec:LocalNames}
-%
-% As mentioned previously in Section~\ref{sec:Tweaks}, both \cmd{\ForgetName} and \cmd{\SubvertName} usually affect both main-matter and front-matter names. This default behavior can be quite helpful. Nevertheless, there are cases where it is undesirable. This section shows \cmd{\Localnames} and \cmd{\Globalnames} in action, limiting the behavior of the ``tweaking macros'' to either the main or front matter.
-%
-% We begin by defining a macro that will report to us whether a name exists in the main matter, front matter, both, or none:
-% \def\CheckChuck{\IfFrontName[Charlie]{Chaplin}%
-%   {\IfMainName[Charlie]{Chaplin}{both}{front}}%
-%   {\IfMainName[Charlie]{Chaplin}{main}{none}}}%
-% \begin{quote}
-% |\def\CheckChuck{%\IfFrontName[Charlie]{Chaplin}%|\\
-% |  {\IfMainName[Charlie]{Chaplin}{both}{front}}%|\\
-% |  {\IfMainName[Charlie]{Chaplin}{main}{none}}}%|
-% \end{quote}
-% Next we create a formatted name in the main matter:
-% \begin{quote}
-% |\Name*[Charlie]{Chaplin}|\hfill\Name*[Charlie]{Chaplin}\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% Now we switch to an unformatted section and create a name there. Observe that \cmd{\global} precedes \cmd{\NamesInactive} because we want those effects to persist beyond the immediate scope of the \texttt{quote} environment:
-% \begin{quote}
-% |\global\NamesInactive|\global\NamesInactive\\
-% |\Name*[Charlie]{Chaplin}|\hfill\Name*[Charlie]{Chaplin}\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% Now we are in a ``front matter section.'' We now have two names. They look and behave the same, but are two different ``species'' with independent first and subsequent uses. We use \cmd{\Localnames} to make \cmd{\ForgetName} and \cmd{\SubvertName} local in scope. We then forget the name in the unformatted section:
-% \begin{quote}
-% |\LocalNames|\LocalNames\\
-% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% Since the ``front-matter name'' was removed, only a ``main-matter name'' exists. We now ``subvert'' the front-matter name to bring its ``existence'' back again and switch to the main section. See that \cmd{\global} precedes \cmd{\NamesActive} because we used \cmd{\global} previously and want a similar effect:
-% \begin{quote}
-% |\SubvertName[Charlie]{Chaplin}|\SubvertName[Charlie]{Chaplin}\\
-% |\global\NamesActive|\global\NamesActive\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% Now both names exist again, but \cmd{\ForgetName} and \cmd{\SubvertName} are still local in scope. We forget the main-matter name and additionally reset the default behavior so that \cmd{\ForgetName} and \cmd{\SubvertName} will be global:
-% \begin{quote}
-% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
-% |\GlobalNames|\GlobalNames\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% Finally, we forget everything. Even though we are in a main-matter section, the front-matter control sequence goes away:
-% \begin{quote}
-% |\ForgetName[Charlie]{Chaplin}|\ForgetName[Charlie]{Chaplin}\\
-% |\CheckChuck|\hfill\CheckChuck
-% \end{quote}
-% \clearpage
-%
 % \subsubsection{Hooks: Intro}
 % \label{sec:Hooksa}
 %
-% Before\marginpar{\small\raggedleft Margin\break Paragraphs} we get to the use of text tags and name conditionals in name formatting, we begin with an intermediate example to illustrate that something more complex can occur in \cmd{\NamesFormat}. Here we put the first mention of a name in boldface, along with a marginal notation if possible:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
-% \begin{quote}
+% Before\marginpar{\small\raggedleft Margin\break Paragraphs} we get to the use of text tags and name conditionals in name formatting, we begin with an intermediate example to illustrate that something more complex can occur in \cmd{\NamesFormat}.\marginpar{\small\raggedleft\dbend} Here we put the first mention of a name in boldface, along with a marginal notation if possible:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
+% \begin{quote}\small\setstretch{1.1}
 % |\let\OldFormat\NamesFormat%|\\
 % |\renewcommand*\NamesFormat[1]%|\\
 % |  {\textbf{#1}\ifinner\else|\\
@@ -2351,7 +2476,7 @@
 % |\let\NamesFormat\OldFormat%|
 % \end{quote}
 % Changes to \cmd{\NamesFormat} should not rely merely on scoping rules to keep them ``local'' but should be changed and reset explicitly, or else odd side effects can result, especially with more exotic changes to \cmd{\NamesFormat}. We now use the example above in a sample text:
-% \begin{quote}
+% \begin{quote}\small\setstretch{1.1}
 % \let\OldFormat\NamesFormat\ignorespaces%
 % \renewcommand*\NamesFormat[1]%
 %   {\textbf{#1}\ifinner\else
@@ -2362,11 +2487,11 @@
 % \let\NamesFormat\OldFormat%
 % \end{quote}
 %
-% Now again we have reverted to the original form of \cmd{\NamesFormat} and we get \ForgetName{Vlad III, Dracula}\Name{Vlad III, Dracula} and \Name{Vlad III, Dracula}. For references to ``Vlad'' instead of ``\Name{Vlad III, Dracula}'' one could use |\Name{Vlad, III Dracula}|. Do not mix these forms with each other or with the old syntax, lest errors bite! You would get multiple index entries, unwanted cross-references, and unexpected forms in the text. The simplified interface greatly helps one to avoid this.
+% Now again we have reverted to the original form of \cmd{\NamesFormat} and we get \ForgetName{Vlad III, Dracula}\Name{Vlad III, Dracula} and \Name{Vlad III, Dracula}. For references to ``Vlad'' instead of ``\Name{Vlad III, Dracula}'' one could use |\Name{Vlad, III Dracula}|. Do not mix these forms with each other and avoid the old syntax, lest errors bite! The simplified interface greatly helps one to avoid this.
 %
 % \let\OldMainHook\MainNameHook%
-% You cannot re-enter \cmd{\Name} or \cmd{\AKA} by calling them from within \cmd{\Namesformat,} \cmd{\FrontNameHook,} or \cmd{\MainNameHook,} as the next example shows:
-% \begin{quote}\small
+% You\marginpar{\small\raggedleft\dbend} cannot re-enter \cmd{\Name} or \cmd{\AKA} by calling them within \cmd{\Namesformat,} \cmd{\FrontNameHook,} or \cmd{\MainNameHook,} as the next example shows:
+% \begin{quote}\small\setstretch{1.1}
 % |\renewcommand*\MainNameHook[1]%|\\
 % |{%|\\
 % |  {#1}%|\\
@@ -2377,11 +2502,12 @@
 % \end{quote}
 % \renewcommand*\MainNameHook[1]{{#1}\IndexInactive\Name{foo}\AKA{bar}{baz}\IndexActive}%
 % Calling, \emph{e.g.}, |\Wash| produces \Wash, without foo, bar, or baz. \cmd{\Name} and \cmd{\AKA} expand to nothing. Version 2.4 of \textsf{nameauth} prevents stack-overflows both in this case and if you called the naming macros as their own arguments. |\Name{foo\Name{bar}}| would produce ``\textsc{foo}'' in the text and ``foo\textsc{bar}'' in the index. As you see, these cases are to be avoided.
-% \let\MainNameHook\OldMainHook%
+% \let\MainNameHook\OldMainHook
+% \clearpage
 %
 % \subsubsection{Hooks: Life Dates}
 % \label{sec:Hooksb}
-% We can use name conditionals (Section~\ref{sec:tests}) and text tags (Section~\ref{sec:tagtext}) to add life information to names when desired.
+% We\marginpar{\small\raggedleft\dbend} can use name conditionals (Section~\ref{sec:tests}) and text tags (Section~\ref{sec:tagtext}) to add life information to names when desired.
 %
 % \DescribeMacro{\if at nameauth@InName}
 % \DescribeMacro{\if at nameauth@InAKA}
@@ -2390,10 +2516,10 @@
 % \DescribeMacro{\@nameauth at toksa}
 % \DescribeMacro{\@nameauth at toksb}
 % \DescribeMacro{\@nameauth at toksc}
-% This package makes three token registers available to facilitate using the name conditional macros as we do below. Using these registers allows accented names to be recognized properly. In \cmd{\AKA} the token registers are copies of the \emph{last} three arguments, corresponding to the pseudonym. Nevertheless, they have the same names as the registers in \cmd{\@nameauth at Name} because they work the same way and may be easier to use this way.
+% This package makes three token registers available to facilitate using the name conditional macros as we do below. Using these registers allows accented names to be recognized properly. In \cmd{\AKA} the token registers are copies of the \emph{last} three arguments, corresponding to the pseudonym.\marginpar{\small\raggedleft\dbend} Nevertheless, they have the same names as the registers in \cmd{\@nameauth at Name} because they work the same way and may be easier to use this way.
 %
 % We assume that we will not be using the \texttt{alwaysformat} option, meaning that we only call this hook once for a first use:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
-% \begin{quote}\small
+% \begin{quote}\small\setstretch{1.1}
 % |\newif\ifNoTextTag%|\hfill|allows us to work around \ForgetName|\\
 % |\let\OldFormat\NamesFormat%|\hfill|save the format|\\
 % |\makeatletter%|\hfill|access internals|\\
@@ -2426,18 +2552,19 @@
 % \end{quote}
 %
 % The example above prints tags by default in the false path of \cmd{\NoTextTag}, while suppressing them in the true path.
+% \clearpage
 %
-% Before we can refer to any text tags, we must create them. Please pardon the fact that I am going to ``avoid the truth'' about the tag used for ``Atatürk'' below in order to illustrate certain points regarding \cmd{\AKA.} I will tell the truth later when this group of examples is complete:
-% \begin{quote}\small
+% Before\marginpar{\small\raggedleft\dbend} we can refer to any text tags, we must create them. For teaching purposes I will ``lie'' (sorry) about the tag used for ``Atatürk'' until later.
+% \begin{quote}\small\setstretch{1.1}
 % |\NameAddInfo[George]{Washington}{ (1732--99)}%|\\
 % |\NameAddInfo[Mustafa]{Kemal}{ (1881--1938)}%|\\
-% |\NameAddInfo{Atatürk}{ (a special surname granted 1934)}%|
+% |\NameAddInfo{Atatürk}{ (in 1934, a special surname)}%|
 % \end{quote}
 % \NameAddInfo[George]{Washington}{ (1732--99)}%
 % \NameAddInfo[Mustafa]{Kemal}{ (1881--1938)}%
-% \NameAddInfo{Atatürk}{ (a special surname granted 1934)}%
-% \NameAddInfo{\kern0pt Atatürk}{ (a special surname granted 1934)}%
-% \NameAddInfo{Atatürk\kern0pt}{ (a special surname granted 1934)}%
+% \NameAddInfo{Atatürk}{ (in 1934, a special surname)}%
+% \NameAddInfo{\kern0pt Atatürk}{ (in 1934, a special surname)}%
+% \NameAddInfo{Atatürk\kern0pt}{ (in 1934, a special surname)}%
 % We begin using the modified \cmd{\NamesFormat} under normal conditions:
 % \newif\ifNoTextTag%
 % \let\OldFormat\NamesFormat%
@@ -2444,54 +2571,61 @@
 % \let\OldFrontFormat\FrontNamesFormat%
 % \makeatletter\renewcommand*\NamesFormat[1]{\let\ex\expandafter\textbf{#1}\if at nameauth@InName\ifNoTextTag\else\ex\ex\ex\ex\ex\ex\ex\NameQueryInfo\ex\ex\ex\ex\ex\ex\ex[\ex\ex\ex\the\ex\ex\ex\@nameauth at toksa\ex\ex\ex]\ex\ex\ex{\ex\the\ex\@nameauth at toksb\ex}\ex[\the\@nameauth at toksc]\fi\fi\if at nameauth@InAKA\ifNoTextTag\else\ex\ex\ex\ex\ex\ex\ex\NameQueryInfo\ex\ex\ex\ex\ex\ex\ex[\ex\ex\ex\the\ex\ex\ex\@nameauth at toksa\ex\ex\ex]\ex\ex\ex{\ex\the\ex\@nameauth at toksb\ex}\ex[\the\@nameauth at toksc]\fi\fi\global\NoTextTagfalse}\makeatother
 % \ForgetName[George]{Washington}%
-% \begin{quote}\small
-% |\Wash| |held| |office| |1789--97.| |No| |tags| |appear| |in| |later| |uses| |of| |\Wash.| |We| |now| |suppress| |the| |dates| |and| |trigger| |a| |new| |first| |use:|\\
+% \begin{quote}\small\setstretch{1.1}
+% |\Wash| |held| |office| |1789--97.| |No| |tags| |appear| |with| |\Wash. %|\\
+% |First| |use,| |dates| |suppressed:%|\\
 % |\NoTextTagtrue\ForgetName[George]{Washington}\Wash.|
 %
-% |\Name[Mustafa]{Kemal}| |was| |later| |given| |the| |name%|\\ |\AKA[Mustafa]{Kemal}{Atatürk}. We mention|\\
+% |\Name[Mustafa]{Kemal}| |was| |granted| |the| |name%|\\
+% |\AKA[Mustafa]{Kemal}{Atatürk}. We mention%|\\
 % |\AKA[Mustafa]{Kemal}{Atatürk} again.|
 %
-% \Wash\ held office 1789--97. No tags appear in later uses of \Wash. We now suppress the dates and trigger a new first use: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
+% \Wash\ held office 1789--97. No tags appear with \Wash. First use, dates suppressed: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
 %
-% \Name[Mustafa]{Kemal} was later given the name \IndexInactive\AKA[Mustafa]{Kemal}{\kern0pt Atatürk}. We mention \AKA[Mustafa]{Kemal}{\kern0pt Atatürk} again\IndexActive.
+% \Name[Mustafa]{Kemal} was granted the name \IndexInactive\AKA[Mustafa]{Kemal}{\kern0pt Atatürk}. We mention \AKA[Mustafa]{Kemal}{\kern0pt Atatürk} again\IndexActive.
 % \end{quote}
 %
-% Notice that the text tag for Atatürk did not print. That is because \cmd{\AKA} usually only calls the ``subsequent use'' hooks. Therefore we simulate the \texttt{formatAKA} option and \cmd{\ForgetName} \Wash\ and \Name[Mustafa]{Kemal}:
-% \begin{quote}\small
+% Notice\marginpar{\small\raggedleft\dbend} that the text tag for Atatürk did not print. That is because \cmd{\AKA} usually only calls the ``subsequent use'' hooks. Therefore we simulate the \texttt{formatAKA} option and \cmd{\ForgetName} \Wash\ and \Name[Mustafa]{Kemal}:
+% \begin{quote}\small\setstretch{1.1}
 % \makeatletter\@nameauth at AKAFormattrue\makeatother
 % \ForgetName[George]{Washington}%
 % \ForgetName[Mustafa]{Kemal}%
-% \Wash\ held office 1789--97. No tags appear in later uses of \Wash. We now suppress the dates and trigger a new first use: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
+% \Wash\ held office 1789--97. No tags appear with \Wash. First use, dates suppressed: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
 %
-% \Name[Mustafa]{Kemal} was later given the name \IndexInactive\AKA[Mustafa]{Kemal}{Atatürk\kern0pt}. We mention \AKA[Mustafa]{Kemal}{Atatürk\kern0pt} again\IndexActive.
+% \Name[Mustafa]{Kemal} was granted the name \IndexInactive\AKA[Mustafa]{Kemal}{Atatürk\kern0pt}. We mention \AKA[Mustafa]{Kemal}{Atatürk\kern0pt} again\IndexActive.
 % \end{quote}
-% Here we see that the tag is printed because \texttt{formatAKA} allows \cmd{\NamesFormat} to be called for the first use of Ataturk.
+% Here we see that the tag is printed because \texttt{formatAKA} allows \cmd{\NamesFormat} to be called for the first use of \AKA[Mustafa]{Kemal}{Atatürk\kern0pt}.
 %
-% Now we \cmd{\let} the first-use macro in the front matter be the same as that in the main matter and see what we get in the front matter via \cmd{\NamesInactive.} Again we simulate the \texttt{formatAKA} option and \cmd{\ForgetName} \Wash\ and \Name[Mustafa]{Kemal}:
-% \begin{quote}\small
+% Now\marginpar{\small\raggedleft\dbend} we \cmd{\let} the first-use macro in the front matter be the same as that in the main matter and see what we get in the front matter via \cmd{\NamesInactive.} Again we simulate the \texttt{formatAKA} option and \cmd{\ForgetName} \Wash\ and \Name[Mustafa]{Kemal}:
+% \begin{quote}\small\setstretch{1.1}
 % \makeatletter\@nameauth at AKAFormattrue\makeatother\NamesInactive|\NamesInactive|\\
 % |\let\OldFrontFormat\FrontNamesFormat|\\
-% \let\FrontNamesFormat\NamesFormat|\let\FrontNamesFormat\NamesFormat|\\
+% \let\FrontNamesFormat\NamesFormat|\let\FrontNamesFormat\NamesFormat|
+%
 % \ForgetName[George]{Washington}%
 % \ForgetName[Mustafa]{Kemal}%
-% \Wash\ held office 1789--97. No tags appear in later uses of \Wash. We now suppress the dates and trigger a new first use: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
+% \Wash\ held office 1789--97. No tags appear with \Wash. First use, dates suppressed: \NoTextTagtrue\ForgetName[George]{Washington}\Wash.
 %
-% \Name[Mustafa]{Kemal} was later given the name \AKA[Mustafa]{Kemal}{Atatürk}. We mention \AKA[Mustafa]{Kemal}{Atatürk} again.
+% \Name[Mustafa]{Kemal} was granted the name \AKA[Mustafa]{Kemal}{Atatürk}. We mention \AKA[Mustafa]{Kemal}{Atatürk} again.
 % \end{quote}
-% Again we see that everything is formatted the way we want, even in the front matter. Nevertheless, I have not been quite honest. Since I wanted to simulate multiple first uses of \cmd{\AKA,} which can print a tag only once unless you use the \texttt{alwaysformat} option, I inserted kerns into the instances of |\AKA[Mustafa]{Kemal}{Atatürk}| in the example paragraphs above:
-% \begin{quote}\footnotesize
+% 
+% I have not been quite honest above. Since I wanted to simulate multiple first uses of \cmd{\AKA,} which can print a tag only once unless you use the \texttt{alwaysformat} option, I inserted kerns into the instances of |\AKA[Mustafa]{Kemal}{Atatürk}| in the example paragraphs above:
+% \begin{quote}\footnotesize\setstretch{1.1}
 % |\NameAddInfo{\kern0pt| |Atatürk}{| |(a| |special| |surname| |granted| |1934)}|\\
 % |\NameAddInfo{Atatürk\kern0pt}{| |(a| |special| |surname| |granted| |1934)}|\\
-% |\NameAddInfo{Atatürk}{| |(a| |special| |surname| |granted| |1934)}|\\
+% |\NameAddInfo{Atatürk}{| |(a| |special| |surname| |granted| |1934)}|
 % \end{quote}
 % Because the names were different in each paragraph even though they looked the same, I prevented the names with kerns from appearing in the index via \cmd{\IndexInactive} and \cmd{\IndexActive.}\medskip
 %
-% Please remember to reset the formatting, if needed:\medskip
+% Please remember to reset the formatting, if needed:
+% \begin{quote}\small\setstretch{1.1}
+% |\let\NamesFormat\OldFormat|\\
+% |\let\FrontNamesFormat\OldFrontFormat|
+% \end{quote}
+% \let\NamesFormat\OldFormat
+% \let\FrontNamesFormat\OldFrontFormat
 %
-% \noindent\let\NamesFormat\OldFormat|\let\NamesFormat\OldFormat|\\
-% \let\FrontNamesFormat\OldFrontFormat|\let\FrontNamesFormat\OldFrontFormat|\medskip
-%
-% Here is a summary of what happens:
+% Here is a summary of the general behavior within the naming and hook macros and the kinds of decisions you might consider:
 % \begin{enumerate}
 % \item In \cmd{\@nameauth at name} and \cmd{\AKA}:
 % \begin{enumerate}
@@ -2511,31 +2645,39 @@
 % \item In \cmd{\@nameauth at name} and \cmd{\AKA}:
 % \begin{enumerate}
 %   \item Generate the control sequence that says the name exists.
-%   \item clean up and exit.
+%   \item Make a second index entry in case of page breaks, clean up and reset any Boolean flags, and exit.
 % \end{enumerate}
 % \end{enumerate}
 % \clearpage
 %
-% \subsubsection{Hooks: Continental}
+% \subsubsection{Hooks: Continental and Caps}
 % \label{sec:Hooksc}
 %
-% For implementing Continental systems of name formatting, in addition to the basic methods already discussed, here we see how one can have the small caps consistently in the surnames for the first uses and the index, yet have a normal font for subsequent references in the body text.
+% \begin{center}\bfseries Continental Format\end{center}
+% For\marginpar{\small\raggedleft\dbend} implementing Continental systems of name formatting, in addition to the basic methods already discussed, here we see how one can have the small caps consistently in the surnames for the first uses and the index, yet have a normal font for subsequent references in the body text.
 %
-% We begin by putting the following in the document preamble:
-% \begin{quote}\small
+% The big difference between this example and the optional caps is that here the font change is optional, while with the caps example, the font change is always present and the caps are optional. And yes, it is possible to do both an optional font change and optional caps.
+%
+% The literal text of this example goes in the document preamble. We add a Boolean value that turns small caps on or off, depending on the context. Please do not change this directly.
+%
+% \begin{quote}\small\setstretch{1.1}
 % |\newif\ifSC|\\
-% |\SCtrue%|\hfill |This turns on small caps by default|
+% |\SCtrue%|\hfill |We want small caps in the index|
+% \end{quote}
 %
+% \cmd{\DoFormat} is the key to this approach. We want a control sequence that will expand differently, depending on the state of the Boolean value above.
+%
+% \begin{quote}\small\setstretch{1.1}
 % \noindent|\def\DoFormat#1{%|\\
-% |  \ifSC|\\
-% |    \textsc{#1}%|\hfill |Format small caps if true|\\
-% |  \else|\\
-% |    #1%|\hfill |Do nothing if false|\\
-% |  \fi|\\
-% |}|
+% |  \ifSC \textsc{#1}%|\hfill |Format small caps if true|\\
+% |  \else #1%|\hfill |Do nothing if false|\\
+% |  \fi}|
+% \end{quote}
+% \def\DoFormat#1{\ifSC\textsc{#1}\else#1\fi}%
 %
-% \cmd{\DoFormat} is the key to this whole approach. We want a control sequence that will expand differently under different circumstances.
+% \cmd{\noexpand} is another vital piece of the solution. If one does not use this, all sorts of errors will arise. See how the formatting always is in the \meta{SNN} field.
 %
+% \begin{quote}\small\setstretch{1.1}
 % {\noindent\footnotesize|\begin{nameauth}|\\
 % |  \< JQA & John Quincy & \noexpand\DoFormat{Adams} & >|\\
 % |  \< Aeths & & \noexpand\DoFormat{Æþelstan} & >|\\
@@ -2542,49 +2684,63 @@
 % |  \< Chas & & \noexpand\DoFormat{Charles}, I & >|\\
 % |  \< Cao & & \noexpand\DoFormat{Cao}, Cao & >|\\
 % |  \< JRIII & John David & \noexpand\DoFormat{Rockefeller}, III & >|\\
-% |  \< SDJR & Sammy & \noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}. & >|\\
+% |  \< SDJR|\,|&|\,|Sammy|\,|&|\,|\noexpand\DoFormat{Davis},\noexpand\DoFormat{Jr}.|\,|& >|\\
 % |\end{nameauth}|}
+% \end{quote}
 %
-% \cmd{\noexpand} is another vital piece of the solution. If one does not use this, all sorts of errors will arise. We also must sort these names properly:
+% Now we must ensure that these names are sorted properly in the index. See again how the formatting must be present:
 %
-% {\noindent\footnotesize|\PretagName[John Quincy]{\noexpand\DoFormat{Adams}}{Adams, John Quincy}|\\
+% \begin{quote}\small\setstretch{1.1}
+% {\noindent\footnotesize|\PretagName[John Quincy]%|\\
+% |  {\noexpand\DoFormat{Adams}}{Adams, John Quincy}|\\
 % |\PretagName{\noexpand\DoFormat{Æþelstan}}{Aethelstan}|\\
 % |\PretagName{\noexpand\DoFormat{Charles}, I}{Charles 1}|\\
 % |\PretagName{\noexpand\DoFormat{Cao}, Cao}{Cao Cao}|\\
 % |\PretagName[John David]{\noexpand\DoFormat{Rockefeller}, III}%|\\
 % |  {Rockefeller, John David, III}|\\
-% |\PretagName[Sammy]{\noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}.}%|\\
+% |\PretagName[Sammy]%|\\
+% |  {\noexpand\DoFormat{Davis}, \noexpand\DoFormat{Jr}.}%|\\
 % |  {Davis, Sammy, Jr.}|}
 % \end{quote}
+% \clearpage
 %
-% Above we have our control sequences set up for our names. Next we save the old ``subsequent use'' hook macros:
-% \begin{quote}\small
-% |\let\OldFrontHook\FrontNameHook%|\\
-% |\let\OldMainHook\MainNameHook%|
+% We save the hook macros if we want to recall them.
+% \begin{quote}\small\setstretch{1.1}
+% |\let\OldNamesFormat\NamesFormat|\\
+% |\let\OldFrontNamesFormat\FrontNamesFormat|\\
+% |\let\OldFrontHook\FrontNameHook|\\
+% |\let\OldMainHook\MainNameHook|
 % \end{quote}
 %
+% \let\OldNamesFormat\NamesFormat%
+% \let\OldFrontNamesFormat\FrontNamesFormat%
 % \let\OldFrontHook\FrontNameHook%
 % \let\OldMainHook\MainNameHook%
-% We do not need to redefine either \cmd{\NamesFormat} or \cmd{\FrontNamesFormat} because we want the first uses to display small caps in the text. We redefine \cmd{\MainNameHook} and \cmd{\FrontNameHook} in order to \emph{suppress} formatting in all subsequent uses of names. We also use the \texttt{formatAKA} option.
-% \clearpage
+% We\marginpar{\small\raggedleft\dbend} do not need to redefine either \cmd{\NamesFormat} or \cmd{\FrontNamesFormat} because we already set the default to be small caps. We redefine \cmd{\MainNameHook} and \cmd{\FrontNameHook} in order to \emph{suppress} formatting in subsequent uses of names.
 %
-% The new implementation of \cmd{\MainNameHook} follows. We incorporate those parts of \cmd{\AKA} and \cmd{\@nameauth at Name} that print name arguments in the text:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
-% \begin{quote}\small
+% The new implementation of \cmd{\MainNameHook} follows. We incorporate those parts of \cmd{\AKA} and \cmd{\@nameauth at Name} that print name arguments in the text.\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
+% Please bear in mind that this example is quite long.
+%
+% \begin{quote}\small\setstretch{1.1}
 % |\makeatletter%|\\
 % |\renewcommand*\MainNameHook[1]%|\\
 % |{%|\\
 % |  \let\ex\expandafter%|\\
 % |  \SCfalse%|
+% \end{quote}
 % 
-% Above we set the small caps Boolean to false. Now we have to ``redo'' name parsing in order to get the different format. We get the unexpanded arguments from the naming macro that called us via the token registers. We must expand the register values for comparisons to work.
+% Above we set the small caps Boolean to false. Now we have to ``redo'' name parsing in order to get the different format. We expand the naming macros from the token registers set by the parent naming macro.
 %
+% \begin{quote}\small\setstretch{1.1}
 % {\noindent\footnotesize|  \protected at edef\arga{\ex\trim at spaces\ex{\the\@nameauth at toksa}}%|\\
 % |  \protected at edef\argb{\ex\trim at spaces\ex{\the\@nameauth at toksb}}%|\\
 % |  \protected at edef\testb{\ex\@nameauth at Root\ex{\the\@nameauth at toksb}}%|\\
 % |  \protected at edef\argc{\ex\trim at spaces\ex{\the\@nameauth at toksc}}%|}
+% \end{quote}
 %
-% \cmd{\Space} is defined by the parent macro. Here we print an appropriate version of the pseudonym in the text. We cannot use the text-only capitalization macros when we use this scheme. This is not much of a problem when using Continental contexts.
+% \cmd{\Space} (below) is defined by the parent naming macro. Before we print an appropriate version of the pseudonym or name in the text, we determine the removable suffix, if any, and the reversed forms.
 %
+% \begin{quote}\small\setstretch{1.1}
 % |  \ifx\argb\testb|\\
 % |    \protected at edef\Suff{\@empty}%|\\
 % |    \let\Reversed\argb%|\\
@@ -2601,103 +2757,63 @@
 % |       \let\Short\testb%|\\
 % |     \fi|\\
 % |  \fi|
+% \end{quote}
 %
-% Only the reversing macros will work with the macros that we generate above as well as in the rest of this hook. The capitalization macros are ignored.
+% \cmd{\AllCapsActive}, \cmd{\CapName}, and the \texttt{allcaps} package option are ignored here because they are incompatible with the Continental approach. Only the reversing macros will be usable.
 % \clearpage
 %
-% Print an appropriate version of the pseudonym in the text.
-%
+% \noindent If the parent naming macro is \cmd{\AKA} and its variants, print an appropriate version of the pseudonym in the text.
+% \begin{quote}\small\setstretch{1.1}
 % |  \if at nameauth@InAKA|\\
 % |    \ifx\arga\@empty|\\
 % |      \ifx\argc\@empty|\\
-% |        \if at nameauth@RevThis|\\
-% |          \Reversed%|\\
-% |        \else|\\
-% |          \SNN%|\\
-% |        \fi|\\
+% |        \if at nameauth@RevThis \Reversed \else \SNN \fi|\\
 % |      \else|\\
-% |        \if at nameauth@AltAKA|\\
-% |          \argc%|\\
+% |        \if at nameauth@AltAKA \argc%|\\
 % |        \else|\\
-% |          \if at nameauth@RevThis|\\
-% |            \ex\argc\ex\Space\SNN%|\\
-% |          \else|\\
-% |            \ex\SNN\ex\space\argc%|\\
-% |          \fi|\\
-% |        \fi|\\
-% |      \fi|\\
+% |          \if at nameauth@RevThis \ex\argc\ex\space\SNN%|\\
+% |          \else \ex\SNN\ex\space\argc%|\\
+% |          \fi \fi \fi|\\
 % |    \else|\\
-% |      \ifx\argc\@empty|\\
-% |        \let\FNN\arga%|\\
-% |      \else|\\
-% |        \let\FNN\argc%|\\
+% |      \ifx\argc\@empty \let\FNN\arga%|\\
+% |      \else \let\FNN\argc%|\\
 % |      \fi|\\
-% |      \if at nameauth@AltAKA|\\
-% |        \FNN%|\\
+% |      \if at nameauth@AltAKA \FNN%|\\
 % |      \else|\\
-% |        \if at nameauth@RevThis|\\
-% |          \ex\SNN\ex\Space\FNN%|\\
-% |        \else|\\
-% |          \ex\FNN\ex\space\SNN%|\\
-% |        \fi|\\
-% |      \fi|\\
-% |    \fi|\\
+% |        \if at nameauth@RevThis \ex\SNN\ex\Space\FNN%|\\
+% |        \else \ex\FNN\ex\space\SNN%|\\
+% |        \fi \fi \fi|\\
 % |  \else|
-% \clearpage
-% Print an appropriate version of the name in the text.
-%
+% \end{quote}
+% If the main naming engine is the parent macro, print an appropriate version of the name in the text.
+% \begin{quote}\small\setstretch{1.1}
 % |    \ifx\arga\@empty|\\
 % |      \ifx\argc\@empty|\\
 % |        \if at nameauth@FullName|\\
-% |          \if at nameauth@RevThis|\\
-% |            \Reversed%|\\
-% |          \else|\\
-% |            \SNN%|\\
-% |          \fi|\\
-% |        \else|\\
-% |          \Short%|\\
-% |        \fi|\\
+% |          \if at nameauth@RevThis \Reversed \else \SNN \fi|\\
+% |        \else \Short \fi|\\
 % |      \else|\\
 % |        \if at nameauth@FullName|\\
-% |          \if at nameauth@RevThis|\\
-% |            \ex\argc\ex\space\SNN%|\\
-% |          \else|\\
-% |            \ex\SNN\ex\space\argc%|\\
+% |          \if at nameauth@RevThis \ex\argc\ex\space\SNN%|\\
+% |          \else \ex\SNN\ex\space\argc%|\\
 % |          \fi|\\
 % |        \else|\\
-% |          \if at nameauth@RevThis|\\
-% |            \argc%|\\
-% |          \else|\\
-% |            \Short%|\\
-% |          \fi|\\
-% |        \fi|\\
-% |      \fi|\\
+% |          \if at nameauth@RevThis \argc \else \Short \fi|\\
+% |        \fi \fi|\\
 % |    \else|\\
-% |      \ifx\argc\@empty|\\
-% |        \let\FNN\arga%|\\
-% |      \else|\\
-% |        \let\FNN\argc%|\\
+% |      \ifx\argc\@empty \let\FNN\arga%|\\
+% |      \else \let\FNN\argc%|\\
 % |      \fi|\\
 % |      \let\Short\FNN%|\\
 % |      \if at nameauth@FullName|\\
-% |        \if at nameauth@RevThis|\\
-% |          \ex\SNN\ex\Space\FNN%|\\
-% |        \else|\\
-% |          \ex\FNN\ex\space\SNN%|\\
+% |        \if at nameauth@RevThis \ex\SNN\ex\Space\FNN%|\\
+% |        \else \ex\FNN\ex\space\SNN%|\\
 % |        \fi|\\
 % |      \else|\\
-% |        \if at nameauth@FirstName|\\
-% |          \Short%|\\
-% |        \else|\\
-% |          \testb%|\\
-% |        \fi|\\
-% |      \fi|\\
-% |    \fi|\\
-% |  \fi|\\
+% |        \if at nameauth@FirstName \Short \else \testb \fi|\\
+% |      \fi \fi \fi|\\
 % |}|
 % \end{quote}
-%
-% This is a really long example! It incorporates much of the parsing that is done in \cmd{\AKA} and \cmd{\@nameauth at Name} in order to implement as much of the standard look and feel as possible.
 % \makeatletter%
 % \renewcommand*\MainNameHook[1]{\ignorespaces%
 %   \let\ex\expandafter\ignorespaces%
@@ -2734,7 +2850,7 @@
 %            \argc%
 %          \else
 %            \if at nameauth@RevThis
-%              \ex\argc\ex\Space\SNN%
+%              \ex\argc\ex\space\SNN%
 %            \else
 %              \ex\SNN\ex\space\argc%
 %            \fi
@@ -2808,8 +2924,8 @@
 % }
 % \clearpage
 %
-% The final hook operates in the front matter. We simply let \cmd{\FrontNameHook} be the same as \cmd{\MainNameHook} in order to suppress all formatting. This is similar to the default behavior of \textsf{nameauth.}
-% \begin{quote}\small
+% Now we let \cmd{\FrontNameHook} be the same as \cmd{\MainNameHook}, and we are ready to see the Continental approach in action.
+% \begin{quote}\small\setstretch{1.1}
 % |\let\FrontNameHok\MainNameHook|\\
 % |\makeatother|
 % \end{quote}
@@ -2816,7 +2932,7 @@
 % \let\FrontNameHook\MainNameHook
 % \makeatother
 %
-% \noindent{\large\bfseries Main Matter}\\
+% \noindent{\bfseries Main Matter}\medskip
 %
 % {\footnotesize\noindent\begin{tabular}{llll}\toprule
 % First & Next & Long & Short \\\midrule
@@ -2827,10 +2943,9 @@
 % \Cao & \Cao & \LCao & \SCao\\\bottomrule
 % \end{tabular}}\bigskip
 %
-% \noindent{\large\bfseries Front Matter}\\
+% \noindent{\bfseries Front Matter}\medskip
 %
-% \NamesInactive
-% {\footnotesize\noindent\begin{tabular}{llll}\toprule
+% \NamesInactive{\footnotesize\noindent\begin{tabular}{llll}\toprule
 % First & Next & Long & Short \\\midrule
 % \JQA & \JQA & \LJQA & \SJQA\\
 % \JRIII & \JRIII & \LJRIII & \SJRIII\\
@@ -2837,81 +2952,299 @@
 % \Aeths & \Aeths & \LAeths & \SAeths\\
 % \Chas & \Chas & \LChas & \SChas\\
 % \Cao & \Cao & \LCao & \SCao\\\bottomrule
-% \end{tabular}}\bigskip
-% \NamesActive
+% \end{tabular}}\NamesActive
+% \begin{itemize}\small
+% \item Punctuation detection still works: \SDJR. Then we have \SDJR.
+% \item \cmd{\RevComma}\cmd{\LJQA} yields \RevComma\LJQA. All the reversing macros work.
+% \item Using the main interface requires some extra typing. For example,\\
+% |\ForgetName[John Quincy]{\noexpand\DoFormat{Adams}}\JQA|\\
+% results in \ForgetName[John Quincy]{\noexpand\DoFormat{Adams}}\JQA.
+% \end{itemize}
 %
-% We can refer to \SDJR. See how the punctuation detection still works? The next reference is \SDJR.
-% We also can use reversing, such as reversing with commas:\\
-%
-% \ReverseCommaActive
-% {\footnotesize\noindent\begin{tabular}{lll}\toprule
-% Long & Normal & Short \\\midrule
-% \LJQA & \JQA &  \SJQA\\
-% \LJRIII & \JRIII & \SJRIII\\
-% \LSDJR & \SDJR & \SSDJR \\\bottomrule
-% \end{tabular}}\bigskip
-% \ReverseCommaInactive
-%
 % \makeatletter\@nameauth at AKAFormattrue\makeatother
-% If we use the \texttt{formatAKA} option we can refer to \LCao\ as \AKA{\noexpand\DoFormat{Cao}, Cao}{\noexpand\DoFormat{Mengde}}, and again \AKA{\noexpand\DoFormat{Cao}, Cao}{\noexpand\DoFormat{Mengde}}. We get that with:
-% \begin{quote}\small
+% Normally \cmd{\AKA} will not format alternate names. However, if we use the \texttt{formatAKA} option we can refer to \LCao\ as \AKA{\noexpand\DoFormat{Cao}, Cao}{\noexpand\DoFormat{Mengde}}, and again \AKA{\noexpand\DoFormat{Cao}, Cao}{\noexpand\DoFormat{Mengde}}. We get that with:
+% \begin{quote}\small\setstretch{1.1}
 % |\PretagName{\noexpand\DoFormat{Mengde}}{Mengde}|\\
 % |\AKA{\noexpand\DoFormat{Cao}, Cao}{\noexpand\DoFormat{Mengde}}|
 % \end{quote}
 % \makeatletter\@nameauth at AKAFormatfalse\makeatother
-% Otherwise \cmd{\AKA} will not format the alternate name.
 %
-% When we are done, if the scope is not document-wide, we restore the hooks to their old values:
-% \begin{quote}\small
-% |\let\FrontNameHook\OldFrontHook|\\
-% |\let\MainNameHook\OldMainHook|
-% \end{quote}
-% \let\FrontNameHook\OldFrontHook
-% \let\MainNameHook\OldMainHook
+% \NamesInactive%
+% If you want to suppress formatting altogether in the front matter, make the following change: 
+% |\let\FrontNamesFormat\MainNameHook|\medskip
+% \let\FrontNamesFormat\MainNameHook%
+% \ForgetName[John Quincy]{\noexpand\DoFormat{Adams}}%
+% \ForgetName{\noexpand\DoFormat{Æþelstan}}%
+% \ForgetName{\noexpand\DoFormat{Charles}, I}%
+% \ForgetName{\noexpand\DoFormat{Cao}, Cao}%
+% \ForgetName[John David]{\noexpand\DoFormat{Rockefeller}, III}
+
+% \noindent{\bfseries Front Matter (hooks changed; names forgotten)}\medskip
 %
-% I am the first to admit that this example is quite involved. I am painfully aware that this package has not crystallized from a great knowledge base or descended on high from any kind of superior design. It has been quite a journey of discovery about naming and \LaTeX, \emph{inter alia}.
+% {\footnotesize\noindent\begin{tabular}{llll}\toprule
+% First & Next & Long & Short \\\midrule
+% \JQA & \JQA & \LJQA & \SJQA\\
+% \JRIII & \JRIII & \LJRIII & \SJRIII\\
+% \Aeths & \Aeths & \LAeths & \SAeths\\
+% \Chas & \Chas & \LChas & \SChas\\
+% \Cao & \Cao & \LCao & \SCao\\\bottomrule
+% \end{tabular}}\NamesActive\bigskip
+%
+% When needed, we can use \cmd{\let} to restore the hooks to their old values. Please note, however, that the index entries will contain small caps, regardless of how we change the hook macros for the document text.
+% \let\NamesFormat\OldNamesFormat%
+% \let\FrontNamesFormat\OldFrontNamesFormat%
+% \let\FrontNameHook\OldFrontHook%
+% \let\MainNameHook\OldMainHook%
 % \clearpage
 %
-% \subsubsection{Variant Spellings}
+% \begin{center}\bfseries Caps within Formatting\end{center}
+% This\marginpar{\small\raggedleft\dbend} method of redesigning the hooks must be used if you want to capitalize a name that is otherwise formatted in the index. All we need to do is modify the example above. We begin in similar fashion, but add a few extra bits:\footnote{A similar version of this example is in \texttt{examples.tex}, collocated with this manual.}
+% \begin{quote}\small\setstretch{1.1}
+% |\newif\ifItal%|\hfill |Flag to trigger italics|\\
+% |\newif\ifFirstCap%|\hfill |Flag to trigger caps|\\
+% |\newif\ifInHook%|\hfill |But only with a name in the body text|\\
+% |\Italtrue%|\hfill |We want italics in the index|\\
+% |\def\DoFormat#1{%|\\
+% |  \ifItal\textit{#1}\else#1\fi|\\
+% |}|\\
+% |\def\CP#1{%|\\
+% |  \ifInHook|\\
+% |    \ifFirstCap\uppercase{#1}\else#1\fi%|\\
+% |  \else|\\
+% |    #1%|\\
+% |  \fi|\\
+% |}|\\
+% |\newcommand*\CapMe{\FirstCaptrue}|
+% \end{quote}
 %
-% This section illustrates why this package is called ``nameauth.'' Here we get to an example where the macros work together to implement a name authority.
-%
-% Handling variant name spellings can be complicated. For example, let us assume that you are editing a collection of essays. You might settle on the form \Name[W.E.B.]{Du Bois} in your name authority. An essay in that collection might use the alternate spelling \IndexInactive\Name*[W.E.B.]{DuBois}\IndexActive. The author or publisher who owns that work might not grant you permission to alter the spelling. In that case, you could add an alternate spelling. Using the simplified interface, it would be:
-% \begin{nameauth}
-% \< DuBois & W.E.B. & Du Bois & >
-% \< AltDuBois & W.E.B. & DuBois & >
-% \end{nameauth}
-% \begin{quote}
+% \def\DoFormat#1{\ifItal\textit{#1}\else#1\fi}%
+% \def\CP#1{\ifInHook\ifFirstCap\uppercase{#1}\else#1\fi\else#1\fi}%
+% Like\marginpar{\small\raggedleft\dbend} the previous example on Continental formatting, you would put the formatting in the naming macro arguments. \cmd{\CP} can fail using NFSS and Unicode, so take care! We have changed the meaning of \cmd{\DoFormat} in this section. If we were to use any of the names from the Continental example above, they would now be formatted italic and produce different index entries that also would be italicized instead of small caps. 
+% \begin{quote}\footnotesize\setstretch{1.1}
+% |\PretagName[Pierre-Jean]{\noexpand\DoFormat{\noexpand\CP{d}e Smet}}%|\\
+% |  {de Smet, Pierre-Jean}|\\
 % |\begin{nameauth}|\\
-% |  \< DuBois & W.E.B. & Du Bois & >|\\
-% |  \< AltDuBois & W.E.B. & DuBois & >|\\
+% | \<| |deSmet| |&| |Pierre-Jean| |&| |\noexpand\DoFormat{\noexpand\CP{d}e| |Smet}}| |&| |>|\\
 % |\end{nameauth}|
 % \end{quote}
+% 
+% We take the code of \cmd{\MainNameHook} above and redefine it to be \cmd{\NamesFormat}. We change the example above to read:
+% \begin{quote}\small\setstretch{1.1}
+% |\renewcommand*\MainNameHook[1]{%|\\
+% |  \let\ex\expandafter%|\\
+% |  \InHooktrue%|\hfill |cap in the text, not the index|
+% \end{quote}
+% Leave the rest of the example intact and change the last part of the macro:
+% \begin{quote}\small\setstretch{1.1}
+% |  \InHookfalse\global\FirstCapfalse%|\\
+% |}\makeatother%|
+% \end{quote}
+% You need to have \cmd{\global} before \cmd{\FirstCapfalse} to ensure that the change persists beyond the scope. By design, the hooks occur within a group in the naming functions.
+% \clearpage
 %
-% If you wanted to index the alternate spelling with its own entry, the trivial use of \cmd{\AltDuBois} allows that easily. All you need do is make cross-references to each variant in the index so that the reader is aware of them.
+% If you want italics all the time, just \cmd{\let} all the hooks be \cmd{\NamesFormat}. If you want to follow the Continental style similar to the example above, you do:
+% \begin{quote}\small\setstretch{1.1}
+% |\let\FrontNamesFormat\NamesFormat|\\
+% |\renewcommand*\MainNameHook[1]%|\\
+% |  {\Italfalse\NamesFormat{#1}\Italtrue}|\\
+% |\let\FrontNameHook\MainNameHook|
+% \end{quote}
+% \newcommand*\CapMe{\FirstCaptrue}
+% \makeatletter%
+% \renewcommand*\NamesFormat[1]{\ignorespaces%
+%   \let\ex\expandafter\ignorespaces%
+%   \InHooktrue\ignorespaces%
+%   \protected at edef\arga{\ex\trim at spaces\ex{\the\@nameauth at toksa}}\ignorespaces%
+%   \protected at edef\argb{\ex\trim at spaces\ex{\the\@nameauth at toksb}}\ignorespaces%
+%   \protected at edef\testb{\ex\@nameauth at Root\ex{\the\@nameauth at toksb}}\ignorespaces%
+%   \protected at edef\argc{\ex\trim at spaces\ex{\the\@nameauth at toksc}}\ignorespaces%
+%   \ifx\argb\testb
+%     \protected at edef\Suff{\@empty}\ignorespaces%
+%     \let\Reversed\argb\ignorespaces%
+%     \let\SNN\argb\ignorespaces%
+%     \let\Short\argb\ignorespaces%
+%   \else
+%     \protected at edef\Suff{\ex\@nameauth at Suffix\ex{\the\@nameauth at toksb}}\ignorespaces%
+%     \protected at edef\Reversed{\Suff\Space\testb}\ignorespaces%
+%     \protected at edef\SNN{\testb\Space\Suff}\ignorespaces%
+%      \if at nameauth@RevThis
+%        \let\Short\Suff%
+%      \else
+%        \let\Short\testb%
+%      \fi
+%   \fi
+%   \if at nameauth@InAKA
+%     \ifx\arga\@empty
+%       \ifx\argc\@empty
+%         \if at nameauth@RevThis
+%           \Reversed%
+%         \else
+%           \SNN%
+%         \fi
+%       \else
+%          \if at nameauth@AltAKA
+%            \argc%
+%          \else
+%            \if at nameauth@RevThis
+%              \ex\argc\ex\space\SNN%
+%            \else
+%              \ex\SNN\ex\space\argc%
+%            \fi
+%          \fi
+%        \fi
+%      \else
+%        \ifx\argc\@empty
+%          \let\FNN\arga%
+%        \else
+%          \let\FNN\argc%
+%        \fi
+%        \if at nameauth@AltAKA
+%          \FNN%
+%        \else
+%          \if at nameauth@RevThis
+%            \ex\SNN\ex\Space\FNN%
+%          \else
+%            \ex\FNN\ex\space\SNN%
+%          \fi
+%        \fi
+%      \fi
+%   \else
+%     \ifx\arga\@empty
+%       \ifx\argc\@empty
+%         \if at nameauth@FullName
+%           \if at nameauth@RevThis
+%             \Reversed%
+%           \else
+%             \SNN%
+%           \fi
+%         \else
+%           \Short%
+%         \fi
+%       \else
+%         \if at nameauth@FullName
+%           \if at nameauth@RevThis
+%             \ex\argc\ex\space\SNN%
+%           \else
+%             \ex\SNN\ex\space\argc%
+%           \fi
+%         \else
+%           \if at nameauth@RevThis
+%             \argc%
+%           \else
+%             \Short%
+%           \fi
+%         \fi
+%       \fi
+%     \else
+%       \ifx\argc\@empty
+%         \let\FNN\arga%
+%       \else
+%         \let\FNN\argc%
+%       \fi
+%       \let\Short\FNN%
+%       \if at nameauth@FullName
+%         \if at nameauth@RevThis
+%           \ex\SNN\ex\Space\FNN%
+%         \else
+%           \ex\FNN\ex\space\SNN%
+%         \fi
+%       \else
+%         \if at nameauth@FirstName
+%           \Short%
+%         \else
+%           \testb%
+%         \fi
+%       \fi
+%     \fi
+%   \fi
+%   \InHookfalse\global\FirstCapfalse}
+% \let\FrontNamesFormat\NamesFormat%
+% \renewcommand*\MainNameHook[1]{\Italfalse\NamesFormat{#1}\Italtrue}%
+% \let\FrontNameHook\MainNameHook%
 %
-% Nevertheless, \DuBois\ and \IndexInactive\AltDuBois\IndexActive\ differ only by spaces. For several good reasons, such as fault tolerance in typing, the first/subsequent use mechanism ignores spaces and sees them as \emph{the same name}. Use |\ForgetName[W.E.B.]{Du Bois}| to trigger the first use of \cmd{\AltDuBois} in that section.
+% Now we show how the formatting hooks work in the body text. One can check the index to see that it is formatted with italics and is consistent.\medskip
 %
-% If you wanted to index the variants under only one name entry, it gets more complicated. You could do the following:
+% \noindent{\bfseries Main Matter}
 %
-% \begin{enumerate}\small
-% \item Use |\ForgetName[W.E.B.]{Du Bois}| at the start of the section.
-% \item Wrap \cmd{\AltDuBois} between \cmd{\IndexInactive} and \cmd{\IndexActive}.
-% \item Call \cmd{\IndexName} with the authoritative form right after \cmd{\IndexActive}.
-% \item Create a cross-reference in the index.
-% \end{enumerate}
-% This can be automated at the start of the section with something like:
-% \begin{quote}%
-% \ForgetName[W.E.B.]{DuBois}%
-% \gdef\OtherDuBois{\IndexInactive\AltDuBois\IndexActive\IndexName[W.E.B.]{Du Bois}}%
-% \index{DuBois, W.E.B.|see{Du Bois, W.E.B.}}%
-% |\ForgetName[W.E.B.]{DuBois}|\\
-% |\gdef\OtherDuBois{\IndexInactive\AltDuBois\IndexActive%|\\|  \IndexName[W.E.B.]{Du Bois}}|\\
-% \verb!\index{DuBois, W.E.B.|see{Du Bois, W.E.B.}}!
+% \begin{center}\footnotesize
+% \begin{tabular}{llll}\toprule
+% First & Next & Long & Short \\\midrule
+% |\deSmet| & |\deSmet| & |\LdeSmet| & |\SdeSmet|\\
+% \deSmet & \deSmet & \LdeSmet & \SdeSmet\\\bottomrule
+% \end{tabular}
+% \end{center}
+%
+% \noindent{\bfseries Front Matter}
+%
+% \begin{center}\NamesInactive\footnotesize
+% \begin{tabular}{llll}\toprule
+% First & Next & Long & Short \\\midrule
+% |\deSmet| & |\deSmet| & |\LdeSmet| & |\SdeSmet|\\
+% \deSmet & \deSmet & \LdeSmet & \SdeSmet\\\bottomrule
+% \end{tabular}
+% \end{center}
+%
+% The capitalized version |\CapMe\deSmet| is \CapMe\deSmet. If we let \cmd{\MainNameHook} be the same as \cmd{\NamesFormat} we can get \let\MainNameHook\NamesFormat\CapMe\deSmet. The index entries will be consistent for all the variations in the text.
+%
+% Of course, one could go a step further and integrate this capitalizing mechanism with the \cmd{\CapThis} and \cmd{\AccentCapThis} macros. That, however, goes beyond the scope of this example. You would have to insert the capitalization bits from \cmd{\@nameauth at name}. Or you could test for the latex engine and do everything in the hook, and redefine \cmd{\CapThis}.
+%
+% Also, remember to restore the macro hooks if they should not persist for the entire document, or else you will get unwanted results:
+% \begin{quote}\small\setstretch{1.1}
+% |\let\NamesFormat\OldNamesFormat%|\\
+% |\let\FrontNamesFormat\OldFrontNamesFormat%|\\
+% |\let\FrontNameHook\OldFrontHook%|\\
+% |\let\MainNameHook\OldMainHook%|
 % \end{quote}
+% \let\NamesFormat\OldNamesFormat%
+% \let\FrontNamesFormat\OldFrontNamesFormat%
+% \let\FrontNameHook\OldFrontHook%
+% \let\MainNameHook\OldMainHook%
+% \clearpage
 %
-% The alternate section mentions \cmd{\OtherDuBois} starting with a first use: \OtherDuBois. Subsequent uses of  \cmd{\OtherDuBois} print \OtherDuBois. Of course, one could get more complex than the example above. The index will only hold the standard entry for \Name*[W.E.B.]{Du Bois}: ``Du Bois, W.E.B.'' and a cross-reference from the variant ``DuBois, W.E.B.'' to the standard entry.
+% \subsubsection{Full Redesign}
+% \label{sec:NewEngine}
 %
+% Assuming\marginpar{\small\raggedleft\dbend\dbend} that redefining hooks and adding control sequences is insufficient to your task, you could modify the core naming macros and hook those modifications back into the \textsf{nameauth} package without needing to continuously track and patch the style file itself.
+%
+% \DescribeMacro{\NameauthName}
+% \DescribeMacro{\NameauthLName}
+% \DescribeMacro{\NameauthFName}
+% These macros are set by default to \cmd{\@nameauth at Name}, the internal name parser. The main and simplified interfaces call them as respective synonyms for \cmd{\Name,} \cmd{\Name*,} and \cmd{\FName.} Should you desire to create your own naming macros, you can redefine them. Here is the minimal working example:
+% \begin{quote}\small\setstretch{1.1}
+% |\makeatletter|\\
+% |\newcommandx*\MyName[3][1=\@empty, 3=\@empty]{|\meta{Name}|}%|\\
+% |\newcommandx*\MyLName[3][1=\@empty, 3=\@empty]%|\\
+% |  {|\meta{Long name}|\@nameauth at FullNamefalse}%|\\
+% |\newcommandx*\MyFName[3][1=\@empty, 3=\@empty]%|\\
+% |  {|\meta{Short name}|\@nameauth at FirstNamefalse}%|\\
+% |\makeatother|
+% \end{quote}
+%
+% The macros above do not really work together with the rest of \textsf{nameauth} package, so be careful! You can hook these macros into the user interface thus:
+% \begin{quote}\small\setstretch{1.1}
+% \makeatletter%
+% \newcommandx*\MyName[3][1=\@empty, 3=\@empty]{\meta{Name}}%
+% \newcommandx*\MyLName[3][1=\@empty, 3=\@empty]{\meta{Long name}\@nameauth at FullNamefalse}%
+% \newcommandx*\MyFName[3][1=\@empty, 3=\@empty]{\meta{Short name}\@nameauth at FirstNamefalse}%
+% \makeatother%
+% |\renewcommand*\NameauthName{\MyName}|\\
+% |\renewcommand*\NameauthLName{\MyLName}|\\
+% |\renewcommand*\NameauthFName{\MyFName}|\\
+% |\begin{nameauth}|\\
+% |  \< Silly & No Particular & Name & >|\\
+% |\end{nameauth}|\\
+% |This is \Silly, \LSilly, and \SSilly.|\\
+% \renewcommand*\NameauthName{\MyName}%
+% \renewcommand*\NameauthLName{\MyLName}%
+% \renewcommand*\NameauthFName{\MyFName}%
+% \begin{nameauth}
+%   \< Silly & No Particular & Name & >
+% \end{nameauth}
+% This is \Silly, \LSilly, and \SSilly.
+% \end{quote}
+% Like\marginpar{\small\raggedleft\cmd{\global}} \cmd{\NamesFormat}, the other hook macros, and many of the state-changing and triggering macros in this package, these naming macros can be redefined or used locally within a scope without making global changes to the document unless you specifically use \cmd{\global}.
+%
+% Here we show that the macros \cmd{\NameauthName,} \cmd{\NameauthLName,} and \cmd{\NameauthFName} have reverted back to their original forms. Now \cmd{\Silly} and |\Name[No Particular]{Name}| produce \IndexInactive\Silly\ and \Name[No Particular]{Name}\IndexActive.
 % \clearpage
 %
 % \subsection{Naming Pattern Reference}
@@ -2942,11 +3275,11 @@
 % \end{tabular}}
 % \vfil
 %
-%{\noindent |\begin{nameauth}|\\
-%|  \< Smith & John & Smith & >|\\
-%|  \< JQP & J.Q. & Public & >|\\
-%|  \< Patton & George S. & Patton, Jr. & >|\\
-%|\end{nameauth}|}
+% {\noindent |\begin{nameauth}|\\
+% |  \< Smith & John & Smith & >|\\
+% |  \< JQP & J.Q. & Public & >|\\
+% |  \< Patton & George S. & Patton, Jr. & >|\\
+% |\end{nameauth}|}
 % \vfil
 %
 % {\setstretch{1.1}\ForgetName[John]{Smith}\ForgetName[J.Q.]{Public}\ForgetName[George S.]{Patton, Jr.}%
@@ -2966,7 +3299,7 @@
 % \begin{tabular}{p{0.53\textwidth}@{}p{0.42\textwidth}}\toprule
 % \textit{First reference}: \ForgetName{Francis, I}\Name{Francis, I} & |\Name*{Francis, I}|\newline |\Name{Francis, I}|\newline |\FName{Francis, I}|\\[1ex]
 % \textit{Subsequent full}: \Name*{Francis, I} & |\Name*{Francis, I}|\\[1ex]
-% \textit{Subsequent name}: \Name{Francis, I} & |\Name{Francis, I}|\newline |\FName{Francis, I}|\\[1ex]
+% \textit{Subsequent name}: \Name{Francis, I} & |\Name{Francis, I}|\newline |\FName{Francis, I}|\\\midrule
 % \textit{First reference}: \newline\hbox to 1em{\hfil}\ForgetName{Demetrius, I Soter}\Name{Demetrius, I Soter} & |\Name*{Demetrius, I Soter}|\newline |\Name{Demetrius, I Soter}|\newline |\FName{Demetrius, I Soter}|\\[1ex]
 % \textit{Subsequent full}: \Name*{Demetrius, I Soter} & |\Name*{Demetrius, I Soter}|\\[1ex]
 % \textit{Subsequent name}: \Name{Demetrius, I Soter} & |\Name{Demetrius, I Soter}|\newline |\FName{Demetrius, I Soter}|\\\midrule
@@ -2979,12 +3312,12 @@
 % \end{tabular}}
 % \vfil
 %
-%\noindent |\begin{nameauth}|\\
-%|  \< Francis & & Francis, I & >|\\
-%|  \< Dem & & Demetrius, I Soter & >|\\
-%|  \< Sun & & Sun, Yat-sen & >|\\
-%|  \< Plato & & Plato & >|\\
-%|\end{nameauth}|
+% \noindent |\begin{nameauth}|\\
+% |  \< Francis & & Francis, I & >|\\
+% |  \< Dem & & Demetrius, I Soter & >|\\
+% |  \< Sun & & Sun, Yat-sen & >|\\
+% |  \< Plato & & Plato & >|\\
+% |\end{nameauth}|
 % \vfil
 %
 % {\setstretch{1.1}\ForgetName{Francis, I}\ForgetName{Demetrius, I Soter}\ForgetName{Sun, Yat-sen}\ForgetName{Plato}%
@@ -3001,11 +3334,11 @@
 % \clearpage
 %
 % \noindent{\bfseries Old Syntax: Royal and Eastern}\\[2ex]
-% Avoid these forms except with the \texttt{comma} option. |\Name{Ptolemy}[I Soter]| keeps the number with the affix. Use |\Name{Ptolemy I}[Soter]| to keep the number with the name. See also Section~\ref{sec:Affix}.\\[2ex]{\small\setstretch{1.1}
+% |\Name{Ptolemy}[I Soter]| keeps the number with the affix. To keep the number with the name, use |\Name{Ptolemy I}[Soter]|. See also Section~\ref{sec:Affix}.\\[2ex]{\small\setstretch{1.1}
 % \begin{tabular}{p{0.53\textwidth}@{}p{0.42\textwidth}}\toprule
 % \textit{First reference}: \ForgetName{Henry}[VIII]\Name{Henry}[VIII] & |\Name*{Henry}[VIII]|\newline |\Name{Henry}[VIII]|\newline |\FName{Henry}[VIII]|\\[1ex]
 % \textit{Subsequent full}: \Name*{Henry}[VIII] & |\Name*{Henry}[VIII]|\\[1ex]
-% \textit{Subsequent name}: \Name{Henry}[VIII] & |\Name{Henry}[VIII]|\newline |\FName{Henry}[VIII]|\\[1ex]
+% \textit{Subsequent name}: \Name{Henry}[VIII] & |\Name{Henry}[VIII]|\newline |\FName{Henry}[VIII]|\\\midrule
 % \textit{First reference}: \ForgetName{Ptolemy}[I Soter]\Name{Ptolemy}[I Soter] & |\Name*{Ptolemy}[I Soter]|\newline |\Name{Ptolemy}[I Soter]|\newline |\FName{Ptolemy}[I Soter]|\\[1ex]
 % \textit{Subsequent full}: \Name*{Ptolemy}[I Soter] & |\Name*{Ptolemy}[I Soter]|\\[1ex]
 % \textit{Subsequent name}: \Name{Ptolemy}[I Soter] & |\Name{Ptolemy}[I Soter]|\newline |\FName{Ptolemy}[I Soter]|\\\midrule
@@ -3015,12 +3348,11 @@
 % \end{tabular}}
 % \vfil
 %
-%\noindent |\begin{nameauth}|\\
-%|  \< Henry & & Henry & VIII >|\\
-%|  \< Ptol & & Ptolemy & I Soter >|\\
-%|  \< Mao & & Mao & Tse-tung >|\\
-%|\end{nameauth}|
-% \vfil
+% \noindent |\begin{nameauth}|\\
+% |  \< Henry & & Henry & VIII >|\\
+% |  \< Ptol & & Ptolemy & I Soter >|\\
+% |  \< Mao & & Mao & Tse-tung >|\\
+% |\end{nameauth}|\medskip
 %
 % {\setstretch{1.1}\ForgetName{Ptolemy}[I Soter]\ForgetName{Henry}[VIII]\ForgetName{Mao}[Tse-tung]%
 % \noindent |\Henry, \LHenry, \Henry, and \SHenry|:\\
@@ -3031,14 +3363,14 @@
 % \indent \Mao, \LMao, \Mao, and \SMao}
 % \vfil
 %
-% Avoid mixing old and new syntax. |\Name{Antiochus,| |IV| |Epiphanes}| and |\Name{Antiochus}[IV| |Epiphanes]| look similar, but they are quite different. Even if you avoid the old syntax, keep the following in mind:
+% The old syntax |\Name{Antiochus}[IV Epi\-phanes]| is functionally equivalent to |\Name{Antiochus, IV Epi\-phanes}|. Consider also how you might handle affixes and sobriquets:
 %
-% \begin{itemize}\small
-% \item \textbf{Okay:} Use |\Name{Antiochus, IV Epi\-phanes}| to get \IndexInactive\Name{Antiochus, IV Epi\-phanes} and \Name{Antiochus, IV Epi\-phanes} in the body text and ``Antiochus IV Epi\-phanes'' in the index.
+% \begin{itemize}\small\IndexInactive
+% \item |\Name{Antiochus, IV Epi\-phanes}| yields \Name{Antiochus, IV Epi\-phanes} and \Name{Antiochus, IV Epi\-phanes} in the body text; ``Antiochus IV Epi\-phanes'' in the index.
 %
-% \item \textbf{Okay:} Use |\Name{Antiochus~IV, Epi\-phanes}| to get \Name{Antiochus~IV, Epi\-phanes} and \Name{Antiochus~IV, Epi\-phanes} in the body text and ``Antiochus IV Epi\-phanes'' in the index.\IndexActive
-%
-% \item \textbf{Best:} Use |\Name{Antiochus,| |IV}| to get \Name{Antiochus, IV} and \Name{Antiochus, IV} in the text. Add a tag like |\TagName{Antiochus,| |IV}{| |Epi\-phanes}| to get ``Antiochus IV Epi\-phanes'' in the index. Manually add ``Epi\-phanes'' in the body text when desired.
+% \item |\Name{Antiochus~IV, Epi\-phanes}| yields \Name{Antiochus~IV, Epi\-phanes} and \Name{Antiochus~IV, Epi\-phanes} in the body text and ``Antiochus IV Epi\-phanes'' in the index.\IndexActive
+% 
+% \item |\Name{Antiochus,| |IV}| yields \Name{Antiochus, IV} and \Name{Antiochus, IV} in the text. Use \cmd{\NameAddInfo}, \cmd{\NameQueryInfo}, and \cmd{\IndexTag} to handle ``Epi\-phanes.'' We prefer, use, and recommend this way.
 % \end{itemize}
 % \clearpage
 %
@@ -3068,12 +3400,12 @@
 % \end{tabular}}
 % \vfil
 %
-%\noindent |\begin{nameauth}|\\
-%|  \< DLM & Walter & de la Mare & >|\\
-%|  \< JWG & Johann Wolfgang von & Goethe & >|\\
-%|  \< Harnack & Adolf & Harnack & >|\\
-%|\end{nameauth}|
-%\vfil
+% \noindent |\begin{nameauth}|\\
+% |  \< DLM & Walter & de la Mare & >|\\
+% |  \< JWG & Johann Wolfgang von & Goethe & >|\\
+% |  \< Harnack & Adolf & Harnack & >|\\
+% |\end{nameauth}|
+% \vfil
 %
 % \ForgetName[Walter]{de la Mare}\ForgetName[Johann Wolfgang von]{Goethe}\ForgetName[Adolf]{Harnack}%
 % \noindent |\DLM\| |and| |\CapThis\DLM|:\\
@@ -3104,13 +3436,13 @@
 % The older syntax presents its own group of potential errors:
 % \begin{itemize}\small\IndexInactive
 % \item Erroneously typing |\Name[Henry]{VIII}| prints ``\Name*[Henry]{VIII}'' and ``\Name[Henry]{VIII},'' as well as producing a malformed index entry.
-% \item Avoid forms like |\Name[Henry]{VIII}[Tudor]| which gives ``\Name*[Henry]{VIII}[Tudor]'' and ``\Name[Henry]{VIII}[Tudor].'' This is a Western name form, not an ancient form. It may act as malformed input if you mix it with proper medieval name forms, but it will not affect them adversely.
+% \item Avoid forms like |\Name[Henry]{VIII}[Tudor]| which gives ``\Name*[Henry]{VIII}[Tudor]'' and ``\Name[Henry]{VIII}[Tudor].'' This is a Western name form, not an ancient form.
 % \item The older syntax will not work with some macros. From the film \emph{Men in Black III}, |\AKA{Boris}[the Animal]{Just Boris}| fails. \cmd{\PName} fails for the same reasons. See also Section~\ref{sec:AKA}
 % \item This form does work:\\ |\Name{Boris,| |the| |Animal}| |\AKA{Boris,| |the| |Animal}{Just| |Boris}|.\\ You get \Name{Boris, the Animal} being ``\AKA{Boris, the Animal}{Just Boris}.''\IndexActive
 % \end{itemize}
 % Warnings result from the following:
 % \begin{itemize}\small
-% \item Using a cross-reference \oarg{Alternate names}\marg{Alternate SNN}\oarg{Alt. names} created by \cmd{\AKA} as a name reference in \cmd{\Name}, \cmd{\FName}, and \cmd{\PName}. They merely will print a name in the body text.
+% \item Using an xref \oarg{Alternate names}\marg{Alternate SNN}\oarg{Alt. names} created by \cmd{\AKA} as a name reference in \cmd{\Name}, \cmd{\FName}, and \cmd{\PName}. They merely will print a name in the body text.
 % \item Using a name reference \oarg{FNN}\marg{SNN}\oarg{Alternate names} created by \cmd{\Name}, \cmd{\FName}, and \cmd{\PName} as a cross-reference in \cmd{\AKA}. It merely will print a name in the body text.
 % \item Using \cmd{\AKA} to create the same cross-reference multiple times or with a cross-reference created by \cmd{\ExcludeName}. It merely will print a name in the body text, but not the index.
 % \item Using \cmd{\IndexName} to index a cross-reference made via \cmd{\AKA} or via the mechanism in \cmd{\ExcludeName} as a main entry. It will do nothing.
@@ -3120,17 +3452,18 @@
 % \item Using \cmd{\Name}, \cmd{\FName}, \cmd{\PName}, and \cmd{\AKA} to refer to names and cross-references excluded by \cmd{\ExcludeName}. They merely will print a name in the body text.
 % \item Using the |nameauth| environment to redefine shorthands, such as:\\[2ex]
 % |\PretagName[E.\,B.]{White}{White, E. B.}|\dots\\[1ex]
-% |\begin{nameauth}|\\\IndexName[E.\,B.]{White}
+% |\begin{nameauth}|\\\IndexName[E.\,B.]{White}\ignorespaces
 % |  \< White & E.\,B. & White & >|\\
 % |  \< White & E. B. & White & >|\\
 % |\end{nameauth}|\\[1ex]
 % Such redefinitions could generate unwanted index entries.
 % \end{itemize}
+% \clearpage
 %
-% \clearpage%\StopEventually{^^A
+% \StopEventually{^^A
 %  \clearpage\PrintChanges
 %  \clearpage\PrintIndex
-%}
+% }
 %
 % \section{Implementation}
 %
@@ -3141,10 +3474,11 @@
 % \subsection{Boolean Values}
 %
 % \noindent{\large\bfseries Affix Commas}\\[0.5ex]
-% The \texttt{comma} and |nocomma| options toggle the first value below, while \cmd{\ShowComma} toggles the second. Each instance of \cmd{\Name} and \cmd{\AKA} reset |\@nameauth at ShowComma|.
+% The \texttt{comma} and |nocomma| options toggle the first value below. \cmd{\ShowComma} toggles the second and \cmd{\NoComma} toggles the third. Each instance of \cmd{\Name} and \cmd{\AKA} reset |\@nameauth at ShowComma|.
 %    \begin{macrocode}
 \newif\if at nameauth@AlwaysComma
 \newif\if at nameauth@ShowComma
+\newif\if at nameauth@NoComma
 %    \end{macrocode}\medskip
 %
 % \noindent{\large\bfseries Toggle Formatting}\\[0.5ex]
@@ -3214,7 +3548,7 @@
 \newif\if at nameauth@InAKA
 \newif\if at nameauth@InName
 %    \end{macrocode}
-% As a side note, \cmd{\AKA} will invoke \cmd{\NamesFormat} / \cmd{\FrontNamesFormat} if the \texttt{alwaysformat} option is set. Otherwise it will invoke \cmd{\MainNameHook} / \cmd{\FrontNameHook}.\medskip
+% As an aside, \cmd{\AKA} will invoke \cmd{\NamesFormat} / \cmd{\FrontNamesFormat} if the \texttt{alwaysformat} option is set. Otherwise it will invoke \cmd{\MainNameHook} / \cmd{\FrontNameHook}.\medskip
 %
 % \noindent{\large\bfseries Stack Overflow Prevention}\\[0.5ex]
 % Here is the locking mechanism that prevents a stack overflow via recursive calls to \cmd{\Name} and \cmd{\AKA}. See Sections~\ref{sec:Hooksb}ff.
@@ -3225,7 +3559,7 @@
 % \begin{macro}{\NamesFormat}
 % Post-process ``first'' instance of final complete name form in text. See Sections~\ref{sec:CustomHooks} and~\ref{sec:Hooksa}ff. Called when both |\@nameauth at MainFormat| and |\@nameauth at FirstFormat| are true.
 %    \begin{macrocode}
-\newcommand*{\NamesFormat}{}
+\newcommand*\NamesFormat{}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\MainNameHook}
@@ -3232,7 +3566,7 @@
 % \changes{v2.4}{2016/03/15}{Added}
 % Post-process subsequent instance of final complete name form in main-matter text. See Sections~\ref{sec:CustomHooks} and~\ref{sec:Hooksa}ff. Called when |\@nameauth at MainFormat| is true and |\@nameauth at FirstFormat| is false.
 %    \begin{macrocode}
-\newcommand*{\MainNameHook}{}
+\newcommand*\MainNameHook{}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\FrontNamesFormat}
@@ -3239,7 +3573,7 @@
 % \changes{v2.5}{2016/04/06}{Added}
 % Post-process ``first'' instance of final complete name form in front-matter text. Called when |\@nameauth at MainFormat| is false and |\@nameauth at FirstFormat| is true.
 %    \begin{macrocode}
-\newcommand*{\FrontNamesFormat}{}
+\newcommand*\FrontNamesFormat{}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\FrontNameHook}
@@ -3246,7 +3580,7 @@
 % \changes{v2.4}{2016/03/15}{Added}
 % Post-process subsequent instance of final complete name form in front-matter text. Called when |\@nameauth at MainFormat| is false and |\@nameauth at FirstFormat| is false.
 %    \begin{macrocode}
-\newcommand*{\FrontNameHook}{}
+\newcommand*\FrontNameHook{}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\NameauthName}
@@ -3253,7 +3587,7 @@
 % \changes{v2.2}{2015/12/01}{Added}
 % Hook to create custom naming macros. Usually the three macros below have the same control sequence, but they need not do so if you want something different. See Section~\ref{sec:NewEngine}. Use at your own risk! Changing these macros basically rewrites this package.
 %    \begin{macrocode}
-\newcommand*{\NameauthName}{\@nameauth at Name}
+\newcommand*\NameauthName{\@nameauth at Name}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\NameauthLName}
@@ -3260,7 +3594,7 @@
 % \changes{v2.3}{2016/01/05}{Added}
 % Customization hook called after \cmd{\@nameauth at FullName} is set true. See Section~\ref{sec:NewEngine}.
 %    \begin{macrocode}
-\newcommand*{\NameauthLName}{\@nameauth at Name}
+\newcommand*\NameauthLName{\@nameauth at Name}
 %    \end{macrocode}
 % \end{macro}
 % \begin{macro}{\NameauthFName}
@@ -3267,7 +3601,7 @@
 % \changes{v2.2}{2015/12/01}{Added}
 % Customization hook called after \cmd{\@nameauth at FirstName} is set true. See Section~\ref{sec:NewEngine}.
 %    \begin{macrocode}
-\newcommand*{\NameauthFName}{\@nameauth at Name}
+\newcommand*\NameauthFName{\@nameauth at Name}
 %    \end{macrocode}
 % \end{macro}
 % \clearpage\noindent
@@ -3305,10 +3639,10 @@
 \DeclareOption{notreversed}%
   {\@nameauth at RevAllfalse\@nameauth at RevAllCommafalse}
 \DeclareOption{alwaysformat}{\@nameauth at AlwaysFormattrue}
-\DeclareOption{smallcaps}{\renewcommand*{\NamesFormat}{\scshape}}
-\DeclareOption{italic}{\renewcommand*{\NamesFormat}{\itshape}}
-\DeclareOption{boldface}{\renewcommand*{\NamesFormat}{\bfseries}}
-\DeclareOption{noformat}{\renewcommand*{\NamesFormat}{}}
+\DeclareOption{smallcaps}{\renewcommand*\NamesFormat{\scshape}}
+\DeclareOption{italic}{\renewcommand*\NamesFormat{\itshape}}
+\DeclareOption{boldface}{\renewcommand*\NamesFormat{\bfseries}}
+\DeclareOption{noformat}{\renewcommand*\NamesFormat{}}
 \ExecuteOptions%
   {nocomma,%
    mainmatter,%
@@ -3338,7 +3672,7 @@
 % \begin{macro}{\@nameauth at Clean}
 % Thanks to \Name*[Heiko]{Oberdiek}, this macro produces a ``sanitized'' string, even using accented characters, based on the arguments of \cmd{\Name} and friends. With this we can construct a control sequence name and test for it to determine the existence of pseudonyms and the first or subsequent occurrences of a name.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at Clean}[1]%
+\newcommand*\@nameauth at Clean[1]%
   {\expandafter\zap at space\detokenize{#1} \@empty}
 %    \end{macrocode}
 % \end{macro}
@@ -3348,7 +3682,7 @@
 % \changes{v1.4}{2012/07/24}{Made more robust}
 % The following two macros parse \meta{SNN} into a radix and a comma-delimited suffix, returning only the radix. They (and their arguments) are expandable in order to facilitate proper indexing functionality. They form the kernel of the suffix removal and comma suppression features.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at Root}[1]%
+\newcommand*\@nameauth at Root[1]%
   {\@nameauth at TrimRoot#1,\@empty\relax}
 %    \end{macrocode}
 % \end{macro}
@@ -3367,7 +3701,7 @@
 % \changes{v2.1}{2015/11/24}{Handle Unicode better}
 % The next two macros implement the particulate name capitalization mechanism by returning a radix where the first letter is capitalized. In \texttt{xelatex} and \texttt{lualatex} this is trivial and causes no problems. In \texttt{pdflatex} we have to account for ``double-wide'' accented Unicode characters.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at CapRoot}[1]%
+\newcommand*\@nameauth at CapRoot[1]%
 {%
   \ifxetex
     \@nameauth at CRii#1\relax%
@@ -3407,7 +3741,7 @@
 % \changes{v1.5}{2013/02/22}{Added}
 % This macro returns a fully-capitalized radix. It is used for generating capitalized Eastern family names in the body text.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at AllCapRoot}[1]%
+\newcommand*\@nameauth at AllCapRoot[1]%
   {\uppercase{\@nameauth at Root{#1}}}
 %    \end{macrocode}
 % \end{macro}
@@ -3416,7 +3750,7 @@
 % \changes{v0.9}{2012/02/10}{Added}
 % The following two macros parse \meta{SNN} into a radix and a comma-delimited suffix, returning only the suffix. Anything before a comma is stripped off by |\@nameauth at Suffix|, but a comma must be present in the argument. Leading spaces are removed to allow consistent formatting.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at Suffix}[1]%
+\newcommand*\@nameauth at Suffix[1]%
   {\@nameauth at TrimSuffix#1\relax}
 %    \end{macrocode}
 % \end{macro}
@@ -3434,7 +3768,7 @@
 % \begin{macro}{\@nameauth at TestDot}
 % This macro, based on a snippet by \Name*[Uwe]{Lueck}, checks for a period at the end of its argument. It determines whether we need to call \cmd{\@nameauth at CheckDot} below.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at TestDot}[1]%
+\newcommand*\@nameauth at TestDot[1]%
 {%
   \def\TestDot##1.\TestEnd##2\TestStop{\TestPunct{##2}}%
   \def\TestPunct##1%
@@ -3448,7 +3782,7 @@
 % \begin{macro}{\@nameauth at CheckDot}
 % We assume that \cmd{\expandafter} precedes the invocation of \cmd{\@nameauth at CheckDot}, which only is called if the terminal character of the input is a period. We evaluate the lookahead \cmd{\@token} while keeping it on the list of input tokens.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at CheckDot}%
+\newcommand*\@nameauth at CheckDot%
   {\futurelet\@token\@nameauth at EvalDot}
 %    \end{macrocode}
 % \end{macro}
@@ -3456,7 +3790,7 @@
 % \begin{macro}{\@nameauth at EvalDot}
 %  If \cmd{\@token} is a full stop, we gobble the token.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at EvalDot}%
+\newcommand*\@nameauth at EvalDot%
   {\let\@period=.\ifx\@token\@period\expandafter\@gobble \fi}
 %    \end{macrocode}
 % \end{macro}
@@ -3472,7 +3806,7 @@
 % \changes{v2.5}{2016/04/06}{Add final formatting hooks and logic}
 % The dispatcher invokes the appropriate formatting hooks, depending on the Boolean values for first use, subsequent use, and name type. The first set of tests enables or disables formatting within \cmd{\AKA}. The second set of tests handle all the other naming macros in the name and front matter. The hooks have a local scope.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at FmtName}[1]%
+\newcommand*\@nameauth at FmtName[1]%
 {%
   \if at nameauth@InAKA
     \if at nameauth@AlwaysFormat
@@ -3529,13 +3863,14 @@
 % \changes{v2.0}{2015/11/11}{Redesigned tagging}
 % If the indexing flag is true, create an index entry, otherwise do nothing.
 %    \begin{macrocode}
-\newcommand*{\@nameauth at Index}[2]%
+\newcommand*\@nameauth at Index[2]%
 {%
   \def\cseq{#1}%
   \ifcsname\cseq!TAG\endcsname
     \ifcsname\cseq!PRE\endcsname
       \if at nameauth@DoIndex
-        \index{\csname\cseq!PRE\endcsname#2\csname\cseq!TAG\endcsname}%
+        \index%
+        {\csname\cseq!PRE\endcsname#2\csname\cseq!TAG\endcsname}%
       \fi
     \else
       \if at nameauth@DoIndex\index{#2\csname\cseq!TAG\endcsname}\fi
@@ -3562,6 +3897,7 @@
 % \changes{v2.4}{2016/03/15}{Define name CS after formatting; add token regs for hooks}
 % \changes{v2.41}{2016/03/17}{No local \cmd{\newtoks}}
 % \changes{v2.5}{2016/04/06}{Enable hooks better to query internal values}
+% \changes{v2.6}{2016/09/19}{Modularize indexing; account for page breaks; fix old syntax}
 % Here is the heart of the package. \Name*[Marc van]{Dongen} provided the basic structure. Parsing, indexing, and formatting are in discrete elements.
 %    \begin{macrocode}
 \newcommandx*\@nameauth at Name[3][1=\@empty, 3=\@empty]%
@@ -3585,7 +3921,7 @@
   \protected at edef\testc{#3}%
   \protected at edef\argc{\trim at spaces{#3}}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \@nameauth at toksa\expandafter{#1}%
   \@nameauth at toksb\expandafter{#2}%
@@ -3603,27 +3939,34 @@
     \fi
   \fi
 %    \end{macrocode}
-% If global caps. reversing, and commas are true, set the local flags true.
+% If global caps. reversing, and commas are true, set the local flags true. If reversing is true, print a full name.
 %    \begin{macrocode}
   \if at nameauth@AllCaps\@nameauth at AllThistrue\fi
   \if at nameauth@RevAll\@nameauth at RevThistrue\fi
   \if at nameauth@RevAllComma\@nameauth at RevThisCommatrue\fi
 %    \end{macrocode}
-% The code below handles non-breaking and regular spaces, as well as commas, in the text and the index by setting up which kind we want to use. These will be inserted as appropriate as the output is formatted.
+% Create an index entry before we print the name.
 %    \begin{macrocode}
-  \protected at edef\ISpace{\space}%
+  \IndexName[#1]{#2}[#3]%
+%    \end{macrocode}
+% The code below handles non-breaking and regular spaces, as well as commas, in the text, which are inserted only for Western names.
+%    \begin{macrocode}
   \protected at edef\Space{\space}%
   \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
-  \if at nameauth@AlwaysComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+  \ifx\arga\@empty\else
+    \if at nameauth@AlwaysComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@ShowComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@NoComma
+      \protected at edef\Space{\space}%
+      \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
+    \fi
   \fi
-  \if at nameauth@ShowComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
-  \fi
 %    \end{macrocode}
 % \clearpage\noindent
 % The section below parses any ``surnames'' into name/suffix pairs and figures out how to capitalize and reverse them as needed, storing the results for the main parser. 
@@ -3635,10 +3978,8 @@
     \let\CapShort\RawShort%
   \fi
   \protected at edef\AllCapShort{\@nameauth at AllCapRoot{#2}}%
-  \let\IndexShort\RawShort%
   \ifx\testb\testbr
-    \protected at edef\Suff{\@empty}%
-    \let\IndexSNN\RawShort%
+    \let\Suff\@empty%
     \let\Reversed\RawShort%
     \let\SNN\RawShort%
     \let\PrintShort\RawShort%
@@ -3654,7 +3995,6 @@
     \fi
   \else
     \protected at edef\Suff{\@nameauth at Suffix{#2}}%
-    \protected at edef\IndexSNN{\RawShort\ISpace\Suff}%
     \protected at edef\Reversed{\Suff\Space\RawShort}%
     \protected at edef\SNN{\RawShort\Space\Suff}%
     \if at nameauth@RevThis
@@ -3682,22 +4022,14 @@
     \fi
   \fi
 %    \end{macrocode}
-% Here we parse names. 
+% Now we begin to format names. 
 %    \begin{macrocode}
   \ifx\testa\@empty
     \ifx\testc\@empty
 %    \end{macrocode}
-% This is the section for momonyms, royal name/suffix pairs, and native Eastern names where comma-delimited suffixes are used. The first conditional below checks if we are trying to use an alternate name cross-reference as a main name (code !PN for pseudonym). If we are using a legitimate name, we generate an index entry.
+% \clearpage\noindent
+% This is the section for momonyms, royal name/suffix pairs, and native Eastern names where comma-delimited suffixes are used. If formatting is active, we handle the main matter names (code !MN). First we handle subsequent uses. We need \cmd{\expandafter} to enable the punctuation detection.
 %    \begin{macrocode}
-      \ifcsname\csb!PN\endcsname
-        \PackageWarning{nameauth}%
-        {macro \Name: Xref: #2 cannot be a page reference}%
-      \else
-        \@nameauth at Index{\csb}{\IndexSNN}%
-      \fi
-%    \end{macrocode}
-% If formatting is active, we handle first and subsequent formatting of names in the main matter (code !MN for main matter name). First we handle subsequent uses. We need \cmd{\expandafter} to enable the punctuation detection.
-%    \begin{macrocode}
       \if at nameauth@MainFormat
         \ifcsname\csb!MN\endcsname
           \if at nameauth@FirstName
@@ -3716,7 +4048,7 @@
           \@nameauth at FirstNamefalse%
         \else
 %    \end{macrocode}
-% Handle first uses.
+% Here we handle first uses.
 %    \begin{macrocode}
           \@nameauth at FirstFormattrue%
           \@nameauth at FullNametrue%
@@ -3731,8 +4063,8 @@
         \fi
       \else
 %    \end{macrocode}
-% \clearpage\noindent
-% Take care of names in the front matter (code !NF for non-formatted). First handle subsequent uses.
+% \noindent
+% If formatting is inactive we process names in the front matter (code !NF for non-formatted). First handle subsequent uses.
 %    \begin{macrocode}
         \ifcsname\csb!NF\endcsname
           \if at nameauth@FirstName
@@ -3751,7 +4083,8 @@
           \@nameauth at FirstNamefalse%
         \else
 %    \end{macrocode}
-% Handle first uses.
+% \clearpage\noindent
+% Handle first uses of front-matter names.
 %    \begin{macrocode}
           \@nameauth at FirstFormattrue%
           \@nameauth at FullNametrue%
@@ -3767,18 +4100,8 @@
       \fi
     \else
 %    \end{macrocode}
-% This is the section that handles the old syntax for royal names and native Eastern names. The first conditional below checks if we are trying to use an alternate name cross-reference as a main name (code !PN for pseudonym). If we are using a legitimate name, we generate an index entry.
+% This is the section that handles the old syntax for royal names and native Eastern names. If formatting is active, we handle first and subsequent formatting of names in the main matter (code !MN for main matter name). First we handle subsequent uses.
 %    \begin{macrocode}
-      \ifcsname\csbc!PN\endcsname
-        \PackageWarning{nameauth}%
-        {macro \Name: Xref: #2 #3 cannot be a page reference}%
-      \else
-        \@nameauth at Index{\csbc}{\IndexSNN\ISpace\argc}%
-      \fi
-%    \end{macrocode}
-% \clearpage\noindent
-% If formatting is active, we handle first and subsequent formatting of names in the main matter (code !MN for main matter name). First we handle subsequent uses.
-%    \begin{macrocode}
       \if at nameauth@MainFormat
         \ifcsname\csbc!MN\endcsname
           \if at nameauth@FirstName
@@ -3786,9 +4109,9 @@
           \fi
           \if at nameauth@FullName
             \if at nameauth@RevThis
-              \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+              \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
             \else
-              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
             \fi
           \else
             \if at nameauth@RevThis
@@ -3807,9 +4130,9 @@
           \@nameauth at FullNametrue%
           \@nameauth at FirstNamefalse%
           \if at nameauth@RevThis
-            \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+            \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
           \else
-            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
           \fi
           \csgdef{\csbc!MN}{}%
           \@nameauth at FullNamefalse%
@@ -3825,9 +4148,9 @@
           \fi
           \if at nameauth@FullName
             \if at nameauth@RevThis
-              \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+              \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
             \else
-              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
             \fi
           \else
             \if at nameauth@RevThis
@@ -3846,9 +4169,9 @@
           \@nameauth at FullNametrue%
           \@nameauth at FirstNamefalse%
           \if at nameauth@RevThis
-            \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+            \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
           \else
-            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
           \fi
           \csgdef{\csbc!NF}{}%
           \@nameauth at FullNamefalse%
@@ -3857,11 +4180,9 @@
     \fi
   \else
 %    \end{macrocode}
-% \clearpage\noindent
-% This is the section that handles Western names and non-native Eastern names. The first pair of conditionals handle the \texttt{comma} option, \cmd{\RevThisComma}, and alternate forenames. The next conditional below checks if we are trying to use an alternate name cross-reference as a main name (code !PN for pseudonym). If we are using a legitimate name, we generate an index entry.
+% This is the section that handles Western names and non-native Eastern names. The first pair of conditionals handle the \texttt{comma} option, \cmd{\RevThisComma}, and alternate forenames.
 %    \begin{macrocode}
     \if at nameauth@RevThisComma
-      \protected at edef\ISpace{,\space}%
       \protected at edef\Space{,\space}%
       \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
     \fi
@@ -3870,17 +4191,8 @@
     \else
       \let\FNN\argc%
     \fi
-    \ifcsname\csab!PN\endcsname
-      \PackageWarning{nameauth}%
-      {macro \Name: Xref: #1 #2 cannot be a page reference}%
-    \else
-      \ifx\Suff\@empty
-        \@nameauth at Index{\csab}{\IndexShort,\space\arga}%
-      \else
-        \@nameauth at Index{\csab}{\IndexShort,\space\arga,\space\Suff}%
-      \fi
-    \fi
 %    \end{macrocode}
+% \clearpage\noindent
 % If formatting is active, we handle first and subsequent formatting of names in the main matter (code !MN for main matter name). First we handle subsequent uses.
 %    \begin{macrocode}
     \if at nameauth@MainFormat
@@ -3902,7 +4214,6 @@
         \@nameauth at FirstNamefalse%
       \else
 %    \end{macrocode}
-% \clearpage\noindent
 % Handle first uses.
 %    \begin{macrocode}
         \@nameauth at FirstFormattrue%
@@ -3938,6 +4249,7 @@
         \@nameauth at FirstNamefalse%
       \else
 %    \end{macrocode}
+% \clearpage\noindent
 % Handle first uses.
 %    \begin{macrocode}
         \@nameauth at FirstFormattrue%
@@ -3954,7 +4266,10 @@
     \fi
   \fi
 %    \end{macrocode}
-% \clearpage\noindent
+% Make another index entry.
+%    \begin{macrocode}
+  \IndexName[#1]{#2}[#3]%
+%    \end{macrocode}
 % Reset all the ``per name'' Boolean values.
 %    \begin{macrocode}
   \@nameauth at Lockfalse%
@@ -3965,6 +4280,7 @@
   \@nameauth at Accentfalse%
   \@nameauth at AllThisfalse%
   \@nameauth at ShowCommafalse%
+  \@nameauth at NoCommafalse%
   \@nameauth at RevThisfalse%
   \@nameauth at RevThisCommafalse%
 %    \end{macrocode}
@@ -3978,6 +4294,7 @@
 }
 %    \end{macrocode}
 % \end{macro}
+% \clearpage
 %
 % \subsection{User Interface Macros}
 %
@@ -3986,7 +4303,7 @@
 % \changes{v0.94}{2012/02/15}{Added}
 % Tells the root capping macro to cap an unaccented first character.
 %    \begin{macrocode}
-\newcommand*{\CapThis}{\@nameauth at DoCapstrue}
+\newcommand*\CapThis{\@nameauth at DoCapstrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -3994,7 +4311,8 @@
 % \changes{v2.1}{2015/11/24}{Added}
 % Tells the root capping macro to cap an accented first Unicode character.
 %    \begin{macrocode}
-\newcommand*{\AccentCapThis}{\@nameauth at Accenttrue\@nameauth at DoCapstrue}
+\newcommand*\AccentCapThis%
+  {\@nameauth at Accenttrue\@nameauth at DoCapstrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4002,7 +4320,7 @@
 % \changes{v1.5}{2013/02/22}{Added}
 % Capitalize entire name.
 %    \begin{macrocode}
-\newcommand*{\CapName}{\@nameauth at AllThistrue}
+\newcommand*\CapName{\@nameauth at AllThistrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4010,7 +4328,7 @@
 % Turn off global surname capitalization.
 % \changes{v1.5}{2013/02/22}{Added}
 %    \begin{macrocode}
-\newcommand*{\AllCapsInactive}{\@nameauth at AllCapsfalse}
+\newcommand*\AllCapsInactive{\@nameauth at AllCapsfalse}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4018,7 +4336,7 @@
 % \changes{v1.5}{2013/02/22}{Added}
 % Turn on global surname capitalization.
 %    \begin{macrocode}
-\newcommand*{\AllCapsActive}{\@nameauth at AllCapstrue}
+\newcommand*\AllCapsActive{\@nameauth at AllCapstrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4027,7 +4345,7 @@
 % \changes{v1.5}{2013/02/22}{Added}
 % Reverse name order.
 %    \begin{macrocode}
-\newcommand*{\RevName}{\@nameauth at RevThistrue}
+\newcommand*\RevName{\@nameauth at RevThistrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4035,7 +4353,7 @@
 % Turn off global name reversing.
 % \changes{v1.5}{2013/02/22}{Added}
 %    \begin{macrocode}
-\newcommand*{\ReverseInactive}{\@nameauth at RevAllfalse}
+\newcommand*\ReverseInactive{\@nameauth at RevAllfalse}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4043,7 +4361,7 @@
 % Turn on global name reversing.
 % \changes{v1.5}{2013/02/22}{Added}
 %    \begin{macrocode}
-\newcommand*{\ReverseActive}{\@nameauth at RevAlltrue}
+\newcommand*\ReverseActive{\@nameauth at RevAlltrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4052,7 +4370,7 @@
 % \changes{v1.5}{2013/02/22}{Added}
 % Last name, comma, first name.
 %    \begin{macrocode}
-\newcommand*{\RevComma}%
+\newcommand*\RevComma%
   {\@nameauth at RevThistrue\@nameauth at RevThisCommatrue}
 %    \end{macrocode}
 % \end{macro}
@@ -4061,7 +4379,7 @@
 % Turn off global ``last-name-comma-first.''
 % \changes{v1.5}{2013/02/22}{Added}
 %    \begin{macrocode}
-\newcommand*{\ReverseCommaInactive}%
+\newcommand*\ReverseCommaInactive%
   {\@nameauth at RevAllfalse\@nameauth at RevAllCommafalse}
 %    \end{macrocode}
 % \end{macro}
@@ -4070,7 +4388,7 @@
 % Turn on global ``last-name-comma-first.''
 % \changes{v1.5}{2013/02/22}{Added}
 %    \begin{macrocode}
-\newcommand*{\ReverseCommaActive}%
+\newcommand*\ReverseCommaActive%
   {\@nameauth at RevAlltrue\@nameauth at RevAllCommatrue}
 %    \end{macrocode}
 % \end{macro}
@@ -4080,16 +4398,25 @@
 % \changes{v1.4}{2012/07/24}{Added}
 % Put comma between name and suffix one time.
 %    \begin{macrocode}
-\newcommand*{\ShowComma}{\@nameauth at ShowCommatrue}
+\newcommand*\ShowComma{\@nameauth at ShowCommatrue}
 %    \end{macrocode}
 % \end{macro}
 %
+% \begin{macro}{\NoComma}
+% \changes{v2.6}{2016/09/19}{Added}
+% Remove comma between name and suffix one time (with \texttt{comma} option)..
+%    \begin{macrocode}
+\newcommand*\NoComma{\@nameauth at NoCommatrue}
+%    \end{macrocode}
+% \end{macro}
+% \clearpage
+%
 % \noindent{\large\bfseries Typographic Formatting\,---\,Affixes}
 % \begin{macro}{\KeepAffix}
 % \changes{v1.9}{2015/07/09}{Added}
 % Trigger a name-suffix pair to be separated by a non-breaking space.
 %    \begin{macrocode}
-\newcommand*{\KeepAffix}{\@nameauth at NBSPtrue}
+\newcommand*\KeepAffix{\@nameauth at NBSPtrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4097,7 +4424,7 @@
 % \begin{macro}{\NamesInactive}
 % Switch to the ``non-formatted'' species of names.
 %    \begin{macrocode}
-\newcommand*{\NamesInactive}{\@nameauth at MainFormatfalse}
+\newcommand*\NamesInactive{\@nameauth at MainFormatfalse}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4104,7 +4431,7 @@
 % \begin{macro}{\NamesActive}
 % Switch to the ``formatted'' species of names.
 %    \begin{macrocode}
-\newcommand*{\NamesActive}{\@nameauth at MainFormattrue}
+\newcommand*\NamesActive{\@nameauth at MainFormattrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4132,7 +4459,7 @@
 % \changes{v0.94}{2012/02/15}{Added}
 % turn off global indexing of names.
 %    \begin{macrocode}
-\newcommand*{\IndexInactive}{\@nameauth at DoIndexfalse}
+\newcommand*\IndexInactive{\@nameauth at DoIndexfalse}
 %    \end{macrocode}
 % \end{macro}
 % 
@@ -4140,7 +4467,7 @@
 % \changes{v0.94}{2012/02/15}{Added}
 % turn on global indexing of names.
 %    \begin{macrocode}
-\newcommand*{\IndexActive}{\@nameauth at DoIndextrue}
+\newcommand*\IndexActive{\@nameauth at DoIndextrue}
 %    \end{macrocode}
 % \end{macro}
 %
@@ -4148,12 +4475,11 @@
 % \changes{v2.0}{2015/11/11}{Added}
 % Change the ``actual'' character from the default.
 %    \begin{macrocode}
-\newcommand*{\IndexActual}[1]%
+\newcommand*\IndexActual[1]%
   {\global\renewcommand*\@nameauth at Actual{#1}}
 %    \end{macrocode}
 % \end{macro}
 %
-% \clearpage
 % \noindent{\large\bfseries Main Naming Interface}
 % \begin{macro}{\Name}
 % \changes{v2.3}{2016/01/05}{Change to interface macro}
@@ -4187,6 +4513,7 @@
 \WithSuffix\def\FName*{\@nameauth at FirstNametrue\NameauthFName}
 %    \end{macrocode}
 % \end{macro}
+% \clearpage
 %
 % \noindent{\large\bfseries Alternate Names}
 % \begin{macro}{\AKA}
@@ -4199,6 +4526,7 @@
 % \changes{v2.3}{2016/01/05}{Expand starred mode}
 % \changes{v2.4}{2016/03/15}{Define name CS after formatting; add token regs for hooks}
 % \changes{v2.41}{2016/03/17}{No local \cmd{\newtoks}}
+% \changes{v2.6}{2016/09/19}{Fix index commas, old syntax}
 % \cmd{\AKA} prints an alternate name and creates index cross-references. It prevents multiple generation of cross-references and suppresses double periods.
 %    \begin{macrocode}
 \newcommandx*\AKA[5][1=\@empty, 3=\@empty, 5=\@empty]%
@@ -4226,7 +4554,7 @@
   \protected at edef\teste{#5}%
   \protected at edef\arge{\trim at spaces{#5}}%
   \def\csd{\@nameauth at Clean{#4}}%
-  \def\csde{\@nameauth at Clean{#4#5}}%
+  \def\csde{\@nameauth at Clean{#4,#5}}%
   \def\cscd{\@nameauth at Clean{#3!#4}}%
   \@nameauth at toksa\expandafter{#3}%
   \@nameauth at toksb\expandafter{#4}%
@@ -4260,25 +4588,28 @@
   \if at nameauth@RevAll\@nameauth at RevThistrue\fi
   \if at nameauth@RevAllComma\@nameauth at RevThisCommatrue\fi
 %    \end{macrocode}
-% The code below handles non-breaking and regular spaces, as well as commas, in the text and the index by setting up which kind we want to use. These will be inserted as appropriate as the output is formatted.
+% The code below handles non-breaking and regular spaces, as well as commas, in the text, which are inserted only for Western names.
 %    \begin{macrocode}
-  \protected at edef\ISpace{\space}%
   \protected at edef\Space{\space}%
   \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
-  \if at nameauth@AlwaysComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+  \ifx\argc\@empty\else
+    \if at nameauth@AlwaysComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@ShowComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@NoComma
+      \protected at edef\Space{\space}%
+      \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
+    \fi
   \fi
-  \if at nameauth@ShowComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
-  \fi
 %    \end{macrocode}
 %
 % \clearpage\noindent
-% The section below parses any ``surnames'' into name/suffix pairs and figures out how to capitalize and reverse them as needed, storing the results for the main parser. We have to handle several more combinations here than with \cmd{\Name} above.
+% The section below parses any ``surnames'' into name/suffix pairs and figures out how to capitalize and reverse them as needed, storing the results for the main parser. We have to handle several more combinations here than with \cmd{\@nameauth at Name} above.
 %    \begin{macrocode}
   \protected at edef\Shortb{\@nameauth at Root{#2}}%
   \protected at edef\Shortd{\@nameauth at Root{#4}}%
@@ -4290,13 +4621,13 @@
   \protected at edef\AllCapShort{\@nameauth at AllCapRoot{#4}}%
   \ifx\testb\testbr
     \let\SNNb\Shortb%
-    \protected at edef\Suffb{\@empty}%
+    \let\Suffb\@empty%
   \else
     \protected at edef\Suffb{\@nameauth at Suffix{#2}}%
-    \protected at edef\SNNb{\Shortb\ISpace\Suffb}%
+    \protected at edef\SNNb{\Shortb\space\Suffb}%
   \fi
   \ifx\testd\testdr
-    \protected at edef\Suffd{\@empty}%
+    \let\Suffd\@empty%
     \let\ISNNd\Shortd%
     \let\Reversed\Shortd%
     \let\SNNd\Shortd%
@@ -4310,7 +4641,7 @@
     \fi
   \else
     \protected at edef\Suffd{\@nameauth at Suffix{#4}}%
-    \protected at edef\ISNNd{\Shortd\ISpace\Suffd}%
+    \protected at edef\ISNNd{\Shortd\space\Suffd}%
     \protected at edef\Reversed{\Suffd\Space\Shortd}%
     \protected at edef\SNNd{\Shortd\Space\Suffd}%
     \if at nameauth@DoCaps
@@ -4324,7 +4655,7 @@
   \fi
 %    \end{macrocode}
 % \clearpage\noindent
-% Here we parse names. 
+% Here we begin to index and format names. 
 %    \begin{macrocode}
   \ifx\testc\@empty
     \ifx\teste\@empty
@@ -4362,7 +4693,6 @@
 % Print an appropriate version of the pseudonym (capped, reversed, etc.) in the text with no special formatting even if no cross-reference was generated in the index. Again, \cmd{\expandafter} is used for the punctuation detection.
 %    \begin{macrocode}
       \if at nameauth@RevThisComma
-        \protected at edef\ISpace{,\space}%
         \protected at edef\Space{,\space}%
         \if at nameauth@NBSP
           \protected at edef\Space{,\nobreakspace}%
@@ -4394,14 +4724,14 @@
           \else
             \ifx\testa\@empty
               \@nameauth at Index{\csde}%
-                {\ISNNd\ISpace\arge|see{\SNNb}}%
+                {\ISNNd\space\arge|see{\SNNb}}%
             \else
               \ifx\Suffb\@empty
                 \@nameauth at Index{\csde}%
-                  {\ISNNd\ISpace\arge|see{\SNNb,\space\arga}}%
+                  {\ISNNd\space\arge|see{\SNNb,\space\arga}}%
               \else
                 \@nameauth at Index{\csde}%
-                {\ISNNd\ISpace\arge|see{\Shortb,\space\arga,\space\Suffb}}%
+                {\ISNNd\space\arge|see{\Shortb,\space\arga,\space\Suffb}}%
               \fi
             \fi
           \fi
@@ -4411,7 +4741,6 @@
 % Print an appropriate version of the pseudonym (capped, reversed, etc.) in the text with no special formatting even if no cross-reference was generated in the index.
 %    \begin{macrocode}
       \if at nameauth@RevThisComma
-        \protected at edef\ISpace{,\space}%
         \protected at edef\Space{,\space}%
         \if at nameauth@NBSP
           \protected at edef\Space{,\nobreakspace}%
@@ -4424,7 +4753,7 @@
         \if at nameauth@RevThis
           \ex\@nameauth at FmtName\ex{\ex\arge\ex\Space\SNNd}%
         \else
-          \ex\@nameauth at FmtName\ex{\ex\SNNd\ex\space\arge}%
+          \ex\@nameauth at FmtName\ex{\ex\SNNd\ex\Space\arge}%
         \fi
       \fi
       \ifcsname\csde!PN\endcsname\else\csgdef{\csde!PN}{}\fi
@@ -4481,7 +4810,6 @@
 % Print an appropriate version of the pseudonym (capped, reversed, etc.) in the text with no special formatting even if no cross-reference was generated in the index.
 %    \begin{macrocode}
     \if at nameauth@RevThisComma
-      \protected at edef\ISpace{,\space}%
       \protected at edef\Space{,\space}%
       \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
     \fi
@@ -4514,6 +4842,7 @@
   \@nameauth at Accentfalse%
   \@nameauth at AllThisfalse%
   \@nameauth at ShowCommafalse%
+  \@nameauth at NoCommafalse%
   \@nameauth at RevThisfalse%
   \@nameauth at RevThisCommafalse%
 %    \end{macrocode}
@@ -4559,6 +4888,7 @@
 % \noindent{\large\bfseries Name Info Database: ``Text Tags''}
 % \begin{macro}{\NameAddInfo}
 % \changes{v2.4}{2016/03/15}{Added}
+% \changes{v2.6}{2016/09/19}{Fix old syntax}
 % This creates a control sequence and information associated with a given name, similar to an index tag, but usable in the body text.
 %    \begin{macrocode}
 \newcommandx\NameAddInfo[4][1=\@empty, 3=\@empty]%
@@ -4567,7 +4897,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and then we parse the arguments, defining the tag control sequences.
@@ -4596,6 +4926,7 @@
 %
 % \begin{macro}{\NameQueryInfo}
 % \changes{v2.4}{2016/03/15}{Added}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This prints the information created by \cmd{\NameAddInfo} if it exists.
 %    \begin{macrocode}
 \newcommandx\NameQueryInfo[3][1=\@empty, 3=\@empty]%
@@ -4604,7 +4935,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % \clearpage\noindent
@@ -4634,6 +4965,7 @@
 %
 % \begin{macro}{\NameClearInfo}
 % \changes{v2.4}{2016/03/15}{Added}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This deletes a text tag. It has the same structure as \cmd{\UntagName.}
 %    \begin{macrocode}
 \newcommandx*\NameClearInfo[3][1=\@empty, 3=\@empty]%
@@ -4642,7 +4974,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and then we parse the arguments, undefining the tag control sequences.
@@ -4672,11 +5004,12 @@
 %
 % \noindent{\large\bfseries Index Operations}
 % \begin{macro}{\IndexName}
-% \changes{v0.75}{2012/01/19}{Use current arguments}
+% \changes{v0.75}{2012/01/19}{Current arguments}
 % \changes{v0.85}{2012/02/05}{Add comma suppression}
 % \changes{v1.26}{2012/04/24}{Fix name suffix sorting}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input; trim spaces; redesign tagging}
-% This creates an index entry that is not already a pseudonym. It prints nothing. It does ensure consistent formatting.
+% \changes{v2.6}{2016/09/19}{No unwanted commas; fix old syntax}
+% This creates an index entry that is not already a pseudonym. It prints nothing. It does ensure consistent formatting. First we make copies of the arguments to test them and make parsing decisions.
 %    \begin{macrocode}
 \newcommandx*\IndexName[3][1=\@empty, 3=\@empty]%
 {%
@@ -4687,10 +5020,10 @@
   \protected at edef\testc{#3}%
   \protected at edef\argc{\trim at spaces{#3}}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
-% We make copies of the arguments to test them and make parsing decisions. Below we handle the types of spaces or commas that will be inserted into the index entries.
+%  Test for malformed input.
 %    \begin{macrocode}
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -4701,13 +5034,6 @@
       {macro \IndexName: Essential name malformed}%
     \fi
   \fi
-  \protected at edef\Space{\space}%
-  \if at nameauth@AlwaysComma
-    \protected at edef\Space{,\space}%
-  \fi
-  \if at nameauth@ShowComma
-    \protected at edef\Space{,\space}%
-  \fi
 %    \end{macrocode}
 % Now we deal with suffixes, and whether to handle them for Western or Eastern names.
 %    \begin{macrocode}
@@ -4714,14 +5040,14 @@
   \let\Short\testbr%
   \ifx\testb\testbr
     \let\SNN\Short%
-    \protected at edef\Suff{\@empty}%
+    \let\Suff\@empty%
   \else
     \protected at edef\Suff{\@nameauth at Suffix{#2}}%
-    \protected at edef\SNN{\Short\Space\Suff}%
+    \protected at edef\SNN{\Short\space\Suff}%
   \fi
 %    \end{macrocode}
 % \clearpage\noindent
-% We create the appropriate index entries with tags, letting the internal indexing macro sort that out. We do not create an index entry in the case that a name has been used as a pseudonym by \cmd{\AKA} or \cmd{\ExcludeName}.
+% We create the appropriate index entries with tags, letting the internal indexing macro sort that out. We do not create an index entry for a ``pseudonym'' control sequence (code !PN) created by \cmd{\AKA} or \cmd{\ExcludeName}.
 %    \begin{macrocode}
   \ifx\testa\@empty
     \ifx\testc\@empty
@@ -4736,7 +5062,7 @@
         \PackageWarning{nameauth}%
         {macro \IndexName: XRef: #2 #3 exists}%
       \else
-        \@nameauth at Index{\csbc}{\SNN\Space\argc}%
+        \@nameauth at Index{\csbc}{\SNN\space\argc}%
       \fi
     \fi
   \else
@@ -4751,7 +5077,6 @@
       \fi
     \fi
   \fi
-  \@nameauth at ShowCommafalse%
 }
 %    \end{macrocode}
 % \end{macro}
@@ -4761,7 +5086,8 @@
 % \changes{v1.2}{2012/02/25}{Added}
 % \changes{v1.9}{2015/07/09}{Fix cs collisions}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input; redesign tagging}
-% This creates an index entry tag that is applied to a name that is not already used as a cross reference via \cmd{\AKA}.
+% \changes{v2.6}{2016/09/19}{fix old syntax}
+% This creates an index entry tag that is applied to a name that is not already used as a \emph{see} reference.
 %    \begin{macrocode}
 \newcommandx*\TagName[4][1=\@empty, 3=\@empty]%
 {%
@@ -4769,7 +5095,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and then we parse the arguments, defining the tag control sequences.
@@ -4816,6 +5142,7 @@
 % \changes{v1.2}{2012/02/25}{Added}
 % \changes{v1.9}{2015/07/09}{Ensure global undef, fix cs collisions}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input; redesign tagging}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This deletes an index tag.
 %    \begin{macrocode}
 \newcommandx*\UntagName[3][1=\@empty, 3=\@empty]%
@@ -4824,7 +5151,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and then we parse the arguments, undefining the tag control sequences.
@@ -4854,6 +5181,7 @@
 % \clearpage\noindent
 % \begin{macro}{\PretagName}
 % \changes{v2.0}{2015/11/11}{Added}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This creates an index entry tag that is applied before a name.
 %    \begin{macrocode}
 \newcommandx*\PretagName[4][1=\@empty, 3=\@empty]%
@@ -4862,7 +5190,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and then we parse the arguments, defining the tag control sequences.
@@ -4905,6 +5233,7 @@
 % \changes{v0.94}{2012/02/15}{Added}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input}
 % \changes{v2.3}{2016/01/05}{Distinguish excluded names from regular aliases}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This macro prevents a name from being formatted or indexed, making \cmd{\Name} and friends print their arguments, emit a warning, and continue.
 %    \begin{macrocode}
 \newcommandx*\ExcludeName[3][1=\@empty, 3=\@empty]%
@@ -4913,7 +5242,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % \clearpage\noindent
@@ -4992,6 +5321,7 @@
 % \noindent{\large\bfseries Name Decisions}
 % \begin{macro}{\IfFrontName}
 % \changes{v2.3}{2016/01/05}{Added}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This macro expands one path if a front matter name exists, or else the other if it does not exist.
 %    \begin{macrocode}
 \newcommandx\IfFrontName[5][1=\@empty, 3=\@empty]%
@@ -5000,7 +5330,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and make parsing decisions. Below we parse the name arguments and create a pseudonym control sequence if it does not exist.
@@ -5030,6 +5360,7 @@
 % \clearpage\noindent
 % \begin{macro}{\IfMainName}
 % \changes{v2.3}{2016/01/05}{Added}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This macro expands one path if a main matter name exists, or else the other if it does not exist.
 %    \begin{macrocode}
 \newcommandx\IfMainName[5][1=\@empty, 3=\@empty]%
@@ -5038,7 +5369,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them and make parsing decisions. Below we parse the name arguments and create a pseudonym control sequence if it does not exist.
@@ -5069,6 +5400,7 @@
 % \begin{macro}{\IfAKA}
 % \changes{v2.3}{2016/01/05}{Added}
 % \changes{v2.4}{2016/03/15}{Redesign exclusion test}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This macro expands one path if a see-reference name exists, another if it does not exist, and a third if it is excluded.
 %    \begin{macrocode}
 \newcommandx\IfAKA[6][1=\@empty, 3=\@empty]%
@@ -5077,7 +5409,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \def\test{!}%
 %    \end{macrocode}
@@ -5121,6 +5453,7 @@
 % \changes{v1.9}{2015/07/09}{Ensure global undef}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input}
 % \changes{v2.3}{2016/01/05}{Changed to allow global or local behavior}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This undefines a control sequence to force the ``first use'' option of \cmd{\Name}.
 %    \begin{macrocode}
 \newcommandx*\ForgetName[3][1=\@empty, 3=\@empty]%
@@ -5129,7 +5462,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them.
@@ -5193,6 +5526,7 @@
 % \changes{v0.9}{2012/02/10}{Added}
 % \changes{v2.0}{2015/11/11}{Isolate malformed input}
 % \changes{v2.3}{2016/01/05}{Changed to allow global or local behavior}
+% \changes{v2.6}{2016/09/19}{fix old syntax}
 % This defines a control sequence to suppress the ``first use'' of \cmd{\Name}.
 %    \begin{macrocode}
 \newcommandx*\SubvertName[3][1=\@empty, 3=\@empty]%
@@ -5201,7 +5535,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
 %    \end{macrocode}
 % We make copies of the arguments to test them.
@@ -5256,13 +5590,15 @@
       \csgdef{\csab!MN}{}%
       \csgdef{\csab!NF}{}%
     \fi
-  \fi}
+  \fi
+}
 %    \end{macrocode}
 % \end{macro}
 %
 % \noindent{\large\bfseries Simplified Interface}
 % \begin{environment}{nameauth}
-% \changes{v1.6}{2013/03/10}{Added}
+% \changes{v1.6}{2013/03/10}{Environment added}
+% \changes{v1.9}{2015/07/09}{Bugfix}
 % \changes{v2.0}{2015/11/11}{Redesigned argument handling}
 % \changes{v2.11}{2015/11/29}{Bugfix}
 % \changes{v2.41}{2016/03/17}{No local \cmd{\newtoks}}

Modified: trunk/Master/texmf-dist/source/latex/nameauth/nameauth.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/nameauth/nameauth.ins	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/source/latex/nameauth/nameauth.ins	2016-09-22 21:36:19 UTC (rev 42128)
@@ -5,6 +5,7 @@
 %% The original source files were:
 %%
 %% nameauth.dtx  (with options: `install')
+%% 
 %% --------:| ----------------------------------------------------------------
 %% nameauth:| Name authority mechanism for consistency in text and index
 %%   Author:| Charles P. Schaum
@@ -16,6 +17,7 @@
 \keepsilent
 \askforoverwritefalse
 \preamble
+
 --------:| ----------------------------------------------------------------
 nameauth:| Name authority mechanism for consistency in text and index
   Author:| Charles P. Schaum
@@ -50,6 +52,7 @@
   \file{\jobname.sty}{\from{\jobname.dtx}{package}}
 }
 \endbatchfile
+
 %% 
 %% Copyright (C) 2016 by Charles P. Schaum <charles dot schaum at comcast dot net>
 %% 

Modified: trunk/Master/texmf-dist/tex/latex/nameauth/nameauth.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/nameauth/nameauth.sty	2016-09-22 21:01:58 UTC (rev 42127)
+++ trunk/Master/texmf-dist/tex/latex/nameauth/nameauth.sty	2016-09-22 21:36:19 UTC (rev 42128)
@@ -5,6 +5,7 @@
 %% The original source files were:
 %%
 %% nameauth.dtx  (with options: `package')
+%% 
 %% --------:| ----------------------------------------------------------------
 %% nameauth:| Name authority mechanism for consistency in text and index
 %%   Author:| Charles P. Schaum
@@ -14,9 +15,11 @@
 %% 
 \NeedsTeXFormat{LaTeX2e}[1999/12/01]
 \ProvidesPackage{nameauth}
-    [2016/04/06 v2.5 Name authority mechanism for consistency in text and index]
+    [2016/09/19 v2.6 Name authority mechanism for consistency in text and index]
+
 \newif\if at nameauth@AlwaysComma
 \newif\if at nameauth@ShowComma
+\newif\if at nameauth@NoComma
 \newif\if at nameauth@MainFormat
 \newif\if at nameauth@AKAFormat
 \newif\if at nameauth@LocalNames
@@ -40,13 +43,13 @@
 \newif\if at nameauth@InAKA
 \newif\if at nameauth@InName
 \newif\if at nameauth@Lock
-\newcommand*{\NamesFormat}{}
-\newcommand*{\MainNameHook}{}
-\newcommand*{\FrontNamesFormat}{}
-\newcommand*{\FrontNameHook}{}
-\newcommand*{\NameauthName}{\@nameauth at Name}
-\newcommand*{\NameauthLName}{\@nameauth at Name}
-\newcommand*{\NameauthFName}{\@nameauth at Name}
+\newcommand*\NamesFormat{}
+\newcommand*\MainNameHook{}
+\newcommand*\FrontNamesFormat{}
+\newcommand*\FrontNameHook{}
+\newcommand*\NameauthName{\@nameauth at Name}
+\newcommand*\NameauthLName{\@nameauth at Name}
+\newcommand*\NameauthFName{\@nameauth at Name}
 \newtoks\@nameauth at toksa%
 \newtoks\@nameauth at toksb%
 \newtoks\@nameauth at toksc%
@@ -71,10 +74,10 @@
 \DeclareOption{notreversed}%
   {\@nameauth at RevAllfalse\@nameauth at RevAllCommafalse}
 \DeclareOption{alwaysformat}{\@nameauth at AlwaysFormattrue}
-\DeclareOption{smallcaps}{\renewcommand*{\NamesFormat}{\scshape}}
-\DeclareOption{italic}{\renewcommand*{\NamesFormat}{\itshape}}
-\DeclareOption{boldface}{\renewcommand*{\NamesFormat}{\bfseries}}
-\DeclareOption{noformat}{\renewcommand*{\NamesFormat}{}}
+\DeclareOption{smallcaps}{\renewcommand*\NamesFormat{\scshape}}
+\DeclareOption{italic}{\renewcommand*\NamesFormat{\itshape}}
+\DeclareOption{boldface}{\renewcommand*\NamesFormat{\bfseries}}
+\DeclareOption{noformat}{\renewcommand*\NamesFormat{}}
 \ExecuteOptions%
   {nocomma,%
    mainmatter,%
@@ -90,12 +93,12 @@
 \RequirePackage{trimspaces}
 \RequirePackage{suffix}
 \RequirePackage{xargs}
-\newcommand*{\@nameauth at Clean}[1]%
+\newcommand*\@nameauth at Clean[1]%
   {\expandafter\zap at space\detokenize{#1} \@empty}
-\newcommand*{\@nameauth at Root}[1]%
+\newcommand*\@nameauth at Root[1]%
   {\@nameauth at TrimRoot#1,\@empty\relax}
 \def\@nameauth at TrimRoot#1,#2\relax{\trim at spaces{#1}}
-\newcommand*{\@nameauth at CapRoot}[1]%
+\newcommand*\@nameauth at CapRoot[1]%
 {%
   \ifxetex
     \@nameauth at CRii#1\relax%
@@ -113,12 +116,12 @@
 }
 \def\@nameauth at CRii#1#2\relax{\uppercase{#1}\@nameauth at Root{#2}}
 \def\@nameauth at CRiii#1#2#3\relax{\uppercase{#1#2}\@nameauth at Root{#3}}
-\newcommand*{\@nameauth at AllCapRoot}[1]%
+\newcommand*\@nameauth at AllCapRoot[1]%
   {\uppercase{\@nameauth at Root{#1}}}
-\newcommand*{\@nameauth at Suffix}[1]%
+\newcommand*\@nameauth at Suffix[1]%
   {\@nameauth at TrimSuffix#1\relax}
 \def\@nameauth at TrimSuffix#1,#2\relax{\trim at spaces{#2}}
-\newcommand*{\@nameauth at TestDot}[1]%
+\newcommand*\@nameauth at TestDot[1]%
 {%
   \def\TestDot##1.\TestEnd##2\TestStop{\TestPunct{##2}}%
   \def\TestPunct##1%
@@ -126,11 +129,11 @@
   \@nameauth at Punctfalse%
   \TestDot#1\TestEnd.\TestEnd\TestStop%
 }
-\newcommand*{\@nameauth at CheckDot}%
+\newcommand*\@nameauth at CheckDot%
   {\futurelet\@token\@nameauth at EvalDot}
-\newcommand*{\@nameauth at EvalDot}%
+\newcommand*\@nameauth at EvalDot%
   {\let\@period=.\ifx\@token\@period\expandafter\@gobble \fi}
-\newcommand*{\@nameauth at FmtName}[1]%
+\newcommand*\@nameauth at FmtName[1]%
 {%
   \if at nameauth@InAKA
     \if at nameauth@AlwaysFormat
@@ -171,13 +174,14 @@
   \fi
 }
 \newcommand*\@nameauth at Actual{@}
-\newcommand*{\@nameauth at Index}[2]%
+\newcommand*\@nameauth at Index[2]%
 {%
   \def\cseq{#1}%
   \ifcsname\cseq!TAG\endcsname
     \ifcsname\cseq!PRE\endcsname
       \if at nameauth@DoIndex
-        \index{\csname\cseq!PRE\endcsname#2\csname\cseq!TAG\endcsname}%
+        \index%
+        {\csname\cseq!PRE\endcsname#2\csname\cseq!TAG\endcsname}%
       \fi
     \else
       \if at nameauth@DoIndex\index{#2\csname\cseq!TAG\endcsname}\fi
@@ -204,7 +208,7 @@
   \protected at edef\testc{#3}%
   \protected at edef\argc{\trim at spaces{#3}}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \@nameauth at toksa\expandafter{#1}%
   \@nameauth at toksb\expandafter{#2}%
@@ -221,19 +225,23 @@
   \if at nameauth@AllCaps\@nameauth at AllThistrue\fi
   \if at nameauth@RevAll\@nameauth at RevThistrue\fi
   \if at nameauth@RevAllComma\@nameauth at RevThisCommatrue\fi
-  \protected at edef\ISpace{\space}%
+  \IndexName[#1]{#2}[#3]%
   \protected at edef\Space{\space}%
   \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
-  \if at nameauth@AlwaysComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+  \ifx\arga\@empty\else
+    \if at nameauth@AlwaysComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@ShowComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@NoComma
+      \protected at edef\Space{\space}%
+      \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
+    \fi
   \fi
-  \if at nameauth@ShowComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
-  \fi
   \protected at edef\RawShort{\@nameauth at Root{#2}}%
   \if at nameauth@DoCaps
     \protected at edef\CapShort{\@nameauth at CapRoot{#2}}%
@@ -241,10 +249,8 @@
     \let\CapShort\RawShort%
   \fi
   \protected at edef\AllCapShort{\@nameauth at AllCapRoot{#2}}%
-  \let\IndexShort\RawShort%
   \ifx\testb\testbr
-    \protected at edef\Suff{\@empty}%
-    \let\IndexSNN\RawShort%
+    \let\Suff\@empty%
     \let\Reversed\RawShort%
     \let\SNN\RawShort%
     \let\PrintShort\RawShort%
@@ -260,7 +266,6 @@
     \fi
   \else
     \protected at edef\Suff{\@nameauth at Suffix{#2}}%
-    \protected at edef\IndexSNN{\RawShort\ISpace\Suff}%
     \protected at edef\Reversed{\Suff\Space\RawShort}%
     \protected at edef\SNN{\RawShort\Space\Suff}%
     \if at nameauth@RevThis
@@ -289,12 +294,6 @@
   \fi
   \ifx\testa\@empty
     \ifx\testc\@empty
-      \ifcsname\csb!PN\endcsname
-        \PackageWarning{nameauth}%
-        {macro \Name: Xref: #2 cannot be a page reference}%
-      \else
-        \@nameauth at Index{\csb}{\IndexSNN}%
-      \fi
       \if at nameauth@MainFormat
         \ifcsname\csb!MN\endcsname
           \if at nameauth@FirstName
@@ -353,12 +352,6 @@
         \fi
       \fi
     \else
-      \ifcsname\csbc!PN\endcsname
-        \PackageWarning{nameauth}%
-        {macro \Name: Xref: #2 #3 cannot be a page reference}%
-      \else
-        \@nameauth at Index{\csbc}{\IndexSNN\ISpace\argc}%
-      \fi
       \if at nameauth@MainFormat
         \ifcsname\csbc!MN\endcsname
           \if at nameauth@FirstName
@@ -366,9 +359,9 @@
           \fi
           \if at nameauth@FullName
             \if at nameauth@RevThis
-              \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+              \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
             \else
-              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
             \fi
           \else
             \if at nameauth@RevThis
@@ -384,9 +377,9 @@
           \@nameauth at FullNametrue%
           \@nameauth at FirstNamefalse%
           \if at nameauth@RevThis
-            \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+            \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
           \else
-            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
           \fi
           \csgdef{\csbc!MN}{}%
           \@nameauth at FullNamefalse%
@@ -398,9 +391,9 @@
           \fi
           \if at nameauth@FullName
             \if at nameauth@RevThis
-              \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+              \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
             \else
-              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+              \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
             \fi
           \else
             \if at nameauth@RevThis
@@ -416,9 +409,9 @@
           \@nameauth at FullNametrue%
           \@nameauth at FirstNamefalse%
           \if at nameauth@RevThis
-            \ex\@nameauth at FmtName\ex{\ex\argc\ex\space\SNN}%
+            \ex\@nameauth at FmtName\ex{\ex\argc\ex\Space\SNN}%
           \else
-            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\space\argc}%
+            \ex\@nameauth at FmtName\ex{\ex\SNN\ex\Space\argc}%
           \fi
           \csgdef{\csbc!NF}{}%
           \@nameauth at FullNamefalse%
@@ -427,7 +420,6 @@
     \fi
   \else
     \if at nameauth@RevThisComma
-      \protected at edef\ISpace{,\space}%
       \protected at edef\Space{,\space}%
       \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
     \fi
@@ -436,16 +428,6 @@
     \else
       \let\FNN\argc%
     \fi
-    \ifcsname\csab!PN\endcsname
-      \PackageWarning{nameauth}%
-      {macro \Name: Xref: #1 #2 cannot be a page reference}%
-    \else
-      \ifx\Suff\@empty
-        \@nameauth at Index{\csab}{\IndexShort,\space\arga}%
-      \else
-        \@nameauth at Index{\csab}{\IndexShort,\space\arga,\space\Suff}%
-      \fi
-    \fi
     \if at nameauth@MainFormat
       \ifcsname\csab!MN\endcsname
         \if at nameauth@FirstName
@@ -506,6 +488,7 @@
       \fi
     \fi
   \fi
+  \IndexName[#1]{#2}[#3]%
   \@nameauth at Lockfalse%
   \@nameauth at InNamefalse%
   \@nameauth at FirstFormatfalse%
@@ -514,34 +497,37 @@
   \@nameauth at Accentfalse%
   \@nameauth at AllThisfalse%
   \@nameauth at ShowCommafalse%
+  \@nameauth at NoCommafalse%
   \@nameauth at RevThisfalse%
   \@nameauth at RevThisCommafalse%
   \fi
   \if at nameauth@Punct\expandafter\@nameauth at CheckDot\fi
 }
-\newcommand*{\CapThis}{\@nameauth at DoCapstrue}
-\newcommand*{\AccentCapThis}{\@nameauth at Accenttrue\@nameauth at DoCapstrue}
-\newcommand*{\CapName}{\@nameauth at AllThistrue}
-\newcommand*{\AllCapsInactive}{\@nameauth at AllCapsfalse}
-\newcommand*{\AllCapsActive}{\@nameauth at AllCapstrue}
-\newcommand*{\RevName}{\@nameauth at RevThistrue}
-\newcommand*{\ReverseInactive}{\@nameauth at RevAllfalse}
-\newcommand*{\ReverseActive}{\@nameauth at RevAlltrue}
-\newcommand*{\RevComma}%
+\newcommand*\CapThis{\@nameauth at DoCapstrue}
+\newcommand*\AccentCapThis%
+  {\@nameauth at Accenttrue\@nameauth at DoCapstrue}
+\newcommand*\CapName{\@nameauth at AllThistrue}
+\newcommand*\AllCapsInactive{\@nameauth at AllCapsfalse}
+\newcommand*\AllCapsActive{\@nameauth at AllCapstrue}
+\newcommand*\RevName{\@nameauth at RevThistrue}
+\newcommand*\ReverseInactive{\@nameauth at RevAllfalse}
+\newcommand*\ReverseActive{\@nameauth at RevAlltrue}
+\newcommand*\RevComma%
   {\@nameauth at RevThistrue\@nameauth at RevThisCommatrue}
-\newcommand*{\ReverseCommaInactive}%
+\newcommand*\ReverseCommaInactive%
   {\@nameauth at RevAllfalse\@nameauth at RevAllCommafalse}
-\newcommand*{\ReverseCommaActive}%
+\newcommand*\ReverseCommaActive%
   {\@nameauth at RevAlltrue\@nameauth at RevAllCommatrue}
-\newcommand*{\ShowComma}{\@nameauth at ShowCommatrue}
-\newcommand*{\KeepAffix}{\@nameauth at NBSPtrue}
-\newcommand*{\NamesInactive}{\@nameauth at MainFormatfalse}
-\newcommand*{\NamesActive}{\@nameauth at MainFormattrue}
+\newcommand*\ShowComma{\@nameauth at ShowCommatrue}
+\newcommand*\NoComma{\@nameauth at NoCommatrue}
+\newcommand*\KeepAffix{\@nameauth at NBSPtrue}
+\newcommand*\NamesInactive{\@nameauth at MainFormatfalse}
+\newcommand*\NamesActive{\@nameauth at MainFormattrue}
 \newcommand*\LocalNames{\global\@nameauth at LocalNamestrue}
 \newcommand*\GlobalNames{\global\@nameauth at LocalNamesfalse}
-\newcommand*{\IndexInactive}{\@nameauth at DoIndexfalse}
-\newcommand*{\IndexActive}{\@nameauth at DoIndextrue}
-\newcommand*{\IndexActual}[1]%
+\newcommand*\IndexInactive{\@nameauth at DoIndexfalse}
+\newcommand*\IndexActive{\@nameauth at DoIndextrue}
+\newcommand*\IndexActual[1]%
   {\global\renewcommand*\@nameauth at Actual{#1}}
 \def\Name{\NameauthName}
 \WithSuffix\def\Name*{\@nameauth at FullNametrue\NameauthLName}
@@ -566,7 +552,7 @@
   \protected at edef\teste{#5}%
   \protected at edef\arge{\trim at spaces{#5}}%
   \def\csd{\@nameauth at Clean{#4}}%
-  \def\csde{\@nameauth at Clean{#4#5}}%
+  \def\csde{\@nameauth at Clean{#4,#5}}%
   \def\cscd{\@nameauth at Clean{#3!#4}}%
   \@nameauth at toksa\expandafter{#3}%
   \@nameauth at toksb\expandafter{#4}%
@@ -592,19 +578,22 @@
   \if at nameauth@AllCaps\@nameauth at AllThistrue\fi
   \if at nameauth@RevAll\@nameauth at RevThistrue\fi
   \if at nameauth@RevAllComma\@nameauth at RevThisCommatrue\fi
-  \protected at edef\ISpace{\space}%
   \protected at edef\Space{\space}%
   \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
-  \if at nameauth@AlwaysComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+  \ifx\argc\@empty\else
+    \if at nameauth@AlwaysComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@ShowComma
+      \protected at edef\Space{,\space}%
+      \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
+    \fi
+    \if at nameauth@NoComma
+      \protected at edef\Space{\space}%
+      \if at nameauth@NBSP\protected at edef\Space{\nobreakspace}\fi
+    \fi
   \fi
-  \if at nameauth@ShowComma
-    \protected at edef\ISpace{,\space}%
-    \protected at edef\Space{,\space}%
-    \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
-  \fi
   \protected at edef\Shortb{\@nameauth at Root{#2}}%
   \protected at edef\Shortd{\@nameauth at Root{#4}}%
   \if at nameauth@DoCaps
@@ -615,13 +604,13 @@
   \protected at edef\AllCapShort{\@nameauth at AllCapRoot{#4}}%
   \ifx\testb\testbr
     \let\SNNb\Shortb%
-    \protected at edef\Suffb{\@empty}%
+    \let\Suffb\@empty%
   \else
     \protected at edef\Suffb{\@nameauth at Suffix{#2}}%
-    \protected at edef\SNNb{\Shortb\ISpace\Suffb}%
+    \protected at edef\SNNb{\Shortb\space\Suffb}%
   \fi
   \ifx\testd\testdr
-    \protected at edef\Suffd{\@empty}%
+    \let\Suffd\@empty%
     \let\ISNNd\Shortd%
     \let\Reversed\Shortd%
     \let\SNNd\Shortd%
@@ -635,7 +624,7 @@
     \fi
   \else
     \protected at edef\Suffd{\@nameauth at Suffix{#4}}%
-    \protected at edef\ISNNd{\Shortd\ISpace\Suffd}%
+    \protected at edef\ISNNd{\Shortd\space\Suffd}%
     \protected at edef\Reversed{\Suffd\Space\Shortd}%
     \protected at edef\SNNd{\Shortd\Space\Suffd}%
     \if at nameauth@DoCaps
@@ -677,7 +666,6 @@
         \fi
       \fi
       \if at nameauth@RevThisComma
-        \protected at edef\ISpace{,\space}%
         \protected at edef\Space{,\space}%
         \if at nameauth@NBSP
           \protected at edef\Space{,\nobreakspace}%
@@ -705,14 +693,14 @@
           \else
             \ifx\testa\@empty
               \@nameauth at Index{\csde}%
-                {\ISNNd\ISpace\arge|see{\SNNb}}%
+                {\ISNNd\space\arge|see{\SNNb}}%
             \else
               \ifx\Suffb\@empty
                 \@nameauth at Index{\csde}%
-                  {\ISNNd\ISpace\arge|see{\SNNb,\space\arga}}%
+                  {\ISNNd\space\arge|see{\SNNb,\space\arga}}%
               \else
                 \@nameauth at Index{\csde}%
-                {\ISNNd\ISpace\arge|see{\Shortb,\space\arga,\space\Suffb}}%
+                {\ISNNd\space\arge|see{\Shortb,\space\arga,\space\Suffb}}%
               \fi
             \fi
           \fi
@@ -719,7 +707,6 @@
         \fi
       \fi
       \if at nameauth@RevThisComma
-        \protected at edef\ISpace{,\space}%
         \protected at edef\Space{,\space}%
         \if at nameauth@NBSP
           \protected at edef\Space{,\nobreakspace}%
@@ -732,7 +719,7 @@
         \if at nameauth@RevThis
           \ex\@nameauth at FmtName\ex{\ex\arge\ex\Space\SNNd}%
         \else
-          \ex\@nameauth at FmtName\ex{\ex\SNNd\ex\space\arge}%
+          \ex\@nameauth at FmtName\ex{\ex\SNNd\ex\Space\arge}%
         \fi
       \fi
       \ifcsname\csde!PN\endcsname\else\csgdef{\csde!PN}{}\fi
@@ -781,7 +768,6 @@
       \fi
     \fi
     \if at nameauth@RevThisComma
-      \protected at edef\ISpace{,\space}%
       \protected at edef\Space{,\space}%
       \if at nameauth@NBSP\protected at edef\Space{,\nobreakspace}\fi
     \fi
@@ -811,6 +797,7 @@
   \@nameauth at Accentfalse%
   \@nameauth at AllThisfalse%
   \@nameauth at ShowCommafalse%
+  \@nameauth at NoCommafalse%
   \@nameauth at RevThisfalse%
   \@nameauth at RevThisCommafalse%
   \fi
@@ -828,7 +815,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -855,7 +842,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -882,7 +869,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -912,7 +899,7 @@
   \protected at edef\testc{#3}%
   \protected at edef\argc{\trim at spaces{#3}}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -923,20 +910,13 @@
       {macro \IndexName: Essential name malformed}%
     \fi
   \fi
-  \protected at edef\Space{\space}%
-  \if at nameauth@AlwaysComma
-    \protected at edef\Space{,\space}%
-  \fi
-  \if at nameauth@ShowComma
-    \protected at edef\Space{,\space}%
-  \fi
   \let\Short\testbr%
   \ifx\testb\testbr
     \let\SNN\Short%
-    \protected at edef\Suff{\@empty}%
+    \let\Suff\@empty%
   \else
     \protected at edef\Suff{\@nameauth at Suffix{#2}}%
-    \protected at edef\SNN{\Short\Space\Suff}%
+    \protected at edef\SNN{\Short\space\Suff}%
   \fi
   \ifx\testa\@empty
     \ifx\testc\@empty
@@ -951,7 +931,7 @@
         \PackageWarning{nameauth}%
         {macro \IndexName: XRef: #2 #3 exists}%
       \else
-        \@nameauth at Index{\csbc}{\SNN\Space\argc}%
+        \@nameauth at Index{\csbc}{\SNN\space\argc}%
       \fi
     \fi
   \else
@@ -966,7 +946,6 @@
       \fi
     \fi
   \fi
-  \@nameauth at ShowCommafalse%
 }
 \newcommandx*\TagName[4][1=\@empty, 3=\@empty]%
 {%
@@ -974,7 +953,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1016,7 +995,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1043,7 +1022,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1082,7 +1061,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1154,7 +1133,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1181,7 +1160,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1208,7 +1187,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \def\test{!}%
   \ifx\testb\@empty
@@ -1245,7 +1224,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1299,7 +1278,7 @@
   \protected at edef\testb{\trim at spaces{#2}}%
   \protected at edef\testc{#3}%
   \def\csb{\@nameauth at Clean{#2}}%
-  \def\csbc{\@nameauth at Clean{#2#3}}%
+  \def\csbc{\@nameauth at Clean{#2,#3}}%
   \def\csab{\@nameauth at Clean{#1!#2}}%
   \ifx\testb\@empty
     \PackageError{nameauth}%
@@ -1345,7 +1324,8 @@
       \csgdef{\csab!MN}{}%
       \csgdef{\csab!NF}{}%
     \fi
-  \fi}
+  \fi
+}
 \newenvironment{nameauth}{%
   \begingroup%
   \let\ex\expandafter%



More information about the tex-live-commits mailing list