ProxmoxVE/.github/CONTRIBUTOR_GUIDE/CONTRIBUTING.md

108 lines
5.2 KiB
Markdown
Raw Normal View History

2024-12-06 10:53:04 +00:00
2024-12-06 12:41:48 +00:00
# Community Scripts Contribution Guide
2024-12-06 10:53:04 +00:00
## **Welcome to the communty-scripts Repository!**
📜 These documents outlines the essential coding standards for all our scripts and JSON files. Adhering to these standards ensures that our codebase remains consistent, readable, and maintainable. By following these guidelines, we can improve collaboration, reduce errors, and enhance the overall quality of our project.
2024-12-06 10:53:04 +00:00
### Why Coding Standards Matter
2024-12-06 10:53:04 +00:00
Coding standards are crucial for several reasons:
2024-12-06 10:53:04 +00:00
1. **Consistency**: Consistent code is easier to read, understand, and maintain. It helps new team members quickly get up to speed and reduces the learning curve.
2. **Readability**: Clear and well-structured code is easier to debug and extend. It allows developers to quickly identify and fix issues.
3. **Maintainability**: Code that follows a standard structure is easier to refactor and update. It ensures that changes can be made with minimal risk of introducing new bugs.
4. **Collaboration**: When everyone follows the same standards, it becomes easier to collaborate on code. It reduces friction and misunderstandings during code reviews and merges.
2024-12-06 10:53:04 +00:00
### Scope of These Documents
2024-12-06 10:53:04 +00:00
These documentes covers the coding standards for the following types of files in our project:
2024-12-06 13:20:57 +00:00
- **`APP-install.sh` Scripts**: These scripts are responsible for the installation of applications and are located in the `/install` directory.
- **`APP.sh` Scripts**: These scripts handle the creation and updating of containers and are found in the `/ct` directory.
- **JSON Files**: These files store structured data and are located in the `/json` directory.
2024-12-06 13:10:04 +00:00
Each section provides detailed guidelines on various aspects of coding, including shebang usage, comments, variable naming, function naming, indentation, error handling, command substitution, quoting, script structure, and logging. Additionally, examples are provided to illustrate the application of these standards.
2024-12-06 13:20:57 +00:00
By following the coding standards outlined in this document, we ensure that our scripts and JSON files are of high quality, making our project more robust and easier to manage. Please refer to this guide whenever you create or update scripts and JSON files to maintain a high standard of code quality across the project. 📚🔍
2024-12-06 13:10:04 +00:00
Let's work together to keep our codebase clean, efficient, and maintainable! 💪🚀
2024-12-06 13:10:04 +00:00
2024-12-06 13:20:57 +00:00
## Getting Started
Before contributing, please ensure that you have the following setup:
2024-12-06 13:10:04 +00:00
1. **Visual Studio Code** (recommended for script development)
2. **Necessary VS Code Extensions:**
- [Shell Syntax](https://marketplace.visualstudio.com/items?itemName=bmalehorn.shell-syntax)
- [ShellCheck](https://marketplace.visualstudio.com/items?itemName=timonwong.shellcheck)
- [Shell Format](https://marketplace.visualstudio.com/items?itemName=foxundermoon.shell-format)
2024-12-06 10:53:04 +00:00
### Important Notes
- Use [AppName.sh](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/ct/AppName.sh) and [AppName-install.sh](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/install/AppName-install.sh) as templates when creating new scripts.
- The call to `community-scripts/ProxmoxVE` should be adjusted to reflect the correct fork URL.
2024-12-06 13:10:04 +00:00
2024-12-06 13:24:38 +00:00
---
2024-12-06 13:10:04 +00:00
# 🚀 The Application Script (ct/AppName.sh)
2024-12-06 12:41:48 +00:00
2024-12-19 10:38:50 +00:00
- You can find all Coding standards, as well as the structure for this files [here](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/ct/AppName.md).
- These Scripts are responsible for Container creataion, setting the necessery varibles and handels the update of the Application.
2024-12-06 10:53:04 +00:00
2024-12-06 12:41:48 +00:00
---
2024-12-06 10:53:04 +00:00
# 🛠 The Installation Script (install/AppName-install.sh)
2024-12-06 10:53:04 +00:00
2024-12-19 10:38:50 +00:00
- You can find all Coding standards, as well as the structure for this files [here](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/install/AppName-install.md).
- These Scripts handel the installation of the Application.
2024-12-06 10:53:04 +00:00
2024-12-06 12:41:48 +00:00
---
2024-12-06 10:53:04 +00:00
2024-12-06 13:20:57 +00:00
## 🚀 Building Your Own Scripts
2024-12-06 12:16:25 +00:00
2024-12-06 13:20:57 +00:00
Start with the [template script](https://github.com/community-scripts/ProxmoxVE/blob/main/docs/templates/example-install.sh)
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
---
2024-12-06 12:16:25 +00:00
2024-12-06 13:20:57 +00:00
## 🤝 Contribution Process
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
### 1. Fork the Repository
2024-12-06 13:20:57 +00:00
Fork to your GitHub account
2024-12-06 12:16:25 +00:00
2024-12-06 13:41:48 +00:00
### 2. Clone Your Fork on your Pc
2024-12-06 12:41:48 +00:00
```bash
2024-12-06 13:41:48 +00:00
git clone https://github.com/yourUserName/ForkName
2024-12-06 12:41:48 +00:00
```
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
### 3. Create a New Branch
```bash
git switch -c your-feature-branch
2024-12-06 12:41:48 +00:00
```
2024-12-06 12:16:25 +00:00
2024-12-06 13:24:38 +00:00
### 4. Change Paths in build.func and install.func
you need to switch "community-scripts/ProxmoxVE" to "yourUserName/ForkName"
### 4. Commit Changes (without build.func and install.func!)
2024-12-06 12:41:48 +00:00
```bash
git commit -m "Your commit message"
```
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
### 5. Push to Your Fork
```bash
git push origin your-feature-branch
```
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
### 6. Create a Pull Request
2024-12-06 13:20:57 +00:00
Open a PR from your feature branch to the main repository branch
2024-12-06 12:16:25 +00:00
2024-12-06 12:41:48 +00:00
---
2024-12-06 12:16:25 +00:00
2024-12-06 13:45:06 +00:00
## 📚 Pages
2024-12-06 12:16:25 +00:00
2024-12-06 13:45:06 +00:00
- [Function-Overview](https://github.com/community-scripts/ProxmoxVE/wiki/Function_Overview)
- [CT Template: AppName.sh](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/ct/AppName.sh)
- [Install Template: AppName-install.sh](https://github.com/community-scripts/ProxmoxVE/blob/contributor_guide/.github/CONTRIBUTOR_GUIDE/install/AppName-install.sh)
---