Skip to content

Latest commit

 

History

History
47 lines (34 loc) · 2.42 KB

CONTRIBUTING.md

File metadata and controls

47 lines (34 loc) · 2.42 KB

Contributing to Pumpkin

We appreciate your interest in contributing to Pumpkin! This document outlines the guidelines for submitting bug reports, feature suggestions, and code changes.

Getting Started

The easiest way to get started is by asking for help in our discord.

How to Contribute

There are several ways you can contribute to Pumpkin:

  • Reporting Bugs: If you encounter a bug, please search for existing issues on the issue tracker first. If you can't find a duplicate issue, open a new one. Provide a clear description of the bug, including steps to reproduce it if possible. Screenshots, logs, or code snippets can also be helpful.
  • Suggesting Features: Do you have an idea on how Pumpkin can be improved? Share your thoughts by opening an issue on the issue tracker. Describe the proposed feature in detail, including its benefits and potential implementation considerations.
  • Submitting Pull Requests: If you'd like to contribute code changes, fork the Pumpkin repository on GitHub. Install Rust at rust-lang.org. Make your changes on your local fork and create a pull request to the main repository. Ensure your code adheres to our project structure and style guidelines. Write clear and concise commit messages that describe your changes.

Docs

The Documentation of Pumpkin can be found at https://pumpkinmc.org/

**Tip: typos is a great Project to detect and automatically fix typos

Coding Guidelines

  • Working with Tokio and Rayon: When invoking CPU intensive work, this work should be done in the Rayon thread pool via rayon::spawn, Rayon's parallel iterators, or otherwise instead of from the Tokio runtime. However, it is important that the Tokio runtime not block on these Rayon calls. Instead, the data should be passed to the Tokio runtime via async means, for example: tokio::sync::mpsc. An example of how to properly do this can be found in pumpkin_world::level::Level::fetch_chunks.

Additional Information

We encourage you to comment on existing issues and pull requests to share your thoughts and provide feedback. Feel free to ask questions in the issue tracker or reach out to the project maintainers if you need assistance. Before submitting a large contribution, consider opening an issue, discussion or talk with us on our discord to discuss your approach.