почему добавление пакета `breqn` нарушает работу команды `etoolbox`?

почему добавление пакета `breqn` нарушает работу команды `etoolbox`?

Я пытался egreg хороший ответздесьв моем основном документе, и я обнаружил, что это не работает там. Оказалось, это потому, что я случайно использовал другой пакет, который breqnмне действительно нужен.

Я понятия не имею, почему breqnнарушается команда. Но вот MWE

\documentclass[10pt,notitlepage]{article}
\usepackage{etoolbox}%see https://tex.stackexchange.com/questions/257621
\makeatletter
\newcommand{\shellcommand}[1]{\@@input"|#1"}
\makeatother
\usepackage{breqn}
\newcounter{c}

\begin{document}
\setcounter{c}{\shellcommand{id -g}}
\arabic{c}
\end{document}

скомпилируйте с помощью lualatex -shell-esc foo.texи ошибка

(/usr/local/texlive/2015/texmf-dist/tex/latex/tools/calc.sty)) (./foo2.aux)
("|id -g!"id: invalid option -- '!'
Try 'id --help' for more information.

Runaway argument?
! Paragraph ended before \@calc@pre@scan was complete.
<to be read again> 
\par 
l.1

Обратите внимание на добавленный здесь дополнительный знак «!».

Теперь просто комментирую строку \usepackage{etoolbox}и снова компилирую, все работает и я получаю ожидаемый результат. Никаких ошибок.

Есть ли способ сохранить breqnи при этом иметь возможность использовать \shellcommandкоманду egreg?

При удалении breqnпакета и компиляции:

>lualatex -shell-esc foo2.tex 
This is LuaTeX, Version beta-0.80.0 (TeX Live 2015) (rev 5238) 
 \write18 enabled.
(./foo2.tex
LaTeX2e <2015/01/01> patch level 2
Babel <3.9l> and hyphenation patterns for 79 languages loaded.
(/usr/local/texlive/2015/texmf-dist/tex/latex/base/article.cls
Document Class: article 2014/09/29 v1.4h Standard LaTeX document class
(/usr/local/texlive/2015/texmf-dist/tex/latex/base/size10.clo))
(/usr/local/texlive/2015/texmf-dist/tex/latex/etoolbox/etoolbox.sty)
(./foo2.aux) ("|id -g") [1{/usr/local/texlive/2015/texmf-var/fonts/map/pdftex/up
dmap/pdftex.map}] (./foo2.aux))
 264 words of node memory still in use:
   2 hlist, 1 vlist, 1 rule, 2 glue, 40 glue_spec, 1 write nodes
   avail lists: 1:4,2:12,3:3,4:22,6:11,7:1,9:6
<</usr/local/texlive/2015/texmf-dist/fonts/type1/public/amsfonts/cm/cmr10.pfb>
Output written on foo2.pdf (1 page, 8298 bytes).
Transcript written on foo2.log.
>

Содержание PDF-файла 1000соответствует ожиданиям.

TL 2015 на Linux Mint 12.2

решение1

Ошибка не из-за breqn, а из-за calcтого, что автоматически загружается им. Это не имеет ничего общего ни с тем, ни с etoolboxдругим, поскольку \@@inputявляется примитивом \inputи определено в ядре LaTeX.

Вот действительно минимальный пример:

\documentclass{article}
\usepackage{calc}

\makeatletter
\newcommand{\shellcommand}[1]{\@@input"|#1"}
\makeatother

\newcounter{c}

\begin{document}

\setcounter{c}{\shellcommand{id -g}}
\arabic{c}

\end{document}

Проблема, похоже, в том, как calcпереопределяет \setcounter, поэтому -рассматривается как знак минуса и, конечно, все ломается. Вот обходной путь: сначала вычислите нужное вам значение и сохраните его во временном макросе.

\documentclass{article}
\usepackage{xparse,catchfile}
\usepackage{calc}

\makeatletter
\DeclareExpandableDocumentCommand{\shellcommand}{om}{%
  \IfNoValueTF{#1}
    {\@@input"|#2"}
    {\CatchFileEdef#1{"|#2"}{}}%
}
\makeatother

\newcounter{c}

\begin{document}

\shellcommand[\temp]{id -g}
\setcounter{c}{\temp}
\arabic{c}

\end{document}

На моем компьютере это печатает 20.

Связанный контент