Skip to content

Commit

Permalink
Merge pull request #1139 from mathjax/issue1137
Browse files Browse the repository at this point in the history
Fix incorrect handling of user-defined environments introduced in #856 (#1137)
  • Loading branch information
dpvc authored Oct 10, 2024
2 parents 117d0e8 + b40232a commit 9b6e85a
Showing 1 changed file with 17 additions and 14 deletions.
31 changes: 17 additions & 14 deletions ts/input/tex/newcommand/NewcommandMethods.ts
Original file line number Diff line number Diff line change
Expand Up @@ -257,18 +257,20 @@ const NewcommandMethods: { [key: string]: ParseMethod } = {
if (begin.getProperty('end') && parser.stack.env['closing'] === name) {
// @test Newenvironment Empty, Newenvironment Content
delete parser.stack.env['closing'];
if (edef && parser.stack.env['processing'] !== name) {
// Parse the commands in the end environment definition, and do the \end again
parser.stack.env['processing'] = name;
parser.string = ParseUtil.addArgs(
parser,
`${edef}\\end{${begin.getName()}}`,
parser.string.slice(parser.i)
);
parser.i = 0;
return null;
const beginN = parser.stack.global['beginEnv'] as number;
if (beginN) {
(parser.stack.global['beginEnv'] as number)--;
if (edef) {
// Parse the commands in the end environment definition.
let rest = parser.string.slice(parser.i);
parser.string = edef;
parser.i = 0;
parser.Parse();
// Reset to parsing the remainder of the expression.
parser.string = rest;
parser.i = 0;
}
}
delete parser.stack.env['processing'];
// Close this environment.
return parser.itemFactory.create('end').setProperty('name', name);
}
Expand All @@ -277,12 +279,12 @@ const NewcommandMethods: { [key: string]: ParseMethod } = {
const args: string[] = [];
if (def != null) {
// @test Newenvironment Optional, Newenvironment Arg Optional
const optional = parser.GetBrackets('\\begin{' + begin.getName() + '}');
const optional = parser.GetBrackets(`\\begin{${name}}`);
args.push(optional == null ? def : optional);
}
for (let i = args.length; i < n; i++) {
// @test Newenvironment Arg Optional
args.push(parser.GetArgument('\\begin{' + begin.getName() + '}'));
args.push(parser.GetArgument(`\\begin{${name}}`));
}
bdef = ParseUtil.substituteArgs(parser, args, bdef);
edef = ParseUtil.substituteArgs(parser, [], edef); // no args, but get errors for #n in edef
Expand All @@ -293,9 +295,10 @@ const NewcommandMethods: { [key: string]: ParseMethod } = {
parser.string.slice(parser.i)
);
parser.i = 0;
parser.stack.global['beginEnv'] = (parser.stack.global['beginEnv'] as number || 0) + 1;
return parser.itemFactory
.create('beginEnv')
.setProperty('name', begin.getName());
.setProperty('name', name);
},

Macro: BaseMethods.Macro,
Expand Down

0 comments on commit 9b6e85a

Please sign in to comment.