繁体   English   中英

Pandoc Lua过滤器:如何为Span元素指定属性

[英]Pandoc Lua filters: how to specify attributes for Span element

我有一个包含原始LaTeX命令的Markdown文档。 我正在尝试使用带有Pandoc(2.0.1.1)的Lua过滤器将LaTeX命令转换为更便携的东西。 特别是,指定文本语言的命令应转换为具有lang属性的跨度。 问题是我不知道如何将属性传递给pandoc.Span构造函数。 这是我尝试过滤器( filter.lua ):

function RawInline(elem)
  if elem.format == "tex" then
    text = string.match(elem.text, "\\textspanish{(.+)}")
    if text then
      contents = {pandoc.Str(text)}
      attrs = pandoc.Attr("",{},{lang = "es-SP"})
      return pandoc.Span(contents, attrs)
    end
  else
    return elem
  end
end

样品用法:

echo '\textspanish{hola}' | pandoc -f markdown -t native --lua-filter=filter.lua

输出为[Para [Span ("",[],[]) [Str "hola"]]] ,跨度上没有属性。

如果我将名称和/或类传递给pandoc.Attr ,这些来自,例如, attrs = pandoc.Attr("name",{"class"},{lang = "es-SP"})产生[Para [Span ("name",["class"],[]) [Str "hola"]]] 但是我传递给构造函数的属性永远不会出现在输出中。 将属性传递给pandoc.Attr的正确方法是什么?

你找到了lua过滤器实现中的一个粗糙边缘; 这应该被解决,并使用户更友好。

当前实现使用两元素表来保存键值对:

attrs = pandoc.Attr("", {}, {{"lang", "es-SP"}})

这不是表示对的好方法。 目前实施的原因有两个:

  1. 它反映了在pandoc的JSON输出中如何编码对(以及一般属性)的方式。
  2. 这些对具有固定的顺序。

当人们想要保证在通过过滤器时不会改变属性的顺序时,最后一部分很重要。 lua中没有规则确定表中键的顺序:lua表{one = 1, two = 2}可以作为属性列表{one="1" two="2}读回到pandoc中as {two="2" one="1"} 。现在,属性的顺序对于大多数应用程序而言并不重要,但我们无法确定。因此,不太直观的表示。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM