%%
%% This is file `luamplib.sty',
%% generated with the docstrip utility.
%%
%% The original source files were:
%%
%% luamplib.dtx  (with options: `package')
%% 
%% See source file 'luamplib.dtx' for licencing and contact information.
%% 
\ifcsname ProvidesPackage\endcsname
  \NeedsTeXFormat{LaTeX2e}
  \ProvidesPackage{luamplib}
    [2025/02/18 v2.37.1 mplib package for LuaTeX]
\fi
\ifdefined\newluafunction\else
  \input ltluatex
\fi
\ifnum\outputmode=0
  \ifdefined\AddToHookNext
    \def\luamplibatnextshipout{\AddToHookNext{shipout/background}}
    \def\luamplibatfirstshipout{\AddToHook{shipout/firstpage}}
    \def\luamplibateveryshipout{\AddToHook{shipout/background}}
  \else
    \input atbegshi.sty
    \def\luamplibatnextshipout#1{\AtBeginShipoutNext{\AtBeginShipoutAddToBox{#1}}}
    \let\luamplibatfirstshipout\AtBeginShipoutFirst
    \def\luamplibateveryshipout#1{\AtBeginShipout{\AtBeginShipoutAddToBox{#1}}}
  \fi
\fi
\directlua{require("luamplib")}
\ifx\pdfoutput\undefined
  \let\pdfoutput\outputmode
\fi
\ifx\pdfliteral\undefined
  \protected\def\pdfliteral{\pdfextension literal}
\fi
\def\mplibsetformat#1{\directlua{luamplib.setformat("#1")}}
\ifnum\pdfoutput>0
  \let\mplibtoPDF\pdfliteral
\else
  \def\mplibtoPDF#1{\special{pdf:literal direct #1}}
  \ifcsname PackageInfo\endcsname
    \PackageInfo{luamplib}{only dvipdfmx is supported currently}
  \else
    \immediate\write-1{luamplib Info: only dvipdfmx is supported currently}
  \fi
