Files
fzu-product/CONTRIBUTING.md
2023-08-15 01:17:42 +08:00

8.2 KiB
Raw Blame History

贡献指南

感谢您的贡献,并感谢您在执行贡献操作之前阅读此文档!

致新贡献者

欢迎你的到来,非常感谢你愿意一起建设 HDU-CS-WIKI 💖

初次参与,你遇到任何问题都可以直接反馈到本仓库,包括但不限于:

  • 开发环境搭建时遇到任何问题。
  • 文档遇到任何问题(笔误,格式,错误等)。

如果你在运行项目的时候发现任何不符合预期或不合理的地方,请直接提交 Issue 反馈和 Bug 报告!

如何贡献

我们欢迎各种贡献,包括但不限于:

  • 新功能Feature
  • 代码构建、CI/CD
  • Bug 修复
  • 文档内容增删改
  • Issue 分类、发起、回复、管理、维护
  • 网站页面设计
  • 在各种媒体、博客文章、群内宣传 HDU-CS-WIKI

文档风格

  1. 使用 Markdown 编写文档,文档格式参考 Markdown 语法。

  2. 一个页面只有一个1级标题H1一个#其他标题从2级开始H2##)。

  3. 本项目自动在英文与中文、数字与中文之间添加空格。

     AI 与人工智能AGI 的发展方向。
    
  4. 标题内的英文单词首字母大写。

  5. 代码块使用 ``` 包裹,并标注常见的语言标识符,如 ```python ,其作用是使代码正常高亮。 ::: details 代码高亮支持的语言

export type Lang =
  | 'abap'
  | 'actionscript-3'
  | 'ada'
  | 'apache'
  | 'apex'
  | 'apl'
  | 'applescript'
  | 'ara'
  | 'asm'
  | 'astro'
  | 'awk'
  | 'ballerina'
  | 'bat' | 'batch'
  | 'beancount'
  | 'berry' | 'be'
  | 'bibtex'
  | 'bicep'
  | 'blade'
  | 'c'
  | 'cadence' | 'cdc'
  | 'clarity'
  | 'clojure' | 'clj'
  | 'cmake'
  | 'cobol'
  | 'codeql' | 'ql'
  | 'coffee'
  | 'cpp'
  | 'crystal'
  | 'csharp' | 'c#' | 'cs'
  | 'css'
  | 'cue'
  | 'cypher' | 'cql'
  | 'd'
  | 'dart'
  | 'dax'
  | 'diff'
  | 'docker' | 'dockerfile'
  | 'dream-maker'
  | 'elixir'
  | 'elm'
  | 'erb'
  | 'erlang' | 'erl'
  | 'fish'
  | 'fsharp' | 'f#' | 'fs'
  | 'gdresource'
  | 'gdscript'
  | 'gdshader'
  | 'gherkin'
  | 'git-commit'
  | 'git-rebase'
  | 'glimmer-js' | 'gjs'
  | 'glimmer-ts' | 'gts'
  | 'glsl'
  | 'gnuplot'
  | 'go'
  | 'graphql'
  | 'groovy'
  | 'hack'
  | 'haml'
  | 'handlebars' | 'hbs'
  | 'haskell' | 'hs'
  | 'hcl'
  | 'hjson'
  | 'hlsl'
  | 'html'
  | 'http'
  | 'imba'
  | 'ini' | 'properties'
  | 'java'
  | 'javascript' | 'js'
  | 'jinja-html'
  | 'jison'
  | 'json'
  | 'json5'
  | 'jsonc'
  | 'jsonl'
  | 'jsonnet'
  | 'jssm' | 'fsl'
  | 'jsx'
  | 'julia'
  | 'kotlin'
  | 'kusto' | 'kql'
  | 'latex'
  | 'less'
  | 'liquid'
  | 'lisp'
  | 'logo'
  | 'lua'
  | 'make' | 'makefile'
  | 'markdown' | 'md'
  | 'marko'
  | 'matlab'
  | 'mdx'
  | 'mermaid'
  | 'mojo'
  | 'narrat' | 'nar'
  | 'nextflow' | 'nf'
  | 'nginx'
  | 'nim'
  | 'nix'
  | 'objective-c' | 'objc'
  | 'objective-cpp'
  | 'ocaml'
  | 'pascal'
  | 'perl'
  | 'php'
  | 'plsql'
  | 'postcss'
  | 'powerquery'
  | 'powershell' | 'ps' | 'ps1'
  | 'prisma'
  | 'prolog'
  | 'proto'
  | 'pug' | 'jade'
  | 'puppet'
  | 'purescript'
  | 'python' | 'py'
  | 'r'
  | 'raku' | 'perl6'
  | 'razor'
  | 'reg'
  | 'rel'
  | 'riscv'
  | 'rst'
  | 'ruby' | 'rb'
  | 'rust' | 'rs'
  | 'sas'
  | 'sass'
  | 'scala'
  | 'scheme'
  | 'scss'
  | 'shaderlab' | 'shader'
  | 'shellscript' | 'bash' | 'sh' | 'shell' | 'zsh'
  | 'shellsession' | 'console'
  | 'smalltalk'
  | 'solidity'
  | 'sparql'
  | 'splunk' | 'spl'
  | 'sql'
  | 'ssh-config'
  | 'stata'
  | 'stylus' | 'styl'
  | 'svelte'
  | 'swift'
  | 'system-verilog'
  | 'tasl'
  | 'tcl'
  | 'tex'
  | 'toml'
  | 'tsx'
  | 'turtle'
  | 'twig'
  | 'typescript' | 'ts'
  | 'v'
  | 'vb' | 'cmd'
  | 'verilog'
  | 'vhdl'
  | 'viml' | 'vim' | 'vimscript'
  | 'vue-html'
  | 'vue'
  | 'vyper' | 'vy'
  | 'wasm'
  | 'wenyan' | '文言'
  | 'wgsl'
  | 'wolfram'
  | 'xml'
  | 'xsl'
  | 'yaml' | 'yml'
  | 'zenscript'
  | 'zig'

