私はこの回答に基づいて、透過的な使用をパッケージ化するようbm
に努めています。siunitx
bm と siunitx の不一致
\documentclass{article}
\usepackage{bm,siunitx}
\newif\ifbm
\bmfalse
% New bm
\let\Oldbm\bm
\renewcommand{\bm}[1]{%
\bmtrue\Oldbm{#1}\bmfalse}
% New num
\let\Oldnum\num
\renewcommand{\num}[2][]{%
\ifbm\Oldbm[math-rm=\mathbf,#1]{#2}%
\else\Oldbm{#2}%
\fi}
% New SI
\let\OldSI\SI
\renewcommand{\SI}[2][]{%
\ifbm\OldSI[
math-rm=\mathbf,
number-unit-product={\mbox{\bfseries\,}},#1
]{#2}%
\else\OldSI{#2}%
\fi}
\begin{document}
$\bm{bob\num{5}\SI{30}{\km}}$
\end{document}
しかし、次のエラーメッセージが表示されます:
! Improper alphabetic constant.
<to be read again>
\reserved@d
l.25 $\bm{bob\num{5}}
$
答え1
コードにエラーがあります。たとえば、定義で の\Oldbm
代わりにを使用しています。また、引数は 2 つではなく 3 つあります。\Oldnum
\num
\SI
動作するコードは次のようになります。どちらのコマンドもオプションの引数を持ち、壊れやすいため、中括弧で保護する必要があることに注意してください。そのため、私見では、https://tex.stackexchange.com/a/416405/2388
\documentclass{article}
\usepackage{bm,siunitx}
\newif\ifbm
\bmfalse
% New bm
\let\Oldbm\bm
\renewcommand{\bm}[1]{%
\bmtrue\Oldbm{#1}\bmfalse}
% New num
\let\Oldnum\num
\renewcommand{\num}[2][]{%
\ifbm {\Oldnum[math-rm=\mathbf,#1]{#2}}%
\else \Oldnum[#1]{#2}%
\fi}
% New SI
\let\OldSI\SI
\renewcommand{\SI}[3][]{%
\ifbm{\OldSI[
math-rm=\mathbf,
number-unit-product={\mbox{\bfseries\,}},#1
]{#2}{#3}}%
\else\OldSI[#1]{#2}{#3}%
\fi}
\begin{document}
\num{5} \SI{30}{\km}
$\bm{bob}$
$\bm{{\num{5}}}$
$\bm{bob{\num{5}\SI{30}{\km}}}$
\end{document}