diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 9990317a..5a76af0c 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -2,54 +2,60 @@ Thank you for considering contributing to Linutil! We appreciate your effort in helping improve this project. To ensure that your contributions align with the goals and quality standards of Linutil, please follow these guidelines: -## 1. Setting Up Your Development Environment +## 1. **Install Rust**: -1. **Clone the repo**: Start by cloning the Linutil repository to your local machine. - ```bash - git clone https://github.com/christitustech/linutil.git - cd linutil +Make sure you have Rust installed on your machine. You can install it by following the instructions at [rust-lang.org](https://www.rust-lang.org/tools/install). + +## 2. **Fork and Clone the repo** + +1. Make a fork of the repo in GitHub +2. Clone the fork +```bash +git clone https://github.com/YOUR_USERNAME_HERE/linutil.git +cd linutil ``` -2. **Install Rust**: Make sure you have Rust installed on your machine. If you don't, you can install it by following the instructions at [rust-lang.org](https://www.rust-lang.org/tools/install). -3. **Edit the files you want to change**: Make your changes to the relevant files. -4. **Test your changes**: Run `cargo run` to test your modifications in a local environment and ensure everything works as expected. -## 2. Make Meaningful Changes +## 3. Make your changes +- **Edit the files you want to change**: Make your changes to the relevant files. +- **Test your changes**: Run `cargo run` to test your modifications in a local environment and ensure everything works as expected. + +## 4. Understand the existing code - **Have a clear reason**: Don’t change the way things are done without a valid reason. If you propose an alteration, be prepared to explain why it’s necessary and how it improves the project. - **Respect existing conventions**: Changes should align with the existing code style, design patterns, and overall project philosophy. If you want to introduce a new way of doing things, justify it clearly. -## 3. Learn from Past Pull Requests (PRs) +## 5. Learn from Past Pull Requests (PRs) - **Check merged PRs**: Reviewing merged pull requests can give you an idea of what kind of contributions are accepted and how they are implemented. - **Study rejected PRs**: This is especially important as it helps you avoid making similar mistakes or proposing changes that have already been considered and declined. -## 4. Write Clean, Descriptive Commit Messages +## 6. Write Clean, Descriptive Commit Messages - **Be descriptive**: Your commit messages should clearly describe what the change does and why it was made. - **Use the imperative mood**: For example, "Add feature X" or "Fix bug in Y", rather than "Added feature X" or "Fixed bug in Y". - **Keep commits clean**: Avoid committing a change and then immediately following it with a fix for that change. Instead, amend your commit or squash it if needed. -## 5. Keep Your Pull Requests (PRs) Small and Focused +## 7. Keep Your Pull Requests (PRs) Small and Focused - **Make small, targeted PRs**: Focus on one feature or fix per pull request. This makes it easier to review and increases the likelihood of acceptance. - **Avoid combining unrelated changes**: PRs that tackle multiple unrelated issues are harder to review and might be rejected because of a single problem. -## 6. Code Review and Feedback +## 8. Code Review and Feedback - **Expect feedback**: PRs will undergo code review. Be open to feedback and willing to make adjustments as needed. - **Participate in reviews**: If you feel comfortable, review other contributors' PRs as well. Peer review is a great way to learn and ensure high-quality contributions. -## 7. Contributing Is More Than Just Code +## 9. Contributing Is More Than Just Code - **Test the tool**: Running tests and providing feedback on how the tool works in different environments is a valuable contribution. - **Write well-formed issues**: Clearly describe bugs or problems you encounter, providing as much detail as possible, including steps to reproduce the issue. - **Propose reasonable feature requests**: When suggesting new features, ensure they fit within the scope, style, and design of the project. Provide clear reasoning and use cases. -## 8. Documentation +## 10. Documentation - **Update the documentation**: If your change affects the functionality, please update the relevant documentation files to reflect this. -## 9. License +## 11. License - **Agree to the license**: By contributing to Linutil, you agree that your contributions will be licensed under the project's MIT license. diff --git a/README.md b/README.md index a2978c3c..cf494362 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,8 @@ **Linutil** is a distro-agnostic toolbox designed to simplify everyday Linux tasks. It helps you set up applications and optimize your system for specific use cases. The utility is actively developed in Rust 🦀, providing performance and reliability. -*Note:* Since the project is still in active development, you may encounter some issues. Please consider [submitting feedback](https://github.com/ChrisTitusTech/linutil/issues) if you do. +> [!NOTE] +> Since the project is still in active development, you may encounter some issues. Please consider [submitting feedback](https://github.com/ChrisTitusTech/linutil/issues) if you do. ## 💡 Usage