[latex3-commits] [git/LaTeX3-latex3-latex2e] prototype: Use local copy of \keys_precompile:nnN at present (c0d88413)

Joseph Wright joseph.wright at morningstar2.co.uk
Wed Mar 9 08:47:51 CET 2022


Repository : https://github.com/latex3/latex2e
On branch  : prototype
Link       : https://github.com/latex3/latex2e/commit/c0d884138e7f2a3e634becda287aa1d4c94b2269

>---------------------------------------------------------------

commit c0d884138e7f2a3e634becda287aa1d4c94b2269
Author: Joseph Wright <joseph.wright at morningstar2.co.uk>
Date:   Tue Mar 8 22:16:09 2022 +0000

    Use local copy of \keys_precompile:nnN at present
    
    This commit
    - Adds the necessary patching for l3keys
    - Updates the interface to \keys_precompile:nnN
    - Removes the texmf version of the precompile code
    
    The debiug code is not covered, but that should make
    minimal difference in practice.


>---------------------------------------------------------------

c0d884138e7f2a3e634becda287aa1d4c94b2269
 required/latex-lab/latex-lab-prototype.dtx | 155 +++++++++++++++++++++++++++--
 texmf/tex/latex/l3kernel/expl3-code.tex    |  78 ++-------------
 texmf/tex/latex/l3kernel/l3debug.def       |   2 +-
 3 files changed, 158 insertions(+), 77 deletions(-)

diff --git a/required/latex-lab/latex-lab-prototype.dtx b/required/latex-lab/latex-lab-prototype.dtx
index eebd4666..1269ad77 100644
--- a/required/latex-lab/latex-lab-prototype.dtx
+++ b/required/latex-lab/latex-lab-prototype.dtx
@@ -45,7 +45,7 @@
 %    }^^A
 % }
 %
-% \date{Released 2022-01-12}
+% \date{Released 2022-03-09}
 %
 % \maketitle
 %
@@ -325,7 +325,7 @@
 %    \begin{macrocode}
 %<*package>
 \ProvidesFile{latex-lab-prototype.sty}
-  [2022-03-08 v0.1a Experimental prototype document functions]
+  [2022-03-09 v0.1b Experimental prototype document functions]
 %</package>
 %    \end{macrocode}
 %
@@ -334,15 +334,147 @@
 %    \end{macrocode}
 %
 %    \begin{macrocode}
-%<@@=prototype>
+\ExplSyntaxOn
 %    \end{macrocode}
 %
+% \subsection{\cs{keys_precompile:nnN}}
+%
 %    \begin{macrocode}
