参与开发 #
在开始之前, 请 Fork 本项目, 并克隆到本地, 并确保 Go 版本 >= 1.23.
以下是一些贡献代码的指南或建议, 你不必完全遵守, 但将有助于快速 review 并合并你的提交:
- 新功能请先提交 Issue, 以便讨论设计和实现细节, 并避免因与项目设计不符而被拒绝.
- 使用现代开发工具, 确保提交前格式化代码, 并保持风格一致.
- 使用语义化提交, 避免提交消息模糊或过于简单.
贡献新存储端 #
- 在
pkg/enums/storage/storages.go
中添加新的存储端类型, 并运行代码生成 - 在
config/storage
目录下定义存储端配置, 并添加到config/storage/factory.go
中 - 在
storage
目录下新建一个包, 编写存储端实现, 然后在storage/storage.go
中导入并添加它 - 更新文档, 添加配置说明
贡献新解析器 #
你可以选择使用 Go 编写原生的解析器实现(推荐), 或是使用 JavaScript 以插件的方式实现.
如果使用 Go 编写, 请:
- 在
parsers
目录下新建一个包, 编写解析器实现 - 在
parsers/parser.go
的init
中注册解析器
如果使用 JavaScript 编写, 请参考 plugins/example_parser_basic.js
的实现, 并在该文件夹下新建一个 js 文件, 实现你的解析逻辑.
需要注意, plugins
目录下解析器默认不会被编译到二进制文件中, 用户需要手动下载它们并放到本地指定目录下以启用它们.