CONTRIBUTING.md 5.9 KB
Newer Older
1
## Contributor License Agreement
2
By contributing you agree to the [LICENSE](https://github.com/vhf/free-programming-books/blob/master/LICENSE) of this repository.
3

4 5 6
## Contributor Code of Conduct
By contributing you agree to respect the [Code of Conduct](https://github.com/vhf/free-programming-books/blob/master/CODE_OF_CONDUCT.md) of this repository.

V
Victor Felder 已提交
7
## In a nutshell
T
Thomas Cort 已提交
8
1. "A link to easily download a book" is not always a link to a *free* book. Please only contribute free content. Make sure it's free.
V
Victor Felder 已提交
9 10
2. You don't have to know git: if you found something of interest which is *not already in this repo*, please open an issue with your links propositions.
    - If you know git, please fork the repo and send pull requests.
11
3. We have 5 kinds of lists. Choose the right one:
12
    
V
Victor Felder 已提交
13
    - *Books* : PDF, HTML, ePub, a gitbook.io based site, a Git repo, etc.
T
Thomas Cort 已提交
14
    - *Courses* : A course is a learning material which is not a book and where there is no interactive tool embedded in the site. [This is a course](http://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-006-introduction-to-algorithms-fall-2011/).
V
Victor Felder 已提交
15 16 17
    - *Interactive Tutorials* : An interactive website which lets the user type code or commands and evaluates the result (by "evaluate" we don't mean "grade"). e.g.: [Try Haskell](http://tryhaskell.org), [Try Github](http://try.github.io).
    - *JavaScript Resources* : Any resources teaching a JavaScript framework or library.
    - *Problem Sets & Competitive Programming* : A website or software which lets you assess your programming skills by solving simple or complex problems, with or without code review, with or without comparing the results with other users.
18

V
Victor Felder 已提交
19
4. Make sure to follow the [guidelines below](#guidelines) and respect the [Markdown formatting](#formatting) of the files
20

V
Victor Felder 已提交
21
### Guidelines
22 23
- make sure a book is free. Double-check if needed
- we don't accept files hosted on google drive, dropbox, mega, scribd, issuu and other similar file upload platforms
24 25
- insert your links in alphabetical order. If you see a misplaced link, please reorder it and submit a PR
- use the link with the most authoritative source (meaning author's website is better than editor's website is better than third party website)
V
Victor Felder 已提交
26
    + no file hosting services (this includes (but is not limited to) Dropbox and Google Drive links)
27 28 29 30 31 32 33 34 35 36 37 38 39 40
- always prefer a `https` link over a `http` one -- as long as they are on the same domain and serve the same content
- on root domains, strip the trailing slash: `http://example.com` instead of `http://example.com/`
- always prefer the shortest link: `http://example.com/dir/` is better than `http://example.com/dir/index.html`
    + no URL shortener links
- usually prefer the "current" link over the "version" one: `http://example.com/dir/book/current/` is better than `http://example.com/dir/book/v1.0.0/index.html`
- if a link has an expired certificate/self-signed certificate/SSL issue of any other kind:
  1. *replace it* with its `http` counterpart if possible (because accepting exceptions can be complicated on mobile devices)
  2. *leave it* if no `http` version but link still accessible through `https` by adding an exception to the browser or ignoring the warning
  3. *remove it* otherwise
- if a link exists in multiple format, add a separate link with a note about each format
- if a resource exists at different places on the Internet
    + use the link with the most authoritative source (meaning author's website is better than editor's website is better than third party website)
    + if they link to different editions and you judge these editions are different enough to be worth keeping them, add a separate link with a note about each edition
- prefer atomic commits (one commit by addition/deletion/modification) over bigger commits. No need to squash your commits before submitting a PR. (We will never enforce this rule as it's just a matter of convenience for the maintainers)
41 42

### Formatting
V
Victor Felder 已提交
43
- All lists are `.md` files. Try to learn [Markdown](https://guides.github.com/features/mastering-markdown/) syntax. It's simple!
44 45
- All the lists start with an Index. The idea is to list and link all sections and subsections there. Keep it in alphabetical order.
- Sections are using level 3 headings (`###`), and subsections are level 4 headings (`####`).
46 47

The idea is to have
48 49 50 51 52 53
- `2` empty lines between last link and new section
- `1` empty line between heading & first link of its section
- `0` empty line between two links
- `1` empty line at the end of each `.md` file

Example:
54

55
    [...]
V
Victor Felder 已提交
56
    * [An Awesome Book](http://example.com/example.html)
V
Victor Felder 已提交
57 58
                                    (blank line)
                                    (blank line)
V
Victor Felder 已提交
59
    ### Example
V
Victor Felder 已提交
60
                                    (blank line)
V
Victor Felder 已提交
61 62
    * [Another Awesome Book](http://example.com/book.html)
    * [Some Other Book](http://example.com/other.html)
63

V
Victor Felder 已提交
64
- Don't put spaces between `]` and `(`
V
victor felder 已提交
65

V
Victor Felder 已提交
66 67 68 69
```
BAD : * [Another Awesome Book] (http://example.com/book.html)
GOOD: * [Another Awesome Book](http://example.com/book.html)
```
70

V
Victor Felder 已提交
71
- If you wish to mention the author, use ` - ` (a dash surrounded by single spaces)
72

V
Victor Felder 已提交
73
```
V
Victor Felder 已提交
74 75
BAD : * [Another Awesome Book](http://example.com/book.html)- John Doe
GOOD: * [Another Awesome Book](http://example.com/book.html) - John Doe
V
Victor Felder 已提交
76
```
77

78
- Put a single space between the link and its format
79

V
Victor Felder 已提交
80
```
V
Victor Felder 已提交
81 82
BAD : * [Another Awesome Book](http://example.com/book.pdf)(PDF)
GOOD: * [Another Awesome Book](http://example.com/book.pdf) (PDF)
V
Victor Felder 已提交
83
```
84

V
Victor Felder 已提交
85
- Author comes before format:
86

V
Victor Felder 已提交
87
```
V
Victor Felder 已提交
88 89
BAD : * [Another Awesome Book](http://example.com/book.pdf)- John Doe
GOOD: * [Another Awesome Book](http://example.com/book.pdf) - John Doe (PDF)
V
Victor Felder 已提交
90
```
91 92 93 94 95 96 97 98

- Multiple formats:

```
BAD : * [Another Awesome Book](http://example.com/)- John Doe (HTML)
BAD : * [Another Awesome Book](https://downloads.example.org/book.html)- John Doe (download site)
GOOD: * [Another Awesome Book](http://example.com/) - John Doe (HTML) [(PDF, EPUB)](https://downloads.example.org/book.html)
```