首页
/ 探索Literate Markdown Tangle:代码与文档的新融合

探索Literate Markdown Tangle:代码与文档的新融合

2024-06-15 20:31:55作者:范靓好Udolf

Literate Markdown Tangle(LMT) 是一个创新的工具,它将Markdown与编程风格相结合,使程序员能够在文档中以清晰易读的方式编写代码。这种** literate programming** 的理念让开发者可以在保持代码可读性的同时,增强文档的完整性。

安装LMT

LMT是一个基于Go语言开发的自包含程序,源码和这个README文件一起存储在GitHub仓库中,用于自我构建。首先确保你的环境中已经安装了Go语言,然后执行以下命令:

git clone https://github.com/driusan/lmt
cd lmt
go build

这将在当前目录下创建名为lmt的二进制文件,你可以通过-o $path参数来指定不同的输出位置。

对于Nix(OS)用户,项目还提供了一个shell.nix文件,可以用来编译项目。

功能演示

为了体验LMT的工作原理,请将此README文件复制到一个空目录,并运行lmt README.md。你会看到从Markdown文件中的代码块中提取出来的文件出现在当前目录。这种过程在literate编程中被称为“tangling”。

LMT是语言无关的,下面的示例使用非常基础的C++来展示其他语言的应用。

文件定向与追加

比如这段带有cpp hello.cpp +=前缀的代码块:

<<<copyright>>>
<<<includes>>>

int main() {
    <<<body of main>>>
}
  1. cpp 表示该代码块为C++,在Markdown渲染时会有相应的语法高亮,在LMT中则会添加语言特定的预处理指令。
  2. hello.cpp 指定了代码块将会被写入到hello.cpp文件中。
  3. += 表示如果文件已存在,则追加内容到文件末尾,如果不存在则新建。

宏引用

<<<...>>>这样的序列称为“宏参考”。LMT的“宏”是一个可以从代码块中提取并插入到其他地方的变量。如上例中的<<<body of main>>>,未定义时会有警告,但定义后会被替换。

宏内容

以下代码块定义了body of main的值:

std::cout << "Hello, werld!" << std::endl;

双引号表示这是一个宏,而没有+=意味着会覆盖之前的定义。

追加到宏

使用+=,我们可以向宏添加新的内容,例如在includes宏后面添加更多头文件:

#include <numeric>

隐藏内容

隐藏内容如注释中的版权信息不会显示在最终文档中,但仍会被提取出来:

// Copyright 2020 Me, myself, and I

可选的Tangle与不可选的

LMT允许你对任意语言字符串和文件名进行编码,以实现不同需求。不指定语言或目标,代码块就不会被打包到任何地方。

应用场景

LMT特别适用于:

  1. 文档驱动的开发,它可以轻松地将代码解释与实现结合在一起。
  2. 教程编写,读者可以直接查看和理解代码细节。
  3. 开源项目,提供清晰的、有注解的代码以提高代码透明度。
  4. 快速原型设计,代码与说明文档可以同时修改,减少切换成本。

项目特点

  • 语言无关:LMT支持所有语言的代码块,只需指定语言名称。
  • 扩展性:通过宏引用,可以在多个代码块之间传递和组合代码。
  • 隐藏内容:在不影响文档展示的情况下,隐藏需要tangle的内容。
  • 灵活的代码组织:追加内容、定义新宏等操作,让代码结构更自由。

LMT不仅是一个工具,更是一种编程哲学。它将代码和文档紧密集成,让开发变得更直观,更易于理解和维护。立即尝试LMT,提升您的代码写作体验吧!

热门项目推荐
相关项目推荐

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
33
24
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
830
0
redis-sdkredis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
376
32
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.92 K
19.09 K
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
15.62 K
1.45 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
19
2
杨帆测试平台杨帆测试平台
扬帆测试平台是一款高效、可靠的自动化测试平台,旨在帮助团队提升测试效率、降低测试成本。该平台包括用例管理、定时任务、执行记录等功能模块,支持多种类型的测试用例,目前支持API(http和grpc协议)、性能、CI调用等功能,并且可定制化,灵活满足不同场景的需求。 其中,支持批量执行、并发执行等高级功能。通过用例设置,可以设置用例的基本信息、运行配置、环境变量等,灵活控制用例的执行。
JavaScript
9
1
Yi-CoderYi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
57
7
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
147
26
anqicmsanqicms
AnQiCMS 是一款基于Go语言开发,具备高安全性、高性能和易扩展性的企业级内容管理系统。它支持多站点、多语言管理,能够满足全球化跨境运营需求。AnQiCMS 提供灵活的内容发布和模板管理功能,同时,系统内置丰富的利于SEO操作的功能,帮助企业简化运营和内容管理流程。AnQiCMS 将成为您建站的理想选择,在不断变化的市场中保持竞争力。
Go
78
5