3
  • 描述:

    • 我正在尝试集成包含 vimwiki 和 Gollum 的工作流程和工具。我只想添加 vimwiki 作为编辑器的扩展类型,同时由 Gollum 的内部 Markdown 处理器处理(请参阅“我尝试过的事情”#1)。
    • 最后,我还希望 Gollum 在创建新文档时也默认为“vimwiki”。
    • 我正在做的项目可以在Vimwiki-Gollum-Integration找到
  • 测试细节:

    • 咕噜版本:4.1.1
    • 正在测试的文件是有效的 github markdown
    • 正在使用不同的文件名和扩展名测试相同的内容:
      • 测试x.thing
      • 废话.vimwiki
    • 使用 .md 扩展名命名的测试文件可以正常工作
    • 安装了相关的渲染宝石:
      • github-markdown
      • github标记
      • 克拉姆当
      • 红地毯
    • 所有代码都在 gollum --config 文件中进行测试
    • 我不精通红宝石

我尝试过的事情

  1. 创建新的扩展和自定义渲染器
    • 这有效,除非没有理由实现自定义处理器(pandoc)
    • 这将是理想的,以便 Markdown 名称最终出现在编辑页面中。但是,我认为我不应该在这里涉及 pandoc
    • 在编辑 vimwiki 扩展时,如何让编辑页面将降价默认为 vimwiki?
    • 使用的文件:blah.vimwiki
# always include this:
Gollum::Page.send :remove_const, :FORMAT_NAMES if defined? Gollum::Page::FORMAT_NAMES

################### custom extension + renderer
# # Custom extension rendering
# ## References
# * file reference: /var/lib/gems/2.1.0/gems/github-markup-1.6.0/lib/github/markup/command_implementation.rb
# * [Adding Pandoc to Gollum - Martin Wolf's weblog [OUTDATED]](https://www.mwolf.net/2014/04/29/adding-pandoc-to-gollum/)
ci = ::GitHub::Markup::CommandImplementation.new(
     /vimwiki/,
     ["Vimwiki"],
     "pandoc -f markdown-tex_math_dollars-raw_tex",
     :vimwiki)

# bind your own extension regex (the new set of extensions will also include `.asc` and `.adoc`):
# # * file reference: /var/lib/gems/2.1.0/gems/github-markup-1.6.0/lib/github/markups.rb
Gollum::Markup.register(:vimwiki,  "Vimwiki")
Gollum::Markup.formats[:vimwiki][:regexp] = /vimwiki/
GitHub::Markup::markup_impl(:vimwiki, ci)
##################
  1. 尝试替换 Markdown 主扩展和正则表达式。
    • 我不明白为什么这不起作用,除非我误解了匹配和覆盖的操作顺序。
    • 该页面将显示,扩展名被识别,但页面根本不格式化 - 将所有内容合并在一起。
# always include this:
Gollum::Page.send :remove_const, :FORMAT_NAMES if defined? Gollum::Page::FORMAT_NAMES

# Attempt to replace the primary extension for Markdown
# remove the original markdown binding:
Gollum::Markup.formats.delete(:markdown)

# and define your own 
Gollum::Markup.formats[:thing] = {
    :name => "Markdown",
    :regexp => /thing/
}
  1. 尝试仅替换降价扩展正则表达式
    • 结果与尝试 2 相同。
    • 页面将显示,但格式不正确
# always include this:
Gollum::Page.send :remove_const, :FORMAT_NAMES if defined? Gollum::Page::FORMAT_NAMES

Gollum::Markup.formats[:markdown][:regexp] = /vimwiki|thing/
4

1 回答 1

0

我要结束这个问题:

事实证明,使用降价处理器并让编辑页面识别出不同的扩展名并不容易。markdown 处理器要求扩展名有效,它是markdown.rb中的扩展名的正则表达式。

最重要的是,无论如何我都需要实现类似于 pandoc 正在做的事情。所以我只是放弃这个主题并坚持 pandoc -'我尝试过的事情#1'来自原始问题。

我没有在这里占用大量空间,而是在项目页面上发布了带有代码示例的文档

感谢任何花时间思考这个问题的人。

于 2017-07-25T21:43:15.827 回答