:::

::: tip 🤓 注意 尽量不要使用 typora 因为它的渲染效果和本项目前端框架 vitepress 不一致。

typora 中编辑完成后,确认一下 .md 文件源代码是否为正常 Markdown 。

编辑完成后需要启动本项目在前端查看效果。 :::

项目构建指南

vitepress 框架要求,强制需要 nodejs v18.0 及以上版本。

本项目使用包管理器 npm。

npm install 
npm run docs:dev      #运行预览环境
npm run docs:build    #编译线上环境
npm run docs:preview  #预览线上环境

图片放置指南

图片放置在当前大章节的 static 目录下,然后在 md 文件中使用相对路径引用。

![](static/xxx.png)

注意尽量不要使用 img 标签,因为经前端构建解析后路径会不正确。

后续会统一放置到 cos 存储桶中。

项目配置指南

修改新添加或移动位置的 md 文件需要在 .vitepress/config.js.vitepress/sidebar.js 中添加或修改对应的配置。

sidebar.js 文件会管理显示在左侧导航栏的所有路由

详见 VitePress 官方文档

如何使用 Git 和 Github

详见 3.5 Git和Github

Commit Message 规范

::: tip 🐒 本项目没有强制使用 commitlint ,但是建议遵循以下规范。

commitlint : 一个提交检查插件 ,可以在提交前检查 commit message 是否符合规范。

本项目选用的规范为 @commitlint/config-conventional(基于 Angular 约定) :::

本项目遵循以下 commit message 规范:

模板:
type(scope): subject

type为commit的类型
    feat:      新特性
    fix:       修改问题
    refactor:  代码重构
    docs:      文档修改
    style:     代码格式修改
    test:      测试用例修改
    chore:     其他修改, 比如构建流程, 依赖管理
    pref:      性能提升的修改
    build:     对项目构建或者依赖的改动
    ci:        CI 的修改
    revert:    revert 前一个 commit(撤销前一个commit)
    
scope是文件名 / 模块名 / 影响的范围
    例如  schoolSchedule
    
subject为commit概述
    建议符合 50 / 72 formatting
    
例  feat(JoinForm): add success submit tips

冒号后方可以使用中文描述

注意 冒号和subject之间要加空格

其中详细内容可以参照 约定式提交

Conventional Commits

Pull Request 流程与指南

Fork 本仓库,然后在你的仓库中进行修改,修改完成后在本仓库创建 NEW Pull Request ,选择 compare across forks 提交 pr 并评论上你修改的具体信息即可,我们会第一时间审阅并合并。

Feature

  1. Markdown 内支持Latex公式格式为单行公式双dollar符号、单行公式单dollar符号。单行公式需要换行才能解析例如

    $行内公式\arccos{a}$
    

    会渲染成 \arccos{a}

    $$单行公式\arcsin{b}$$
    

    会渲染成

    \arcsin{b}

    ::: tip Latex语法在线编辑器 https://www.latexlive.com :::

  2. 支持Mermaid流程图格式如下

        ```mermaid
        graph TD;
        A-->B;
        A-->C;
        B-->D;
        C-->D;
        ``` 
    

    会渲染成

    graph TD;
        A-->B;
        A-->C;
        B-->D;
        C-->D;
    

    :::tip 语法自查 https://mermaid.js.org :::

  3. 代码分块

        ::: code-group
    
        ```sh [npm]
        $ npm install -D vitepress
        ```
    
        ```sh [pnpm]
        $ pnpm add -D vitepress
        ```
    
        ```sh [yarn]
        $ yarn add -D vitepress
        ```
    
        :::
    

    ::: code-group

    $ npm install -D vitepress
    
    $ pnpm add -D vitepress
    
    $ yarn add -D vitepress
    

    :::