import{C as e}from"./chunks/ContributorBar.CvlwDakj.js";import{c as o,I as t,a9 as i,o as r}from"./chunks/framework.C4_mTacX.js";import"./chunks/theme.CqBL1Slk.js";const a=i('
Development Guide
How to Develop
Please read the Plugin Development and API Reference documents if you are developing a plugin.
If you need to submit code to the Liteyuki repository, please read the following:
- First fork a copy of the Liteyuki repository to your personal/organization account.
- Develop in your repository.
- Create a new branch in your repository and submit your code to this branch.
- Create a Pull Request in your repository to merge your branch into the
main
branch of the Liteyuki repository.
- Participation in development assumes that you are already familiar with the basic usage of the Python language and the Liteyuki framework.
- If you are developing documentation, please ensure that you are familiar with Markdown syntax and basic front-end knowledge.
- Contact the repository maintainer in case of conflicts.
Suggestions
- During development, you can use tools such as
mypy
, flake8
, and black
for code checking and formatting. - Enable developer mode by setting
dev_mode: true
in config.yml
to see more debugging information in the console.
Project Structure
main.py
: Bot entry fileliteyuki
: Framework directory (liteyukibot)src
: Bot application source code directory liteyuki_plugins
: Liteyuki plugin directorynonebot_plugins
: Nonebot plugin directoryresources
: Built-in resource packs directoryutils
: Utility directory
tests
: Unit test directorydocs
: Documentation directory en
: English documentationzh
: Chinese documentation
docker
: Docker related content directory
The liteyuki
framework is included in the LiteyukiBot
application, so this project is both the LiteyukiBot
application repository and the liteyuki
framework repository.
The src
directory is the application part, please develop business logic in this directory. liteyuki_plugins
and nonebot_plugins
directories are plugin directories, please develop plugins in these directories.
Standardization
- Code should follow
PEP8
and Google Python Style Guide
. - In addition, code submitted to the Liteyuki repository should follow the following guidelines:
- Ensure that the code is runnable and harmless.
- Ensure that the type hints in the code are correct.
- Ensure that the comment style is
Google Docstring
or Liteyuki Docstring
(recommended) to ensure that Litedoc can parse and generate documentation correctly. - Strings should be enclosed in double quotes
"
as much as possible, and single quotes '
should be used when nesting strings. - If there is a part for ordinary users, ensure that the documentation is complete (each language has corresponding documentation).
- commit message should follow the following guidelines:
- You should commit the code after completing a feature or fixing a bug, and not mix the code of multiple features or bugs together.
- We use gitmoji to mark the type of commit, such as
:sparkles:
for introducing new features, :bug:
for fixing bugs, etc., please refer to gitmoji for details. - The format of the commit message is
<emoji> [type:] <message>
, such as :sparkles: feat: add new field to event
, where the type field is the type of commit, not much is required, but please fill in as much as possible; the message field is a brief description, in summary, what you did. - There is no restriction on the language of the commit message, and bilingual use is possible if conditions permit.
- The documentation should follow
Markdown
syntax and support vitepress-related content: - Revise the documentation for each language when editing.
- Ensure that the links in the document are correct and do not lead to inaccessible links.
- Ensure that the User Documentation is easy to understand and the Development Documentation is detailed.
Finally
- This project is a non-profit open-source project, and we welcome anyone to participate in development. Your contributions will make Liteyuki better.
',16),p=JSON.parse('{"title":"Development Guide","description":"","frontmatter":{"title":"Development Guide","order":0},"headers":[],"relativePath":"en/dev/guide.md","filePath":"en/dev/guide.md","lastUpdated":1725389024000}'),l={name:"en/dev/guide.md"},g=Object.assign(l,{setup(n){return(d,s)=>(r(),o("div",null,[a,t(e)]))}});export{p as __pageData,g as default};