This book is developed collaboratively and openly, here on GitHub. We accept comments, contributions and corrections from all.
CONTENT FREEZE - FIRST EDITION IN PRODUCTION
Before contributing with a Pull Request, please read the current PROJECT STATUS.
If the current PROJECT STATUS is CONTENT FREEZE, please keep these points in mind;
- Please submit only PRs for errors that a non-domain-expert copy editor might miss. Do not submit PRs for typos, grammar and syntax, as those are part of the copy editors job.
- Please don't merge code. Any changes will have to be applied manually (by the Author) after copy edit and before final proof, if the copy editor doesn't catch the same errors.
You can chat with the authors and editors on Gitter chat.
All contributions must be properly licensed and attributed. If you are contributing your own original work, then you are offering it under a CC-BY license (Creative Commons Attribution). You are responsible for adding your own name or pseudonym in the Acknowledgments section in the Preface, as attribution for your contribution.
If you are sourcing a contribution from somewhere else, it must carry a compatible license. The book will initially be released under a CC-BY-NC-ND license which means that contributions must be licensed under open licenses such as MIT, CC0, CC-BY, etc. You need to indicate the original source and original license, by including an asciidoc markup comment above your contribution, like this:
////
Source: https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20-token-standard.md
License: CC0
Added by: @aantonop
////
The best way to contribute to this book is by making a pull request:
- Login with your GitHub account or create one now
- Fork the
ethereumbook
repository. Work on your fork. - Create a new branch on which to make your change, e.g.
git checkout -b my_code_contribution
, or make the change on thedevelop
branch. - Please do one pull request PER asciidoc file, to avoid large merges. Edit the asciidoc file where you want to make a change or create a new asciidoc file in the
contrib
directory if you're not sure where your contribution might fit. - Edit
preface.asciidoc
and add your own name to the list of contributors under the Acknowledgment section. Use your name, or a GitHub username, or a pseudonym. - Commit your change. Include a commit message describing the correction.
- Submit a pull request against the ethereumbook repository.
Here's a video tutorial to help you make your first pull request:
If you find a mistake and you're not sure how to fix it, or you don't know how to do a pull request, then you can file an Issue. Filing an Issue will help us see the problem and fix it.
Create a new Issue now!
Adjust heading style in each section as follows:
- Only the chapter/section should be level 2, everything else should be level 3 and below (level 1 is the book title itself). Each asciidoc file should start with a "==" heading.
- All lower case, except for first letter, proper nouns and acronyms. "What is this thing?", "What is the Ethereum sprocket?" "Who created the Ethereum Name Service (ENS)"
- Acronyms are spelled out, capitalized, with the acronym in parentheses. Once you have spelled out an acronym in one heading, we can keep it as an acronym in subsequent headings.
- No period at the end. Question mark if it is a question (generally avoid question headings, unless really appropriate)
- Should include a unique anchor (see #279), all lower case, underscore separated.
- Headings should be followed by a blank line.
- Heading should be followed by a paragraph of text, not a lower-level heading without any text. If you find one like this, add a TODO comment (line of 4 slashes "////", line with "TODO: add paragraph", line of 4 slashes)
All submission should use Unix-like line endings: LF (not CR, not CR/LF). All the postprocessing is done on Unix-like systems. Incorrect line endings, or changes to line endings cause confusion for the diff tools and make the whole file look like it has changed.
If you are unsure or your OS makes things difficult, consider using a developer's text editor such as Atom.
We are very grateful for the support of the entire Ethereum community. With your help, this will be a great book that can help thousands of developers get started and eventually "master" Ethereum. Thank you!