\documentclass[load-preamble+]{cnltx-doc} \usepackage{siunitx,setspace,pifont,hologo} \usepackage[spbmark]{altsubsup} \usepackage[noto]{newtxmath} \setcnltx { package = spbmark, title = the spbmark package, version = v1.46g, date = 2024/05/02, authors = Qu Yi, info = Customize superscript and subscript, email = toquyi@163.com, url = https://github.com/texno3/spbmark, abstract = { \pkg*{spbmark} provides three commands \cs{super}, \cs{sub} and \cs{supersub} to improve the layout of superscript and subscript which can be adjusted the relative position and format, and can be used in text and math mode. }, color-scheme = blue, title-format = \huge\bfseries\scshape, listings-options = {numbers = none,gobble = 2,lineskip = 1pt}, pre-output = {\parindent = 0em\setstretch{1.3}}, before-skip = \smallskipamount, after-skip = \smallskipamount } \makeatletter \newcommand{\splitmeta}[2]{\meta{#1}\texttt{,}\meta{#2}} \newcommand{\newsplitarg}[4][\splitmeta] { \newcommand{#2}[2] {\code{\textcolor{argument}{#3\textnormal{#1{##1}{##2}}#4}}} } \newcommand{\kvsplit}[3] { \item\code{\option{#1}\cnltx@isvalue\splitmarg{#2}{#3}} \cnltx@checkdefault{\hfill\newline} } \newsplitarg{\splitoarg}{[}{]} \newsplitarg{\splitmarg}{\{}{\}} \newsplitarg{\splitdarg}{(}{)} \newnote{\newtag}[1][New]{\textcolor{red}{\ding{73}\ #1}} \renewcommand{\emph}[1]{\textcolor{red}{#1}} \renewcommand{\cnltx@write@lastname}{} \makeatother \begin{document} \section{Macro package options} The following macro package options will redefine the script commands of the \LaTeX{} kernel. If you do not specify the values of boolean options, they default to \code{true}. These options can also be changed in the preamble area and main body using the global control command \cs{spbset}. \begin{options} \keychoice{text}{true,\fbox{false}}\newtag[Changed]% \cs{textsuperscript} and \cs{textsubscript} are equivalent to the \cs{super} and \cs{sub} commands. At this point, you can use the \cs{defspbstyle} command to define the style \code{textsp} and \code{textsb} to change the format of the text superscript and subscript. \keychoice{math}{true,\fbox{false}}\newtag[Changed]% \cs{sp} and \cs{sb} are equivalent to the \cs{super} and \cs{sub} commands. At this point, you can use the \cs{defspbstyle} command to define the style \code{mathsp} and \code{mathsb} to change the format of the math superscript and subscript. \keychoice{foot}{true,\fbox{false}}\newtag[Changed]% The format of the footnote mark match the superscript global move and format settings. At this point, you can use the \cs{defspbstyle} command to define the superscript style \code{fnmark} to change the format of the footnote mark. \begin{example}[code-only] \defspbstyle{textsp}{vmove=-1pt,cmd=\bfseries} \defspbstyle{mathsb}{hmove=0.5em} \defspbstyle{fnmark}{cmd=\small\color{red}} \end{example} \keychoice{both}{true,\fbox{false}} The values of \option{text} and \option{math} two options are \code{true} or \code{false} at the same time. \keychoice{all}{true,\fbox{false}} The values of \option{text}, \option{math} and \option{foot} three options are \code{true} or \code{false} at the same time. \begin{example}[code-only] \usepackage[both]{spbmark} \usepackage[text,foot=true]{spbmark} \spbset{all=false,math} \end{example} \end{options} \section{User commands} \label{sec:user commands} There are currently three commands to set superscript and subscript. Their format can be set temporarily using the optional parameters of the command, or set globally using a key-value list, see Section \ref{sec:global control interface}. \begin{commands} \command{super}[\sarg\oarg{kv list}\marg{content}\oarg{kv list}] This is a superscript output command. The two \meta{kv list} are equivalent. \command{sub}[\sarg\oarg{kv list}\marg{content}\oarg{kv list}] This is a subscript output command. The two \meta{kv list} are equivalent. When the horizontal movement distance of the marker is \emph{non-negative}, since the \cs{super} and \cs{sub} commands put the marker in a horizontal box, the horizontal position is staggered when using superscript and subscript \emph{consecutively}, which is a different mechanism than the sequential use of \code{\^{}} and \code{\_{}} symbols in math mode. The following three commands save the width of the previous marker, use it for negative move of the \option{hmove} option of the next marker, and provide the corresponding alignment. It should be noted that the following commands should save the longer width of the marker, that is, the longer width of the marker in the front, the shorter width of the marker in the back. This is due to the fact that horizontal movement uses a negative distance to leave the marker in a zero-width box state. \command{llastwd} Save the width of the previous marker and provide left alignment. This is actually the width of the previous marker, and is the same as the value of \cs{rlastwd} after the next command is used. \command{clastwd} Save the width of the previous marker and provide center alignment. \command{rlastwd} Save the width of the previous marker and provide right alignment. Actually this is the width of the next marker. \begin{example} 1A\super{bcd}\sub{e}B \\ 2A\super{bcd}\sub[hmove=-\llastwd]{e}B \\ 3A\sub{e}\super{bcd}[hmove=-\llastwd]B \\ 4A\super{bcd}\sub[hmove=-\clastwd]{e}B \\ 5A\super{bcd}\sub[hmove=-\rlastwd]{e}B \end{example} \command{supersub}[\sarg\oarg{kv list}\marg{super cont}\marg{sub cont}\oarg{kv list}] This is a command that outputs both superscript and subscript at the same time. You can also use the shorter command \cs{spb} instead of it. The two \meta{kv list} are equivalent. \command{superwd} Save the width of the superscript in the previous super-subscript command. \command{subwd} Save the width of the subscript in the previous super-subscript command. \command{maxwd} Save the maximum width of superscript and subscript in the previous super-subscript command. That is, it is the larger of the \cs{superwd} and \cs{subwd} commands. If horizontally move is negative and its absolute value is \emph{less} than the maximum width of the marker, then the marker overlaps the subsequent text. To avoid this use the command with the \emph{asterisk} parameter or adjust the horizontal distance with the marker length commands. \begin{example} \spbset{spvmove=5pt,vsep=1.8ex,spcmd=\color{blue}} 1A\super[hmove=-8pt]{super}B \\ 2A\supersub[hmove=-8pt]{examsuper}{sub}B \\ 3A\super*[hmove=-8pt]{super}B \\ 4A\supersub*[hmove=-8pt]{examsuper}{sub}B \\ 5A\super[hmove=-8pt]{super}\hspace{\dimexpr(\llastwd-8pt)}B \\ 6A\supersub[hmove=-8pt]{examsuper}{sub}\hspace{\dimexpr(\maxwd-8pt)}B \end{example} \command{defspbstyle}[\marg{style name}\marg{kv list}] Defines the style of the superscript or subscript used for the \option{style} option. \command{spbifmath}[\marg{math code}\marg{text code}] In some cases, \code{math} or \code{text} output modes require different code for format or move. This command can be used when using the \code{match} option or changing the output mode locally, whitch should be used in the move or format options. It can switch the corresponding code according to different output modes. \command{spbshortkv}[\marg{short opt}\marg{key value}] Converts any existing key-value pair to a shorthand option. The value of key \code{\#1} indicates that the shorthand option needs to be assigned a value. \begin{example} \spbshortkv{x}{sphmove=#1} \defspbstyle{fancy}{sbcmd=\color{blue},mode=math} \spbshortkv{mysb}{style=fancy} 1A\super[x=2pt]{b} \\ 2A\sub{b}[mysb] \end{example} \end{commands} The options common to \meta{kv list} of the three commands are as follows. They can also be used in \meta {key-value list} of the \cs{spbset} command. In this situation, in addition to \option{style} and \option{mode}, they will be set according to the type of the previous most recent command. \begin{options} \keyval{vmove}{fixed length}\Default{0pt} Vertical move of superscript or subscript. Represents the extra vertical distance \option{vsep} between superscript and subscript in super-subscript command. The vertical movement starts at the marker horizontal baseline position. \keyval{hmove}{fixed length}\Default{0pt} Horizontal move of superscript or subscript. Represents the \emph{common} move of superscript and subscript in super-subscript command. The starting point for horizontal movement is to the left of the marker. Moved values can be expressed mathematically: \begin{example} 1A\super{b}[vmove=0.4ex+4pt/2,hmove=2pt*3-11.5pt] \\ 2A\supersub[vsep={3pt,6pt-2bp}]{examsuper}{sub} \end{example} \keyval{cmd}{format cmds} The format commands of superscript or subscript. The last command can take a parameter, which accepts superscript or subscript. Represents the format of superscript and subscript in the superscript and subscript commands. \keyval{cmd+}{format cmds} Add code to the previous global superscript or subscript format commands. \keyval{height}{fixed length} The distance between the superscript or subscript baseline and the previous line. It is recommended that the superscript adjusts the height and the subscript adjusts the depth. \keyval{depth}{fixed length} The distance between the superscript or subscript baseline and the next line. \keyval{style}{style name} Use the \meta{style name} defined by the \cs{defspbstyle} command to make it work global or local. \keychoice{mode}{text,math,\fbox{match}} The mode of superscript or subscript output can be \code{text} or \code{math} mode. The \code{match} option automatically matches output modes according to the current mode. \keychoice{thiswd}{auto,\fbox{keep}}\newtag% Sets how the length of the this marker is handled after this command is used. If it is \code{keep}, the width of the previous marker remains the same. If it is \code{auto}, if the next token is a marker command and the upper or lower position is the \textcolor{red}{opposite} of the this command, the width of the this marker is maintained, otherwise the width automatically returns to \textcolor{red}{zero}. \begin{example} \spbset{sbhmove=-\llastwd,sbthiswd=auto,sbcmd=\color{red}} 1A\super{bcd}\sub[thiswd=keep]{e}Some texts\sub{e} \\ 3A\super{bcd}\sub{e}Some texts\sub{e} \\ 3A\sub{bcd}[thiswd=keep]\sub{e}Some texts\sub{e} \\ 4A\sub{bcd}\sub{e}Some texts\sub{e} \end{example} \keyval{regex}{regular expression}\newtag% After using the superscript or subscript command, this option is used to determine whether the \textcolor{red}{following} tokens match the \meta{regular expression}. If it does \textcolor{red}{not}, the width of the this marker returns to zero. \begin{example}[code-only] \newcommand{\mysp}[2][]{\super[regex=\c{mysb},#1]{#2}} \newcommand{\mysb}[2][]{\sub[regex=\c{mysp},#1]{#2}} \end{example} \end{options} \section{Global control interface} \label{sec:global control interface} \begin{commands} \command{spbset}[\marg{key-value list}] \pkg*{spbmark} uses the \cs{spbset} command to control the global default format of superscript and subscript. These options also apply to \meta{kv list} of the above commands. The values ​set by it will be overwritten by the optional parameters of the superscript and other commands. \end{commands} The following list of keys control the format both of superscript \emph{or} subscript. \begin{options} \keyval{spvmove}{fixed length}\Default{0pt} Extra vertical move of the superscript. \keyval{sphmove}{fixed length}\Default{0pt} Extra horizontal move of the superscript. \keyval{sbvmove}{fixed length}\Default{0pt} Extra vertical move of the subscript. \keyval{sbhmove}{fixed length}\Default{0pt} Extra horizontal move of the subscript. \opt{nohmove} Cancel the horizontal move of superscript and subscript at the same time. \opt{novmove} Cancel the vertical move of superscript and subscript at the same time. \keyval{spcmd}{format cmds} The format commands of superscript. The last command in the code can take an argument, which is a superscript. \keyval{spcmd+}{format cmds} Add code to the previous global superscript format commands. \keyval{sbcmd}{format cmds} The format commands of subscript. The last command in the code can take an argument, which is a subscript. \keyval{sbcmd+}{format cmds} Add code to the previous global subcript format commands. \keyval{spheight}{fixed length} The distance between the superscript baseline and the previous line. \keyval{spdepth}{fixed length} The distance between the superscript baseline and the next line. \keyval{sbheight}{fixed length} The distance between the subscript baseline and the previous line. \keyval{sbdepth}{fixed length} The distance between the subscript baseline and the next line. \keychoice{spthiswd}{auto,\fbox{keep}}\newtag% Width processing mode after using this superscript. See Section \ref{sec:user commands} for the meaning of this option. \keychoice{sbthiswd}{auto,\fbox{keep}}\newtag% Width processing mode after using this subscript. See Section \ref{sec:user commands} for the meaning of this option. \keyval{spregex}{regular expression}\newtag% After the superscript command is used, the regular expression rules of the following tokens are matched. See Section \ref{sec:user commands} for the meaning of this option. \keyval{sbregex}{regular expression}\newtag% After the subscript command is used, the regular expression rules of the following tokens are matched. See Section \ref{sec:user commands} for the meaning of this option. \end{options} If \option{sphmove} is positive, the superscript or subscript moves to the right, conversely it moves to the left. The positive direction of vertical offset of subscript and superscript is \textcolor{red}{opposite}. For superscript, if \option{spvmove} is positive, the superscript moves up, conversely it moves down. For subscript, if \option{spvmove} is positive, the subscript moves down, conversely it moves up. The following list of keys control the format of superscript \emph{and} subscript. \begin{options} \keyval{spbhmove}{fixed length}\Default{0pt} Extra vertical move of the superscript and the subscript. \kvsplit{spbcmd}{super cmds}{sub cmds} The format commands of superscript and subscript. The first part is in superscript format, and the latter part is in subscript format. They are separated by commas, or only the first part exists. \kvsplit{spbcmd+}{super cmds}{sub cmds} Add code to the previous global superscript and subscript format commands. \keyval{spbheight}{fixed length} The distance between the superscript baseline and the previous line. \keyval{spbdepth}{fixed length} The distance between the subscript baseline and the next line. \kvsplit{vsep}{super move}{sub move}\Default{0.6ex} The extra vertical distance between superscript and subscript. The front part is the movement amount of the superscript, and the latter part is the movement amount of the subscript. If only the front part means that both are vertically shifted by one-half of the current value. \keychoice{halign}{\fbox{l},c,r} The alignment of superscript and subscript, which contains \code{l}, \code{c}, and \code{r} parameters respectively for left, center, and right alignment. \end{options} \section{Examples of use} Here is a list of the three commands, please pay attention to the usage of optional parameters. Note when the horizontal move is negative, the starting point is at the right end of the mark. \begin{example} \defspbstyle{fancy}{cmd=\color{purple}} \spbset{spbcmd={\spbifmath{\mathtt}{\ttfamily},\color{blue}}} 1A\super[vmove=0.2ex,hmove=0.2em,cmd=\textcolor{red}]{exam}B \\ 2$A\sub[style=fancy,cmd+=\mathsf,mode=math]{exam}B$ \\ 3A\supersub[vsep=0.6ex,halign=c]{examsuper}{sub}B \\ 4A\super{c}[vmove=5pt,hmove=-5.5pt]B\sub[vmove=5pt,hmove=-5pt]{d}AB \\ 5A\super{c\super{d}}B \end{example} \subsection{siunitx} It can also be used with the \pkg*{siunitx} package to output superscript and subscript in the unit: \begin{example} \unit[mode=math]{kg.m/s\super[vmove=-1pt]{2}} \\ \qty[mode=text]{30}{A\supersub[hmove=1pt,cmd=\color{red}]{b}{c}} \\ \spbset{sbhmove=2pt}\unit[mode=text]{A\sub{b}} \end{example} \subsection{realscripts} If the OpenType text font you are using does not have optical sizes, the superscript and subscript may not appear correctly. Loading the \pkg*{realscripts} package before the \pkg*{spbmark} package fixes this behavior. \begin{example}[code-only] \usepackage{realscripts,spbmark} \end{example} \subsection{altsubsup} The \pkg*{altsubsup} package allows to write alternate superscript and subscript in math mode with \code{\^{}}\oarg{mark} and \code{\_{}}\oarg{mark} dimensions. When the package is loaded using the \code{spbmark} option, the superscript and subscript mechanism of \pkg*{spbmark} is used, you can use \cs{defspbstyle} to define its superscript style \code{altsup} and subscript style \code{altsub}. \begin{example} \defspbstyle{altsup}{sphmove=-\llastwd,spthiswd=auto,spvmove=1pt} $A_[bcd]^[e]B$ \end{example} \subsection{footnote} \pkg*{spbmark} also patches the footer markers for standard document class and \cls*{KOMA-Script}. You can format the footer markers by redefining the \cs{fnmarkfont} command. Note that extra horizontal move does not work with footnote markers. \section{Developer commands} If you need to use the original definitions of \cs{textsuperscript}, \cs{textsubscript}, \cs{sp} and \cs{sb} after using the \option{text} or \option{math} option, then you can use the following commands: \begin{commands} \command{spb@textsuperscript@save}[\marg{content}] Save the original definition of the \cs{textsuperscript} command, output superscript in the text mode. \command{spb@textsubscript@save}[\marg{content}] Save the original definition of the \cs{textsubscript} command, output subscript in the text mode. \command{spb@math@super@save}[\marg{content}] Save the original definition of the \cs{sp} command, output superscript in the math mode. \command{spb@math@sub@save}[\marg{content}] Save the original definition of the \cs{sb} command, output subscript in the math mode. \end{commands} \section{Known issues} At present, the vertical and horizontal move are effective for the unit commands in the \pkg*{siunitx} macro package. However, due to the special mechanism that the decimal point is not recognized correctly because it's converted to a space in the \cs*{unit} command, it's recommended to use \code{pt} as the unit of move. \appendix \nocite{*} \end{document}