-\ExplSyntaxOn
+%<@@=keys>
+%    \end{macrocode}
+%
+% This may not yet be available in \pkg{expl3} so we ensure it is set up
+% here: all temporary. We just redefine those internals that need it.
+%    \begin{macrocode}
+\tl_if_exist:NF \l_@@_precompile_tl
+  {
+    \bool_new:N \l_@@_precompile_bool
+    \tl_new:N \l_@@_precompile_tl
+  }
+\cs_gset_protected:Npn \@@_precompile:n #1
+  {
+    \bool_if:NTF \l_@@_precompile_bool
+      { \tl_put_right:Nn \l_@@_precompile_tl }
+      { \use:n }
+        {#1}
+  }
+\cs_gset_protected:Npn \@@_bool_set:Nnnn #1#2#3#4
+  {
+    \bool_if_exist:NF #1 { \bool_new:N #1 }
+    \@@_choice_make:
+    \@@_cmd_set:nx { \l_keys_path_str / true }
+      { \exp_not:c { bool_ #2 set_ #3 :N } \exp_not:N #1 }
+    \@@_cmd_set:nx { \l_keys_path_str / false }
+      { \exp_not:c { bool_ #2 set_ #4 :N } \exp_not:N #1 }
+    \@@_cmd_set_direct:nn { \l_keys_path_str / unknown }
+      {
+        \msg_error:nnx { keys } { boolean-values-only }
+          \l_keys_key_str
+      }
+    \@@_default_set:n { true }
+  }
+\cs_gset_protected:Npn \@@_choice_make_aux:N #1
+  {
+    \cs_set_nopar:cpn { \c_@@_type_root_str \l_keys_path_str }
+      { choice }
+    \@@_cmd_set_direct:nn \l_keys_path_str { #1 {##1} }
+    \@@_cmd_set_direct:nn { \l_keys_path_str / unknown }
+      {
+        \msg_error:nnxx { keys } { choice-unknown }
+          \l_keys_path_str {##1}
+      }
+  }
+\cs_gset_protected:Npn \@@_cmd_set:nn #1#2
+  {  \@@_cmd_set_direct:nn {#1} { \@@_precompile:n {#2} } }
+\cs_gset_protected:Npn \@@_cmd_set_direct:nn #1#2
+  { \cs_set_protected:cpn { \c_@@_code_root_str #1 } ##1 {#2} }
+\cs_gset_protected:Npn \@@_cs_set:NNpn #1#2#3#
+  {
+    \cs_set_protected:cpx { \c_@@_code_root_str \l_keys_path_str } ##1
+      {
+        \@@_precompile:n
+          { #1 \exp_not:N #2 \exp_not:n {#3} {##1} }
+      }
+    \use_none:n
+  }
+\cs_gset_protected:Npn \@@_meta_make:n #1
+  {
+    \exp_args:NVo \@@_cmd_set_direct:nn \l_keys_path_str
+      {
+        \exp_after:wN \keys_set:nn \exp_after:wN 
+          { \l_@@_module_str } {#1}
+      }
+  }
+\cs_gset_protected:Npn \@@_meta_make:nn #1#2
+  {
+    \exp_args:NV \@@_cmd_set_direct:nn
+      \l_keys_path_str { \keys_set:nn {#1} {#2} }
+  }
+\cs_gset_protected:Npn \keys_precompile:nnN #1#2#3
+  {
+    \bool_set_true:N \l_@@_precompile_bool
+    \tl_clear:N \l_@@_precompile_tl
+    \keys_set:nn {#1} {#2}
+    \bool_set_false:N \l_@@_precompile_bool
+    \tl_set_eq:NN #3 \l_@@_precompile_tl
+  }
+\cs_gset_protected:Npn \@@_show:Nnn #1#2#3
+  {
+    #1 { keys } { show-key }
+      { \@@_trim_spaces:n { #2 / #3 } }
+      {
+        \keys_if_exist:nnT {#2} {#3}
+          {
+            \exp_args:Nnf \msg_show_item_unbraced:nn { code }
+              {
+                \exp_args:Ne \@@_show:n
+                  {
+                    \exp_args:Nc \cs_replacement_spec:N
+                    {
+                      \c_@@_code_root_str
+                      \@@_trim_spaces:n { #2 / #3 }
+                    }
+                  }
+              }
+          }
+      }
+      { } { }
+  }
+\cs_gset:Npx \@@_show:n #1
+  {
+    \exp_not:N \@@_show:w
+      #1
+      \tl_to_str:n { \@@_precompile:n }
+      #1
+      \tl_to_str:n { \@@_precompile:n }
+      \exp_not:N \s_@@_stop
+  }
+\use:x
+  {
+    \cs_gset:Npn \exp_not:N \@@_show:w
+      ##1 \tl_to_str:n { \@@_precompile:n }
+      ##2 \tl_to_str:n { \@@_precompile:n }
+      ##3 \exp_not:N \s_@@_stop
+  }
+  {
+    \tl_if_blank:nTF {#2}
+      {#1}
+      { \@@_show:Nw #2 \s_@@_stop }
+  }
+\use:x
+  {
+    \cs_gset:Npn \exp_not:N \@@_show:Nw ##1##2
+      \c_right_brace_str \exp_not:N \s_@@_stop
+  }
+  {#2}
 %    \end{macrocode}
 %
 % \subsection{Setup}
 %
+%    \begin{macrocode}
+%<@@=prototype>
+%    \end{macrocode}
+%
 % \begin{variable}{\l_@@_tmp_tl}
 %    \begin{macrocode}
 \tl_new:N \l_@@_tmp_tl
@@ -425,7 +557,7 @@
 % \end{macro}
 %
 %    \begin{macrocode}
-\cs_generate_variant:Nn \keys_precompile:Nnn { Nnv }
+\cs_generate_variant:Nn \keys_precompile:nnN { v , nv }
 %    \end{macrocode}
 %
 % \begin{macro}{\prototype_use_template:nnn}
@@ -457,10 +589,11 @@
   {
     \cs_if_exist:cTF { @@_template_ #1 _ #2 :w }
       {
-        \keys_precompile:Nnv \l_@@_assignments_tl
+        \keys_precompile:nvN
           { prototype / #1 / #2 }
           { l_@@_defaults_ #1 _ #2 _tl }
-        \keys_precompile:Nnn \l_@@_tmp_tl { prototype / #1 / #2 } {#3}
+          \l_@@_assignments_tl
+        \keys_precompile:nnN { prototype / #1 / #2 } {#3} \l_@@_tmp_tl
         \tl_put_right:NV \l_@@_assignments_tl \l_@@_tmp_tl
         #4
       }
@@ -486,12 +619,16 @@
         \tl_if_blank:nF {#3}
           {
             \tl_set:Nx \l_@@_tmp_tl
+              {
+
+              }
+            \keys_precompile:vnN
               {
                 prototype / #1 /
                 \tl_use:c { l_@@_instance_ #1 _ #2 _template_tl }
               }
-            \exp_args:NNV \keys_precompile:Nnn
-              \l_@@_tmp_tl \l_@@_tmp_tl {#3}
+              {#3}
+              \l_@@_tmp_tl
             \tl_put_right:NV \l_@@_assignments_tl
               \l_@@_tmp_tl
           }
diff --git a/texmf/tex/latex/l3kernel/expl3-code.tex b/texmf/tex/latex/l3kernel/expl3-code.tex
index 62f18c42..3904ec54 100644
--- a/texmf/tex/latex/l3kernel/expl3-code.tex
+++ b/texmf/tex/latex/l3kernel/expl3-code.tex
@@ -13036,8 +13036,6 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
 \bool_new:N \l__keys_tmp_bool
 \tl_new:N \l__keys_tmpa_tl
 \tl_new:N \l__keys_tmpb_tl
-\bool_new:N \l__keys_precompile_bool
-\tl_new:N \l__keys_precompile_tl
 \prop_new:N \l_keys_usage_load_prop
 \prop_new:N \l_keys_usage_preamble_prop
 \scan_new:N \s__keys_nil
@@ -13045,13 +13043,6 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
 \scan_new:N \s__keys_stop
 \quark_new:N \q__keys_no_value
 \__kernel_quark_new_conditional:Nn \__keys_quark_if_no_value:N { TF }
-\cs_new_protected:Npn \__keys_precompile:n #1
-  {
-    \bool_if:NTF \l__keys_precompile_bool
-      { \tl_put_right:Nn \l__keys_precompile_tl }
-      { \use:n }
-        {#1}
-  }
 \cs_new_protected:Npn \keys_define:nn
   { \__keys_define:onn \l__keys_module_str }
 \cs_new_protected:Npn \__keys_define:nnn #1#2#3
@@ -13155,7 +13146,7 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
       { \exp_not:c { bool_ #2 set_ #3 :N } \exp_not:N #1 }
     \__keys_cmd_set:nx { \l_keys_path_str / false }
       { \exp_not:c { bool_ #2 set_ #4 :N } \exp_not:N #1 }
-    \__keys_cmd_set_direct:nn { \l_keys_path_str / unknown }
+    \__keys_cmd_set:nn { \l_keys_path_str / unknown }
       {
         \msg_error:nnx { keys } { boolean-values-only }
           \l_keys_key_str
@@ -13187,8 +13178,8 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
   {
     \cs_set_nopar:cpn { \c__keys_type_root_str \l_keys_path_str }
       { choice }
-    \__keys_cmd_set_direct:nn \l_keys_path_str { #1 {##1} }
-    \__keys_cmd_set_direct:nn { \l_keys_path_str / unknown }
+    \__keys_cmd_set:nn \l_keys_path_str { #1 {##1} }
+    \__keys_cmd_set:nn { \l_keys_path_str / unknown }
       {
         \msg_error:nnxx { keys } { choice-unknown }
           \l_keys_path_str {##1}
@@ -13216,17 +13207,12 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
       }
   }
 \cs_new_protected:Npn \__keys_cmd_set:nn #1#2
-  {  \__keys_cmd_set_direct:nn {#1} { \__keys_precompile:n {#2} } }
-\cs_generate_variant:Nn \__keys_cmd_set:nn { nx , Vn , Vo }
-\cs_new_protected:Npn \__keys_cmd_set_direct:nn #1#2
   { \cs_set_protected:cpn { \c__keys_code_root_str #1 } ##1 {#2} }
+\cs_generate_variant:Nn \__keys_cmd_set:nn { nx , Vn , Vo }
 \cs_new_protected:Npn \__keys_cs_set:NNpn #1#2#3#
   {
     \cs_set_protected:cpx { \c__keys_code_root_str \l_keys_path_str } ##1
-      {
-        \__keys_precompile:n
-          { #1 \exp_not:N #2 \exp_not:n {#3} {##1} }
-      }
+      { #1 \exp_not:N #2 \exp_not:n {#3} {##1} }
     \use_none:n
   }
 \cs_generate_variant:Nn \__keys_cs_set:NNpn { Nc }
@@ -13299,17 +13285,13 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
   }
 \cs_new_protected:Npn \__keys_meta_make:n #1
   {
-    \exp_args:NVo \__keys_cmd_set_direct:nn \l_keys_path_str
+    \__keys_cmd_set:Vo \l_keys_path_str
       {
-        \exp_after:wN \keys_set:nn \exp_after:wN
-          { \l__keys_module_str } {#1}
+        \exp_after:wN \keys_set:nn \exp_after:wN { \l__keys_module_str } {#1}
       }
   }
 \cs_new_protected:Npn \__keys_meta_make:nn #1#2
-  {
-    \exp_args:NV \__keys_cmd_set_direct:nn
-      \l_keys_path_str { \keys_set:nn {#1} {#2} }
-  }
+  { \__keys_cmd_set:Vn \l_keys_path_str { \keys_set:nn {#1} {#2} } }
 \cs_new_protected:Npn \__keys_prop_put:Nn #1#2
   {
     \prop_if_exist:NF #1 { \prop_new:N #1 }
@@ -13766,14 +13748,6 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
     \__keys_set:nn {#2} {#4}
     \tl_set:Nn \l__keys_selective_seq {#1}
   }
-\cs_new_protected:Npn \keys_precompile:Nnn #1#2#3
-  {
-    \bool_set_true:N \l__keys_precompile_bool
-    \tl_clear:N \l__keys_precompile_tl
-    \keys_set:nn {#2} {#3}
-    \bool_set_false:N \l__keys_precompile_bool
-    \tl_set_eq:NN #1 \l__keys_precompile_tl
-  }
 \cs_new_protected:Npn \__keys_set_keyval:n #1
   {
     \bool_set_true:N \l__keys_no_value_bool
@@ -14114,46 +14088,16 @@ Type  H <return>  for immediate help}\def~{\errmessage{%
           {
             \exp_args:Nnf \msg_show_item_unbraced:nn { code }
               {
-                \exp_args:Ne \__keys_show:n
+                \exp_args:Nc \cs_replacement_spec:N
                   {
-                    \exp_args:Nc \cs_replacement_spec:N
-                    {
-                      \c__keys_code_root_str
-                      \__keys_trim_spaces:n { #2 / #3 }
-                    }
+                    \c__keys_code_root_str
+                    \__keys_trim_spaces:n { #2 / #3 }
                   }
               }
           }
       }
       { } { }
   }
-\cs_new:Npx \__keys_show:n #1
-  {
-    \exp_not:N \__keys_show:w
-      #1
-      \tl_to_str:n { \__keys_precompile:n }
-      #1
-      \tl_to_str:n { \__keys_precompile:n }
-      \exp_not:N \s__keys_stop
-  }
-\use:x
-  {
-    \cs_new:Npn \exp_not:N \__keys_show:w
-      ##1 \tl_to_str:n { \__keys_precompile:n }
-      ##2 \tl_to_str:n { \__keys_precompile:n }
-      ##3 \exp_not:N \s__keys_stop
-  }
-  {
-    \tl_if_blank:nTF {#2}
-      {#1}
-      { \__keys_show:Nw #2 \s__keys_stop }
-  }
-\use:x
-  {
-    \cs_new:Npn \exp_not:N \__keys_show:Nw ##1##2
-      \c_right_brace_str \exp_not:N \s__keys_stop
-  }
-  {#2}
 \msg_new:nnnn { keys } { bad-relative-key-path }
   { The~key~'#1'~is~not~inside~the~'#2'~path. }
   { The~key~'#1'~cannot~be~expressed~relative~to~path~'#2'. }
diff --git a/texmf/tex/latex/l3kernel/l3debug.def b/texmf/tex/latex/l3kernel/l3debug.def
index 864ce5a0..7f90a7f9 100644
--- a/texmf/tex/latex/l3kernel/l3debug.def
+++ b/texmf/tex/latex/l3kernel/l3debug.def
@@ -624,7 +624,7 @@
         { \__kernel_debug_log:x { Defining~key~#1~\msg_line_context: } }
     }
     { }
-    { \__keys_cmd_set_direct:nn }
+    { \__keys_cmd_set:nn }
   \__kernel_patch:nnn
     { }
     {





More information about the latex3-commits mailing list.