\fi
\def\mplibforcehmode{\let\prependtomplibbox\leavevmode}
\def\mplibnoforcehmode{\let\prependtomplibbox\relax}
\mplibnoforcehmode
\def\mplibsetupcatcodes{%
  %catcode`\{=12 %catcode`\}=12
  \catcode`\#=12 \catcode`\^=12 \catcode`\~=12 \catcode`\_=12
  \catcode`\&=12 \catcode`\$=12 \catcode`\%=12 \catcode`\^^M=12
}
\def\mplibputtextbox#1{\vbox to 0pt{\vss\hbox to 0pt{\raise\dp#1\copy#1\hss}}}
\protected\def\usemplibgroup#1#{\usemplibgroupmain}
\def\usemplibgroupmain#1{%
  \mplibstarttousemplibgroup
  \csname luamplib.group.#1\endcsname
  \mplibstoptousemplibgroup
}
\def\mplibstarttousemplibgroup{\prependtomplibbox\hbox dir TLT\bgroup}
\def\mplibstoptousemplibgroup{\egroup}
\protected\def\mplibgroup#1{%
  \begingroup
  \def\MPllx{0}\def\MPlly{0}%
  \def\mplibgroupname{#1}%
  \mplibgroupgetnexttok
}
\def\mplibgroupgetnexttok{\futurelet\nexttok\mplibgroupbranch}
\def\mplibgroupskipspace{\afterassignment\mplibgroupgetnexttok\let\nexttok= }
\def\mplibgroupbranch{%
  \ifx [\nexttok
    \expandafter\mplibgroupopts
  \else
    \ifx\mplibsptoken\nexttok
      \expandafter\expandafter\expandafter\mplibgroupskipspace
    \else
      \let\mplibgroupoptions\empty
      \expandafter\expandafter\expandafter\mplibgroupmain
    \fi
  \fi
}
\def\mplibgroupopts[#1]{\def\mplibgroupoptions{#1}\mplibgroupmain}
\def\mplibgroupmain{\setbox\mplibscratchbox\hbox\bgroup\ignorespaces}
\protected\def\endmplibgroup{\egroup
  \directlua{ luamplib.registergroup(
    \the\mplibscratchbox, '\mplibgroupname', {\mplibgroupoptions}
  )}%
  \endgroup
}
{\def\:{\global\let\mplibsptoken= } \: }
\protected\def\mppattern#1{%
  \begingroup
  \def\mplibpatternname{#1}%
  \mplibpatterngetnexttok
}
\def\mplibpatterngetnexttok{\futurelet\nexttok\mplibpatternbranch}
\def\mplibpatternskipspace{\afterassignment\mplibpatterngetnexttok\let\nexttok= }
\def\mplibpatternbranch{%
  \ifx [\nexttok
    \expandafter\mplibpatternopts
  \else
    \ifx\mplibsptoken\nexttok
      \expandafter\expandafter\expandafter\mplibpatternskipspace
    \else
      \let\mplibpatternoptions\empty
      \expandafter\expandafter\expandafter\mplibpatternmain
    \fi
  \fi
}
\def\mplibpatternopts[#1]{%
  \def\mplibpatternoptions{#1}%
  \mplibpatternmain
}
\def\mplibpatternmain{%
  \setbox\mplibscratchbox\hbox\bgroup\ignorespaces
}
\protected\def\endmppattern{%
  \egroup
  \directlua{ luamplib.registerpattern(
    \the\mplibscratchbox, '\mplibpatternname', {\mplibpatternoptions}
  )}%
  \endgroup
}
\def\mpfiginstancename{@mpfig}
\protected\def\mpfig{%
  \begingroup
  \futurelet\nexttok\mplibmpfigbranch
}
\def\mplibmpfigbranch{%
  \ifx *\nexttok
    \expandafter\mplibprempfig
  \else
    \ifx [\nexttok
      \expandafter\expandafter\expandafter\mplibgobbleoptsmpfig
    \else
      \expandafter\expandafter\expandafter\mplibmainmpfig
    \fi
  \fi
}
\def\mplibgobbleoptsmpfig[#1]{\mplibmainmpfig}
\def\mplibmainmpfig{%
  \begingroup
  \mplibsetupcatcodes
  \mplibdomainmpfig
}
\long\def\mplibdomainmpfig#1\endmpfig{%
  \endgroup
  \directlua{
    local legacy = luamplib.legacyverbatimtex
    local everympfig = luamplib.everymplib["\mpfiginstancename"] or ""
    local everyendmpfig = luamplib.everyendmplib["\mpfiginstancename"] or ""
    luamplib.legacyverbatimtex = false
    luamplib.everymplib["\mpfiginstancename"] = ""
    luamplib.everyendmplib["\mpfiginstancename"] = ""
    luamplib.process_mplibcode(
    "beginfig(0) "..everympfig.." "..[===[\unexpanded{#1}]===].." "..everyendmpfig.." endfig;",
    "\mpfiginstancename")
    luamplib.legacyverbatimtex = legacy
    luamplib.everymplib["\mpfiginstancename"] = everympfig
    luamplib.everyendmplib["\mpfiginstancename"] = everyendmpfig
  }%
  \endgroup
}
\def\mplibprempfig#1{%
  \begingroup
  \mplibsetupcatcodes
  \mplibdoprempfig
}
\long\def\mplibdoprempfig#1\endmpfig{%
  \endgroup
  \directlua{
    local legacy = luamplib.legacyverbatimtex
    local everympfig = luamplib.everymplib["\mpfiginstancename"]
    local everyendmpfig = luamplib.everyendmplib["\mpfiginstancename"]
    luamplib.legacyverbatimtex = false
    luamplib.everymplib["\mpfiginstancename"] = ""
    luamplib.everyendmplib["\mpfiginstancename"] = ""
    luamplib.process_mplibcode([===[\unexpanded{#1}]===],"\mpfiginstancename")
    luamplib.legacyverbatimtex = legacy
    luamplib.everymplib["\mpfiginstancename"] = everympfig
    luamplib.everyendmplib["\mpfiginstancename"] = everyendmpfig
  }%
  \endgroup
}
\protected\def\endmpfig{endmpfig}
\unless\ifcsname ver@luamplib.sty\endcsname
  \def\mplibcodegetinstancename[#1]{\xdef\currentmpinstancename{#1}\mplibcodeindeed}
  \protected\def\mplibcode{%
    \begingroup
    \futurelet\nexttok\mplibcodebranch
  }
  \def\mplibcodebranch{%
    \ifx [\nexttok
      \expandafter\mplibcodegetinstancename
    \else
      \global\let\currentmpinstancename\empty
      \expandafter\mplibcodeindeed
    \fi
  }
  \def\mplibcodeindeed{%
    \begingroup
    \mplibsetupcatcodes
    \mplibdocode
  }
  \long\def\mplibdocode#1\endmplibcode{%
    \endgroup
    \directlua{luamplib.process_mplibcode([===[\unexpanded{#1}]===],"\currentmpinstancename")}%
    \endgroup
  }
  \protected\def\endmplibcode{endmplibcode}
\else
  \newenvironment{mplibcode}[1][]{%
    \xdef\currentmpinstancename{#1}%
    \mplibtmptoks{}\ltxdomplibcode
  }{}
  \def\ltxdomplibcode{%
    \begingroup
    \mplibsetupcatcodes
    \ltxdomplibcodeindeed
  }
  \def\mplib@mplibcode{mplibcode}
  \long\def\ltxdomplibcodeindeed#1\end#2{%
    \endgroup
    \mplibtmptoks\expandafter{\the\mplibtmptoks#1}%
    \def\mplibtemp@a{#2}%
    \ifx\mplib@mplibcode\mplibtemp@a
      \directlua{luamplib.process_mplibcode([===[\the\mplibtmptoks]===],"\currentmpinstancename")}%
      \end{mplibcode}%
    \else
      \mplibtmptoks\expandafter{\the\mplibtmptoks\end{#2}}%
      \expandafter\ltxdomplibcode
    \fi
  }
\fi
\def\mplibshowlog#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.showlog = true
    else
      luamplib.showlog = false
    end
}}
\def\mpliblegacybehavior#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.legacyverbatimtex = true
    else
      luamplib.legacyverbatimtex = false
    end
}}
\def\mplibverbatim#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.verbatiminput = true
    else
      luamplib.verbatiminput = false
    end
}}
\newtoks\mplibtmptoks
\ifcsname ver@luamplib.sty\endcsname
  \protected\def\everymplib{%
    \begingroup
    \mplibsetupcatcodes
    \mplibdoeverymplib
  }
  \protected\def\everyendmplib{%
    \begingroup
    \mplibsetupcatcodes
    \mplibdoeveryendmplib
  }
  \newcommand\mplibdoeverymplib[2][]{%
    \endgroup
    \directlua{
      luamplib.everymplib["#1"] = [===[\unexpanded{#2}]===]
    }%
  }
  \newcommand\mplibdoeveryendmplib[2][]{%
    \endgroup
    \directlua{
      luamplib.everyendmplib["#1"] = [===[\unexpanded{#2}]===]
    }%
  }
\else
  \def\mplibgetinstancename[#1]{\def\currentmpinstancename{#1}}
  \protected\def\everymplib#1#{%
    \ifx\empty#1\empty \mplibgetinstancename[]\else \mplibgetinstancename#1\fi
    \begingroup
    \mplibsetupcatcodes
    \mplibdoeverymplib
  }
  \long\def\mplibdoeverymplib#1{%
    \endgroup
    \directlua{
      luamplib.everymplib["\currentmpinstancename"] = [===[\unexpanded{#1}]===]
    }%
  }
  \protected\def\everyendmplib#1#{%
    \ifx\empty#1\empty \mplibgetinstancename[]\else \mplibgetinstancename#1\fi
    \begingroup
    \mplibsetupcatcodes
    \mplibdoeveryendmplib
  }
  \long\def\mplibdoeveryendmplib#1{%
    \endgroup
    \directlua{
      luamplib.everyendmplib["\currentmpinstancename"] = [===[\unexpanded{#1}]===]
    }%
  }
\fi
\def\mpdim#1{ runscript("luamplibdimen{#1}") }
\def\mpcolor#1#{\domplibcolor{#1}}
\def\domplibcolor#1#2{ runscript("luamplibcolor{#1{#2}}") }
\def\mplibnumbersystem#1{\directlua{
  local t = "#1"
  if t == "binary" then t = "decimal" end
  luamplib.numbersystem = t
}}
\def\mplibmakenocache#1{\mplibdomakenocache #1,*,}
\def\mplibdomakenocache#1,{%
  \ifx\empty#1\empty
    \expandafter\mplibdomakenocache
  \else
    \ifx*#1\else
      \directlua{luamplib.noneedtoreplace["#1.mp"]=true}%
      \expandafter\expandafter\expandafter\mplibdomakenocache
    \fi
  \fi
}
\def\mplibcancelnocache#1{\mplibdocancelnocache #1,*,}
\def\mplibdocancelnocache#1,{%
  \ifx\empty#1\empty
    \expandafter\mplibdocancelnocache
  \else
    \ifx*#1\else
      \directlua{luamplib.noneedtoreplace["#1.mp"]=false}%
      \expandafter\expandafter\expandafter\mplibdocancelnocache
    \fi
  \fi
}
\def\mplibcachedir#1{\directlua{luamplib.getcachedir("\unexpanded{#1}")}}
\def\mplibtextextlabel#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.textextlabel = true
    else
      luamplib.textextlabel = false
    end
}}
\def\mplibcodeinherit#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.codeinherit = true
    else
      luamplib.codeinherit = false
    end
}}
\def\mplibglobaltextext#1{\directlua{
    local s = string.lower("#1")
    if s == "enable" or s == "true" or s == "yes" then
      luamplib.globaltextext = true
    else
      luamplib.globaltextext = false
    end
}}
\ifx\mplibscratchbox\undefined \newbox\mplibscratchbox \fi
\def\mplibstarttoPDF#1#2#3#4{%
  \prependtomplibbox
  \hbox dir TLT\bgroup
  \xdef\MPllx{#1}\xdef\MPlly{#2}%
  \xdef\MPurx{#3}\xdef\MPury{#4}%
  \xdef\MPwidth{\the\dimexpr#3bp-#1bp\relax}%
  \xdef\MPheight{\the\dimexpr#4bp-#2bp\relax}%
  \parskip0pt%
  \leftskip0pt%
  \parindent0pt%
  \everypar{}%
  \setbox\mplibscratchbox\vbox\bgroup
  \noindent
}
\def\mplibstoptoPDF{%
  \par
  \egroup %
  \setbox\mplibscratchbox\hbox %
    {\hskip-\MPllx bp%
     \raise-\MPlly bp%
     \box\mplibscratchbox}%
  \setbox\mplibscratchbox\vbox to \MPheight
    {\vfill
     \hsize\MPwidth
     \wd\mplibscratchbox0pt%
     \ht\mplibscratchbox0pt%
     \dp\mplibscratchbox0pt%
     \box\mplibscratchbox}%
  \wd\mplibscratchbox\MPwidth
  \ht\mplibscratchbox\MPheight
  \box\mplibscratchbox
  \egroup
}
\def\mplibtextext#1#2#3#4#5{%
  \begingroup
  \setbox\mplibscratchbox\hbox
    {\font\temp=#1 at #2bp%
     \temp
     #3}%
  \setbox\mplibscratchbox\hbox
    {\hskip#4 bp%
     \raise#5 bp%
     \box\mplibscratchbox}%
  \wd\mplibscratchbox0pt%
  \ht\mplibscratchbox0pt%
  \dp\mplibscratchbox0pt%
  \box\mplibscratchbox
  \endgroup
}
\openin0=luamplib.cfg
\ifeof0 \else
  \closein0
  \input luamplib.cfg
\fi
\def\luamplibtagtextbegin#1{}
\let\luamplibtagtextend\relax
\let\luamplibtagasgroupbegin\relax
\let\luamplibtagasgroupend\relax
\ifcsname SuspendTagging\endcsname\else\endinput\fi
\ifcsname ver@tagpdf.sty\endcsname \else
  \ExplSyntaxOn
  \keys_define:nn{luamplib/notag}
    {
      ,alt          .code:n = { }
      ,actualtext   .code:n = { }
      ,artifact     .code:n = { }
      ,text         .code:n = { }
      ,correct-BBox .code:n = { }
      ,tag          .code:n = { }
      ,debug        .code:n = { }
      ,instance     .code:n = { \tl_gset:Nn \currentmpinstancename {#1} }
      ,instancename .meta:n = { instance = {#1} }
      ,unknown      .code:n = { \tl_gset:Ne \currentmpinstancename {\l_keys_key_str} }
    }
  \RenewDocumentCommand\mplibcode{O{}}
    {
      \tl_gset_eq:NN \currentmpinstancename \c_empty_tl
      \keys_set:ne{luamplib/notag}{#1}
      \mplibtmptoks{}\ltxdomplibcode
    }
  \ExplSyntaxOff
  \let\mplibalttext \luamplibtagtextbegin
  \let\mplibactualtext \mplibalttext
  \endinput\fi
\let\mplibstarttoPDForiginal\mplibstarttoPDF
\let\mplibstoptoPDForiginal\mplibstoptoPDF
\let\mplibputtextboxoriginal\mplibputtextbox
\let\mplibstarttousemplibgrouporiginal\mplibstarttousemplibgroup
\let\mplibstoptousemplibgrouporiginal\mplibstoptousemplibgroup
\ExplSyntaxOn
\tl_new:N \l__luamplib_tag_alt_tl
\tl_new:N \l__luamplib_tag_alt_dflt_tl
\tl_set:Nn\l__luamplib_tag_alt_dflt_tl {metapost~figure}
\tl_new:N \l__luamplib_tag_actual_tl
\tl_new:N \l__luamplib_tag_struct_tl
\tl_set:Nn\l__luamplib_tag_struct_tl {Figure}
\bool_new:N \l__luamplib_tag_usetext_bool
\bool_new:N \l__luamplib_tag_BBox_bool
\bool_set_true:N \l__luamplib_tag_BBox_bool
\seq_new:N\l__luamplib_tag_bboxcorr_seq
\bool_new:N\l__luamplib_tag_bboxcorr_bool
\bool_new:N \l__luamplib_tag_debug_bool
\tl_new:N \l__luamplib_BBox_label_tl
\tl_new:N \l__luamplib_BBox_llx_tl
\tl_new:N \l__luamplib_BBox_lly_tl
\tl_new:N \l__luamplib_BBox_urx_tl
\tl_new:N \l__luamplib_BBox_ury_tl
\cs_set_nopar:Npn \luamplibtagtextbegin #1
{
  \bool_if:NTF \l__luamplib_tag_usetext_bool
  {
    \tag_mc_end_push:
    \tag_mc_begin:n{}
    \tag_struct_begin:n{tag=NonStruct,stash}
    \def\myboxnum{#1}
    \edef\mystructnum{\tag_get:n{struct_num}}
    \edef\statebeforebox{\inteval{\tag_get:n{struct_counter}+\tag_get:n{mc_counter}}}
  }
  {
    \tag_if_active:TF
      { \bool_set_true:N \l_tmpa_bool }
      { \bool_set_false:N \l_tmpa_bool }
    \SuspendTagging{luamplib.textext}
  }
}
\cs_set_nopar:Npn \luamplibtagtextend
{
  \bool_if:NTF \l__luamplib_tag_usetext_bool
  {
    \edef\stateafterbox{\inteval{\tag_get:n{struct_counter}+\tag_get:n{mc_counter}}}
    \tag_if_active:T {
      \int_compare:nNnTF
      {\stateafterbox}
      =
      {\statebeforebox}
      { \cs_gset_nopar:cpe {luamplib.notagbox.\myboxnum} {\mystructnum} }
      { \cs_gset_nopar:cpe {luamplib.tagbox.\myboxnum} {\mystructnum} }
    }
    \tag_struct_end:
    \tag_mc_end:
    \tag_mc_begin_pop:n{}
  }
  {
    \bool_if:NT \l_tmpa_bool
      { \ResumeTagging{luamplib.textext} }
  }
}
\msg_new:nnn {luamplib}{figure-text-reuse}
{
  textext~box~#1~probably~is~incorrectly~tagged.\\
  Reusing~a~box~in~text-keyed~figures~is~strongly~discouraged.
}
\cs_set_nopar:Npn \mplibputtextbox #1
{
  \vbox to 0pt{\vss\hbox to 0pt{%
    \bool_if:NTF \l__luamplib_tag_usetext_bool
    {
      \ResumeTagging{luamplib.puttextbox}
      \tag_mc_end:
      \cs_if_exist:cTF {luamplib.tagbox.#1}
      {
        \tag_struct_use_num:n {\csname luamplib.tagbox.#1\endcsname}
        \raise\dp#1\copy#1
      }
      {
        \cs_if_exist:cF {luamplib.notagbox.#1}
        {
          \msg_warning:nnn{luamplib}{figure-text-reuse}{#1}
        }
        \tag_mc_begin:n{}
        \int_set:Nn \l_tmpa_int {#1}
        \tag_mc_reset_box:N \l_tmpa_int
        \raise\dp#1\copy#1
        \tag_mc_end:
      }
      \tag_mc_begin:n{artifact}
    }
    {
      \int_set:Nn \l_tmpa_int {#1}
      \tag_mc_reset_box:N \l_tmpa_int
      \raise\dp#1\copy#1
    }
  \hss}}
}
\cs_new_nopar:Npn \__luamplib_tagging_begin_figure:
{
  \tag_if_active:T
  {
    \tag_mc_end_push:
    \tl_if_empty:NT\l__luamplib_tag_alt_tl
    {
      \msg_warning:nne{luamplib}{alt-text-missing}{\l__luamplib_tag_alt_dflt_tl}
      \tl_set:Ne\l__luamplib_tag_alt_tl {\l__luamplib_tag_alt_dflt_tl}
    }
    \tag_struct_begin:n
    {
      tag=\l__luamplib_tag_struct_tl,
      alt=\l__luamplib_tag_alt_tl,
    }
    \tag_mc_begin:n{}
  }
}
\cs_new_nopar:Npn \__luamplib_tagging_end_figure:
{
  \tag_if_active:T
  {
    \tag_mc_end:
    \tag_struct_end:
    \tag_mc_begin_pop:n{}
  }
}
\cs_new_nopar:Npn \__luamplib_tagging_begin_actualtext:
{
  \tag_if_active:T
  {
    \tag_mc_end_push:
    \tag_struct_begin:n
    {
      tag=Span,
      actualtext=\l__luamplib_tag_actual_tl,
    }
    \tag_mc_begin:n{}
  }
}
\cs_set_eq:NN \__luamplib_tagging_end_actualtext: \__luamplib_tagging_end_figure:
\cs_new_nopar:Npn \__luamplib_tagging_begin_artifact:
{
  \tag_if_active:T
  {
    \tag_mc_end_push:
    \tag_mc_begin:n{artifact}
  }
}
\cs_new_nopar:Npn \__luamplib_tagging_end_artifact:
{
  \tag_if_active:T
  {
    \tag_mc_end:
    \tag_mc_begin_pop:n{}
  }
}
\cs_set_eq:NN \luamplibtaggingbegin \__luamplib_tagging_begin_figure:
\cs_set_eq:NN \luamplibtaggingend \__luamplib_tagging_end_figure:
\keys_define:nn{luamplib/tag}
  {
    ,alt .code:n =
      {
        \tl_set:Ne\l__luamplib_tag_alt_tl{\text_purify:n{#1}}
      }
    ,actualtext .code:n =
      {
        \bool_set_false:N \l__luamplib_tag_BBox_bool
        \tl_set:Ne\l__luamplib_tag_actual_tl{\text_purify:n{#1}}
        \cs_set_eq:NN \luamplibtaggingbegin \__luamplib_tagging_begin_actualtext:
        \cs_set_eq:NN \luamplibtaggingend \__luamplib_tagging_end_actualtext:
        \tag_if_active:T {\noindent}
      }
    ,artifact .code:n =
      {
        \bool_set_false:N \l__luamplib_tag_BBox_bool
        \cs_set_eq:NN \luamplibtaggingbegin \__luamplib_tagging_begin_artifact:
        \cs_set_eq:NN \luamplibtaggingend \__luamplib_tagging_end_artifact:
      }
    ,text .code:n =
      {
        \bool_set_false:N \l__luamplib_tag_BBox_bool
        \bool_set_true:N  \l__luamplib_tag_usetext_bool
        \cs_set_eq:NN \luamplibtaggingbegin \__luamplib_tagging_begin_artifact:
        \cs_set_eq:NN \luamplibtaggingend \__luamplib_tagging_end_artifact:
        \tag_if_active:T {\noindent}
      }
    ,tag .code:n =
      {
        \str_case:nnF {#1}
          {
            {text}
            {
              \bool_set_false:N \l__luamplib_tag_BBox_bool
              \bool_set_true:N  \l__luamplib_tag_usetext_bool
              \cs_set_eq:NN \luamplibtaggingbegin \__luamplib_tagging_begin_artifact:
              \cs_set_eq:NN \luamplibtaggingend \__luamplib_tagging_end_artifact:
              \tag_if_active:T {\noindent}
            }
            {false}
            {
              \SuspendTagging{luamplib.tagfalse}
            }
          }
          {
            \tl_set:Nn\l__luamplib_tag_struct_tl{#1}
          }
      }
    ,correct-BBox .code:n =
      {
        \bool_set_true:N \l__luamplib_tag_bboxcorr_bool
        \seq_set_split:Nnn \l__luamplib_tag_bboxcorr_seq{~}{#1~0pt~0pt~0pt~0pt}
      }
    ,debug .code:n =
      { \bool_set_true:N \l__luamplib_tag_debug_bool }
    ,instance .code:n =
      { \tl_gset:Nn \currentmpinstancename {#1} }
    ,instancename .meta:n = { instance = {#1} }
    ,unknown .code:n =
      { \tl_gset:Ne \currentmpinstancename {\l_keys_key_str} }
  }
\cs_new_nopar:Npn \luamplibtaggingBBox
{
  \bool_lazy_and:nnT
  {\tag_if_active_p:}
  {\l__luamplib_tag_BBox_bool}
  {
    \tl_set:Ne \l__luamplib_BBox_label_tl {luamplib.BBox.\tag_get:n{struct_num}}
    \tex_savepos:D
    \property_record:ee{\l__luamplib_BBox_label_tl}{xpos,ypos,abspage}
    \tl_set:Ne \l__luamplib_BBox_llx_tl
      {
        \dim_to_decimal_in_bp:n
        { \property_ref:een {\l__luamplib_BBox_label_tl}{xpos}{0}sp }
      }
    \tl_set:Ne \l__luamplib_BBox_lly_tl
      {
        \dim_to_decimal_in_bp:n
        { \property_ref:een {\l__luamplib_BBox_label_tl}{ypos}{0}sp - \dp\mplibscratchbox }
      }
    \tl_set:Ne \l__luamplib_BBox_urx_tl
      {
        \dim_to_decimal_in_bp:n
        { \l__luamplib_BBox_llx_tl bp + \wd\mplibscratchbox }
      }
    \tl_set:Ne \l__luamplib_BBox_ury_tl
      {
        \dim_to_decimal_in_bp:n
        { \l__luamplib_BBox_lly_tl bp + \ht\mplibscratchbox + \dp\mplibscratchbox }
      }
    \bool_if:NT \l__luamplib_tag_bboxcorr_bool
      {
        \tl_set:Ne \l__luamplib_BBox_llx_tl
          {
            \fp_eval:n
            {
              \l__luamplib_BBox_llx_tl
              +
              \dim_to_decimal_in_bp:n {\seq_item:Nn \l__luamplib_tag_bboxcorr_seq {1} }
            }
          }
        \tl_set:Ne \l__luamplib_BBox_lly_tl
          {
            \fp_eval:n
            {
              \l__luamplib_BBox_lly_tl
              +
              \dim_to_decimal_in_bp:n {\seq_item:Nn \l__luamplib_tag_bboxcorr_seq {2} }
            }
          }
        \tl_set:Ne \l__luamplib_BBox_urx_tl
          {
            \fp_eval:n
            {
              \l__luamplib_BBox_urx_tl
              +
              \dim_to_decimal_in_bp:n {\seq_item:Nn \l__luamplib_tag_bboxcorr_seq {3} }
            }
          }
        \tl_set:Ne \l__luamplib_BBox_ury_tl
          {
            \fp_eval:n
            {
              \l__luamplib_BBox_ury_tl
              +
              \dim_to_decimal_in_bp:n {\seq_item:Nn \l__luamplib_tag_bboxcorr_seq {4} }
            }
          }
      }
    \prop_gput:cne
      { g__tag_struct_\tag_get:n{struct_num}_prop }
      {A}
      {
        << /O /Layout /BBox [
          \l__luamplib_BBox_llx_tl\c_space_tl
          \l__luamplib_BBox_lly_tl\c_space_tl
          \l__luamplib_BBox_urx_tl\c_space_tl
          \l__luamplib_BBox_ury_tl
        ] >>
      }
    \bool_if:NT \l__luamplib_tag_debug_bool
      {
        \iow_log:e
          {
            luamplib/tag/debug:~BBox~of~structure~\tag_get:n{struct_num}~is~
            \l__luamplib_BBox_llx_tl\c_space_tl
            \l__luamplib_BBox_lly_tl\c_space_tl
            \l__luamplib_BBox_urx_tl\c_space_tl
            \l__luamplib_BBox_ury_tl
          }
        \use:e
        {
          \exp_not:N\AddToHookNext{shipout/foreground}
          {
            \exp_not:N\int_compare:nNnT
            {\exp_not:N\g_shipout_readonly_int}
            =
            {\property_ref:een{\l__luamplib_BBox_label_tl}{abspage}{0}}
            {
              \exp_not:N\put
              (\l__luamplib_BBox_llx_tl bp, \dim_eval:n{\l__luamplib_BBox_lly_tl bp -\paperheight})
              {
                \exp_not:N\opacity_select:n{0.5} \exp_not:N\color_select:n{red}
                \exp_not:N\rule
                  {\dim_eval:n {\l__luamplib_BBox_urx_tl bp - \l__luamplib_BBox_llx_tl bp}}
                  {\dim_eval:n {\l__luamplib_BBox_ury_tl bp - \l__luamplib_BBox_lly_tl bp}}
              }
            }
          }
        }
      }
  }
}
\cs_set_nopar:Npn \luamplibtagasgroupbegin
{
  \bool_if:NT \l__luamplib_tag_usetext_bool
  {
    \ResumeTagging{luamplib.asgroup}
    \tag_mc_begin:n{}
  }
}
\cs_set_nopar:Npn \luamplibtagasgroupend
{
  \bool_if:NT \l__luamplib_tag_usetext_bool
  {
    \tag_mc_end:
    \SuspendTagging{luamplib.asgroup}
  }
}
\cs_set_nopar:Npn \mplibstarttousemplibgroup
{
  \prependtomplibbox\hbox dir TLT\bgroup
  \luamplibtaggingbegin
  \setbox\mplibscratchbox\hbox\bgroup
  \bool_if:NT \l__luamplib_tag_usetext_bool
  {
    \tag_mc_end:
    \tag_mc_begin:n{}
  }
}
\cs_set_nopar:Npn \mplibstoptousemplibgroup
{
  \bool_if:NT \l__luamplib_tag_usetext_bool
  {
    \tag_mc_end:
    \tag_mc_begin:n{artifact}
  }
  \egroup
  \luamplibtaggingBBox
  \unhbox\mplibscratchbox
  \luamplibtaggingend
  \egroup
}
\cs_set_nopar:Npn \mplibstarttoPDF #1 #2 #3 #4
  {
    \prependtomplibbox
    \hbox dir TLT\bgroup
    \luamplibtaggingbegin % begin tagging
    \xdef\MPllx{#1}\xdef\MPlly{#2}%
    \xdef\MPurx{#3}\xdef\MPury{#4}%
    \xdef\MPwidth{\the\dimexpr#3bp-#1bp\relax}%
    \xdef\MPheight{\the\dimexpr#4bp-#2bp\relax}%
    \parskip0pt
    \leftskip0pt
    \parindent0pt
    \everypar{}%
    \setbox\mplibscratchbox\vbox\bgroup
    \SuspendTagging{luamplib.mplibtopdf}% stop tag inside figure
    \noindent
  }
\cs_set_nopar:Npn \mplibstoptoPDF
  {
    \par
    \egroup
    \setbox\mplibscratchbox\hbox
      {\hskip-\MPllx bp
       \raise-\MPlly bp
       \box\mplibscratchbox}%
    \setbox\mplibscratchbox\vbox to \MPheight
      {\vfill
       \hsize\MPwidth
       \wd\mplibscratchbox0pt
       \ht\mplibscratchbox0pt
       \dp\mplibscratchbox0pt
       \box\mplibscratchbox}%
    \wd\mplibscratchbox\MPwidth
    \ht\mplibscratchbox\MPheight
    \luamplibtaggingBBox % BBox
    \box\mplibscratchbox
    \luamplibtaggingend % end tagging
    \egroup
  }
\RenewDocumentCommand\mplibcode{O{}}
  {
    \msg_set:nnn {luamplib}{alt-text-missing}
    {
      Alternative~text~for~mplibcode~is~missing.\\
      Using~the~default~value~'##1'~instead.
    }
    \tl_gset_eq:NN \currentmpinstancename \c_empty_tl
    \keys_set:ne{luamplib/tag}{#1}
    \tl_if_empty:NF \currentmpinstancename
      { \tl_set:Nn\l__luamplib_tag_alt_dflt_tl {metapost~figure~\currentmpinstancename} }
    \mplibtmptoks{}\ltxdomplibcode
  }
\RenewDocumentCommand\mpfig{s O{}}
  {
    \begingroup
    \IfBooleanTF{#1}
    {\mplibprempfig *}
    {
      \msg_set:nnn {luamplib}{alt-text-missing}
      {
        Alternative~text~for~mpfig~is~missing.\\
        Using~the~default~value~'##1'~instead.
      }
      \keys_set:ne{luamplib/tag}{#2}
      \tl_if_empty:NF \mpfiginstancename
        { \tl_set:Nn\l__luamplib_tag_alt_dflt_tl {metapost~figure~\mpfiginstancename} }
      \mplibmainmpfig
    }
  }
\RenewDocumentCommand\usemplibgroup{O{} m}
  {
    \begingroup
    \msg_set:nnn {luamplib}{alt-text-missing}
    {
      Alternative~text~for~usemplibgroup~is~missing.\\
      Using~the~default~value~'##1'~instead.
    }
    \keys_set:ne{luamplib/tag}{#1}
    \tl_set:Nn\l__luamplib_tag_alt_dflt_tl {metapost~figure~#2}
    \mplibstarttousemplibgroup
    \csname luamplib.group.#2\endcsname
    \mplibstoptousemplibgroup
    \endgroup
  }
\cs_new_nopar:Npn \mplibalttext #1
{
  \tl_set:Ne \l__luamplib_tag_alt_tl {\text_purify:n{#1}}
}
\cs_new_nopar:Npn \mplibactualtext #1
{
  \tl_set:Ne \l__luamplib_tag_actual_tl {\text_purify:n{#1}}
}
\ExplSyntaxOff
\endinput
%%
%% End of file `luamplib.sty'.