Bons exemplos de \tl_case:Nn(TF) e \str_case:nn(TF)

Bons exemplos de \tl_case:Nn(TF) e \str_case:nn(TF)

Enquanto aprendo expl3, estou tendo dificuldade em usar \str_case:nn(TF)e \tl_case:Nn(TF). Não consegui encontrar bons exemplos online. (Por exemplo, aqueles emunravelsão muito complicados para mim.) Você poderia fornecer exemplos independentes, concisos e úteis de aplicação \tl_case:Nn(TF)e \str_case:nn(TF)para fins de demonstração? Vamos abordar

  1. \tl_case:NnTF
  2. \str_case:nnTF
  3. \str_case_e:nnTF

primeiro. Eu os peguei dehttp://mirrors.ctan.org/macros/latex/contrib/l3kernel/interface3.pdf. Se você deseja fornecer exemplos para outros sufixos, como :cnTF, :Nn, etc., fique à vontade.

Responder1

Esta é apenas uma demonstração de aplicação de \str_case:nnTF, \str_case_e:nne \tl_case:nnTF.

Os casos para :cnTFetc. já foram explicados nos comentários à pergunta.

A diferença entre \str_case_ee \str_caseé a expansão dos argumentos. A diferença entre a \tl..e \str..é que para uma string os catcodes dos caracteres são todos iguais (12), exceto aqueles dos caracteres de espaço, que ainda possuem o código 10, enquanto em uma lista de tokens, os catcodes são preservados.

As \foo:nnTFversões apenas inserem a ramificação condicional no fluxo de entrada - é possível usar os colchetes correspondentes {foobar}{...}para processamento ou configuração adicional (ou 'composição tipográfica') ou mudar para TF-ramificação.

Eu pessoalmente uso o \foo:nnúnico e não me lembro do que precisei \foo:nnTFaté agora, mas isso depende do caso de uso real, é claro.

\documentclass{article}

\usepackage{expl3}

\ExplSyntaxOn

\newcommand{\strcase}[1]{%
  \str_case:nn {#1} {
    {TeX} {\use:c{#1}\space is\space the\space predecessor\space of\space \LaTeX}
    {LaTeX} {\use:c{#1}\space is\space the\space successor\space of\space \TeX}
  }
}

\newcommand{\strcasetf}[3]{%
  \str_case:nnTF {#1} {
    {TeX} {\use:c{#1}\space is\space the\space predecessor\space of\space \LaTeX}
    {LaTeX} {\use:c{#1}\space is\space the\space successor\space of\space \TeX}
    {Word} {#1\space is\space a\space 'typesetter'}
  }{
    \space#2
  }{
    \space#3
  }
}

\newcommand{\genericstrcase}[3]{%
  \str_case:nn {#3} {
    {#1} {It was the first argument}
    {#2} {It was the second argument}
    {Other} {#1 it was 'other'}
  }
}


\newcommand{\strcasextf}[3]{%
  \str_case_e:nnTF {#1} {
    {TeX} {\use:c{#1}\space is\space the\space predecessor\space of\space \LaTeX}
    {LaTeX} {\use:c{#1}\space is\space the\space successor\space of\space \TeX}
    {Word} {#1\space is\space a\space 'typesetter'}
  }{
    \space#2
  }{
    \space#3
  }
}

\tl_new:N \l_tl_one
\tl_new:N \l_tl_two

\newcommand{\tlcase}[3]{%
  \tl_set:Nn \l_tl_one {#1}
  \tl_set:Nn \l_tl_two {#2}

\tl_set:Nn \l_tmpa_tl {#3}

\tl_case:Nn \l_tmpa_tl {
  {\l_tl_one} {Yes,\space it\space was\space #1}
  {\l_tl_two}  {Yes,\space it\space was\space #2}
}
}

\ExplSyntaxOff

\newcommand{\LaTeXStr}{LaTeX}
\newcommand{\WordPressString}{WordPress}
\newcommand{\WordString}{Word}


\begin{document}

\strcase{TeX}

\strcase{LaTeX}

\strcasetf{LaTeX}{-- the strings match}{-- the strings does not match!}

\strcasetf{Word}{-- the strings match}{-- the strings does not match!}

\strcasetf{WordPress}{-- the strings match}{-- the strings does not match!}

\textbf{Compare}

\strcasetf{\LaTeXStr}{-- the strings match}{-- the strings does not match!}

\strcasextf{\LaTeXStr}{-- the strings match}{-- the strings does not match!}

\tlcase{LaTeX}{TeX}{LaTeX}
\tlcase{LaTeX}{TeX}{\LaTeX} % Does nothing, since \LaTeX is not expanded

\textbf{Comparing command tokens}

\tlcase{\LaTeX}{TeX}{\LaTeX}% Compares again

\tlcase{LaTeX is very nice}{TeX}{LaTeX is very nice} 
\tlcase{TeX is nice}{TeX is not outdated}{TeX is very nice} % Does not match

\textbf{Comparing strings}

\genericstrcase{LaTeX}{TeX}{LaTeX}

\genericstrcase{ #LaTeX}{ #TeX}{ #TeX}

\genericstrcase{\LaTeX}{TeX}{\LaTeX}

\end{document}

informação relacionada