The Ray Tracing in One Weekend series is intended to be lightweight and accessible for all who want to learn about ray tracing and related graphics topics. To that end, we welcome feedback, proposals, and improvements.
In particular, we are now a dedicated GitHub organization. The books are now available in HTML from https://raytracing.github.io/, so we can keep the content up-to-date with the latest corrections and improvements.
We use release
as our release branch. Generally, changes should never go directly to the release
branch. All ongoing development work (and all of the latest changes) will be in the dev
branch.
However, we may want changes in other development branches (for example, in a dev-patch
branch for
a quick patch release). The appropriate target branch for any pull requests you want to make will be
determined in the associated issue first (all pull requests should have an associated issue).
The easiest way to help out is to log any issues you find in the books. Unclear passages, errors of all kinds, even better ways to present something -- just go to the issues page.
-
First ensure that the issue is still outstanding in the current development branch (
dev
). Often the issue has already been addressed or no longer applies to the latest in-development version. -
Before creating a new issue, please review existing issues to see if someone has already submitted the same one. Chances are you're not the first to encounter something, so a little quick research can save everyone some hassle. If you have new information, please continue the thread in the existing issue.
-
When entering a new issue, please include all relevant information. For content issues, include the book or books this applies to, and specific locations that should be reviewed. Similarly for code: please include the file, function/class, and line number(s) if that applies.
-
Finally, please keep issues focused on a single problem or suggestion. If discussion prompts you to think of a related issue, create a separate issue for that topic and add a link back to the original discussion or issue (just use the "#NNN" syntax for issue/discussion/pull-request NNN -- GitHub will automatically make this a link).
To contribute a change to the project, please follow these steps:
-
Let us know if you're willing to make the fix yourself.
-
Participate in the discussion as needed. We'll ensure that the work doesn't conflict with or duplicate other work planned or in progress, and decide which development branch is correct for the release type and release schedule.
-
Once you've received instructions to proceed with your change, create a new feature branch (or fork) from the assigned development branch (usually
dev
). -
Follow the existing code style.
-
Ensure that the change is complete:
-
Update all relevant source code for all three books (
src/*
). Since the code is developed as the books proceed, you may need to update many historical code listings as well, and this may require corresponding updates to the book text. -
Update all relevant code listings and text in all three books (
books/RayTracing*.html
). Follow existing style for the Markdeep source (for example, text should be wrapped to 100 characters). -
Provide clear and full commit descriptions: title line (50 characters max), followed by a blank line, and then a descriptive body with lines not exceeding 72 characters. If a commit is expected to completely resolve an outstanding issue, add a line "Resolves #NNN" to the bottom of your commit message, where NNN is the existing GitHub issue number. You may provide multiple such lines if applicable.
-
Include a one-line summary change at the bottom of the current development section in the changelog (
CHANGELOG.md
). Include a reference to the associated GitHub issue. -
For an example of the above, see issue #1262 and PR #1263.
-
-
When ready, create your pull request (PR) and request a review from "rt-reviewers".
-
Congratulate yourself for having been part of the 1% of contributors who actually read and followed these guidelines.
Note the code philosophy outlined in the first section of the first book. In short, the code is intended to be clear for everyone, using simple C/C++ idioms as much as possible. We have chosen to adopt some modern conventions where we feel it makes the code more accessible to non-C++ programmers. Please follow the existing coding style and simplicity when offering your suggested changes.
If anything above sounds daunting, note that you'll get massive credit for actually reading the CONTRIBUTING.md and following the process above -- so we'd be delighted to answer any questions and guide you through the process.
If you have any questions, feel free to ping me at steve@hollasch.net.