语言: :us: :cn: :ru:
#
e x T
首先,非常感谢大家抽出宝贵时间来让我们的 NexT 主题越变越好。在这里,我们介绍一下 [NexT 主题及其子模块](https://github.com/theme-next) 的开源贡献指南。不过,我们希望大家不要局限于此,更欢迎大家随时进行补充。 ## 目录 [如何为 NexT 做贡献](#如何为-next-做贡献) * [你需要了解的](#你需要了解的) * [阅读文档](#阅读文档) * [快速调试指南](#快速调试指南) * [反馈 Bug](#反馈-bug) * [提交漏洞](#提交漏洞) * [提交功能需求](#提交功能需求) * [提交合并请求](#提交合并请求) * [发布版本](#发布版本) [规范](#规范) * [行为规范](#行为规范) * [编码规范](#编码规范) * [标签规范](#标签规范) * [提交信息规范](#提交信息规范) ## 如何为 NexT 做贡献 ### 你需要了解的 #### 阅读文档 如果你在使用过程中遇到了问题,你可以查阅 [FAQs](https://theme-next.org/docs/faqs) 或者 [NexT 帮助文档](https://theme-next.org/docs/troubleshooting)。 另外,你也可以通过 [这里](https://github.com/theme-next/hexo-theme-next/search?q=&type=Issues&utf8=%E2%9C%93) 进行大致检索,有些问题已经得到解答,你可以自行解决。对于没有解决的 Issue,你也可以继续提问。 #### 快速调试指南 在 GitHub 上提交 Issue 前,请先通过以下方法 debug: * 执行`hexo clean`,清除浏览器缓存,并禁用 CDN 服务(例如 Cloudflare Rocket Loader); * 切换到其它主题并检查 bug 是否仍然存在(例如使用默认主题 landscape)。换言之,证明这是 NexT 主题而非来自 Hexo 的 bug; * 将 NexT 主题升级到最新版; * 将 Hexo 和 Hexo 插件升级到最新版; * 将 Node.js 和 `npm` 升级到最新版; * 卸载不必要的 Hexo 插件,或重新通过 `npm install --save` 安装插件。 如果你得到了来自 Hexo 或浏览器控制台的报错信息,请在 Google / Stackoverflow / GitHub Issue 中搜寻,或在提交 Issue 时报告给我们。 如果你在使用过程中发现了 Bug,请再次确认 Bug 在 [最新发布版本](https://github.com/theme-next/hexo-theme-next/releases/latest) 中是否重现。如果 Bug 重现,欢迎你到我们的 [主题仓库](https://github.com/theme-next/hexo-theme-next) 中 [反馈 Bug](#reporting-bugs) 或者 [提交功能需求](#提交功能需求),也更期待您 [提交合并请求](#提交合并请求)。 ### 反馈 Bug 反馈 Bug 前,请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容,避免提交重复的 Issue。确定相关仓库后,创建 Issue 并按照 [模板](../../.github/ISSUE_TEMPLATE.md) 尽可能的详细填写相关信息。 请认真遵守如下指南,这样我们才能更好地理解问题,重现问题和解决问题。 * 在标题中清晰准确地描述你的问题。 * 参照如下问题尽可能多的提供信息: * Bug 是否能够重现?是一直出现还是偶尔出现? * Bug 是从什么时候开始发生的? * 如果 Bug 突然发生,使用 [旧版本主题](https://github.com/theme-next/hexo-theme-next/releases) 是否能够重现 Bug?又是从哪个版本开始出现 Bug? * 你所使用 Node,Hexo 以及 Next 的版本号多少?你可以运行 `node -v` 和 `hexo version` 获取版本号,或者查看文件 `package.json` 的内容。 * 你使用了哪些插件包?查看文件 `package.json` 的内容即可获取。 * 一步步详细你是如何重现 Bug 的,做了什么,使用了哪些功能等等。如果你需要展示代码段,请使用 [Markdown 代码块](https://help.github.com/articles/creating-and-highlighting-code-blocks/) 或 [Github 预览链接](https://help.github.com/articles/creating-a-permanent-link-to-a-code-snippet/) 或 [Gist 链接](https://gist.github.com/)。 * 提供 Bug 的样例,如图像文件、在线演示网址等等。 * 详细描述通过上述重现过程出现的问题。 * 详细描述你期待的结果。 #### 提交漏洞 如果你发现安全问题,请以负责任的方式行事,即不要在公共 Issue 中提交而是直接向我们反馈,这样我们就可以在漏洞被利用之前对其进行修复。请将相关信息发送到 security@theme-next.com(可接受 PGP 加密邮件)。 我们很乐意对任何提交漏洞的人予以特别感谢以便我们修复它。如果你想保持匿名性或使用笔名替代,请告诉我们。我们将充分尊重你的意愿。 ### 提交功能需求 提交功能需求前,请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容,避免提交重复的 Issue。确定相关仓库后,创建 Issue 并按照 [模板](../../.github/ISSUE_TEMPLATE.md) 尽可能的详细填写相关信息。 请认真遵守如下指南,这样我们才能更好地理解和开发功能需求:pencil:: * 在标题中清晰准确地描述你的功能需求。 * 详细描述目前所具有的功能和你所期待的功能,并解释为什么需要该功能。 * 提供功能需求的样例,如图像文件、在线演示网址等等。 ### 提交合并请求 提交合并请求前,请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容,避免提交重复的合并请求。确定相关仓库后,创建合并请求。更多详细操作过程可以查看 [帮助文档](https://help.github.com/articles/creating-a-pull-request/)。 请认真遵守如下指南,这样我们才能更好地理解你的合并请求: * 创建合并请求时,请遵守 [编码规范](#编码规范) 和 [提交信息规范](#提交信息规范)。 * 在标题中清晰准确地描述你的合并请求,不要加入 Issue 编号。 * 按照 [模板](../../.github/PULL_REQUEST_TEMPLATE.md) 尽可能的详细填写相关信息。 * 合并请求需要在所有主题样式中测试通过,并提供所表现功能的样例,如图像文件、在线演示网址等等。 ### 发布版本 版本发布是将项目发布给用户的一种很好的方式。 1. 进入 GitHub 项目主页,点击 **Releases** 和 **Draft a new release**。 2. 输入你需要发布的版本号。版本控制是基于 [Git tags](https://git-scm.com/book/en/Git-Basics-Tagging) 工作的,建议按照 [About Major and Minor NexT versions](https://github.com/theme-next/hexo-theme-next/issues/187) 确定版本号。 3. 确定你需要发布的分支。除非发布测试版本,通常情况下选择 `master` 分支。 4. 输入发布版本的标题和说明。 - 标题为版本号。 - 所有内容更改的类型包括了 **Breaking Changes**, **Updates**, **Features** 和 **Bug Fixes**。在描述 Breaking Changes 时,使用二级标题分别陈述,描述其他类型时,使用项目列表陈述。 - 使用被动语态,省略主语。 - 所有的变化都需要记录在版本说明中。对于没有使用 PR 的更改,需要添加相应的 commit 编号。如果使用了 PR 进行合并修改,则直接添加相应的 PR 编号即可。 5. 如果您希望随版本一起发布二进制文件(如编译的程序),请在上传二进制文件对话框中手动拖放或选择文件。 6. 如果版本不稳定,请选择 **This is a pre-release**,以通知用户它尚未完全准备好。如果您准备公布您的版本,请点击 **Publish release**。否则,请单击 **Save draft** 以稍后处理。 ## 规范 ### 行为规范 为了保证本项目的顺利运作,所有参与人都需要遵守 [行为规范](CODE_OF_CONDUCT.md)。 ### 编码规范 我们使用 ESLint 和 Stylint 来识别和报告 JavaScript 和 Stylus 中的模式,目的是使代码更加一致并避免错误。编码时应遵循这些规范。 ### 标签规范 为了方便维护人员和用户能够快速找到他们想要查看的问题,我们使用“标签”功能对 Pull requests 和 Issues 进行分类。 如果您不确定某个标签的含义,或者不知道将哪些标签应用于 PR 或 issue,千万别错过这个。 Issue 的标签: - 类型 - `Bug`: 检测到需要进行确认的 Bug - `Feature Request`: 提出了新功能请求的 Issue - `Question`: 提出疑问的 Issue - `Meta`: 表明使用条款变更的 Issue - `Support`: 被标记为支持请求的 Issue - `Polls`: 发起投票的 Issue - 结果 - `Duplicate`: 重复提及的 Issue - `Irrelevant`: 与 NexT 主题无关的 Issue - `Invalid`: 无法复现的 Issue - `Expected Behavior`: 与预期行为相符的 Issue - `Need More Info`: 需要更多信息的 Issue - `Verified`: 已经被确认的 Issue - `Solved`: 已经解决的 Issue - `Backlog`: 待解决的 Issue - `Stale`: 由于长期无人回应被封存的 Issue Pull Request 的标签: - `Breaking Change`: 产生重大变动的 Pull Request - `Bug Fix`: 修复相关 Bug 的 Pull Request - `New Feature`: 添加了新功能的 Pull Request - `Feature`: 为现有功能提供选项或加成的 Pull Request - `i18n`: 更新了翻译的 Pull Request - `Work in Progress`: 仍在进行改动和完善的 Pull Request - `Skip Release`: 无需在 Release Note 中展现的 Pull Request 两者兼有: - `Roadmap`: 与 NexT 主题发展相关的 Issue 或者 Pull Request - `Help Wanted`: 需要帮助的 Issue 或者 Pull Request - `Discussion`: 需要进行讨论的 Issue 或者 Pull Request - `Improvement`: 需要改进的 Issue 或者改进了 NexT 主题的 Pull Request - `Performance`: 提出性能问题的 Issue 或者提高了 NexT 主题性能的 Pull Request - `Hexo`: 与 Hexo 和 Hexo 插件相关的 Issue 或者 Pull Request - `Template Engine`: 与模版引擎相关的 Issue 或者 Pull Request - `CSS`: 与 NexT 主题 CSS 文件相关的 Issue 或者 Pull Request - `Fonts`: 与 NexT 主题字体相关的 Issue 或者 Pull Request - `PJAX`: 与 PJAX 相关的 Issue 或者 Pull Request - `3rd Party Plugin`: 与第三方插件和服务相关的 Issue 或者 Pull Request - `Docs`: 与文档说明相关的 Issue 或者 Pull Request - `Configurations`: 与 NexT 主题设置相关的 Issue 或者 Pull Request ### 提交信息规范 我们对项目的 git 提交信息格式进行统一格式约定,每条提交信息由 `type`+`subject` 组成,这将提升项目日志的可读性。 - `type` 用于表述此次提交信息的意义,首写字母大写,包括但不局限于如下类型: * `Build`:基础构建系统或依赖库的变化 * `Ci`:CI 构建系统及其脚本变化 * `Docs`:文档内容变化 * `Feat`:新功能 * `Fix`:Bug 修复 * `Perf`:性能优化 * `Refactor`:重构(即不是新增功能,也不是修改 Bug 的代码变动) * `Style`:格式(不影响代码运行的变动) * `Revert`:代码回滚 * `Release`:版本发布 - `subject` 用于简要描述修改变更的内容,如 `Update code highlighting in readme.md`。 * 句尾不要使用符号。 * 使用现在时、祈使句语气。