You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
226 lines
13 KiB
226 lines
13 KiB
3 years ago
|
*[Read this in other languages](../README.md#translations)*
|
||
|
|
||
6 years ago
|
|
||
9 years ago
|
## Contributor License Agreement
|
||
8 years ago
|
By contributing you agree to the [LICENSE](https://github.com/EbookFoundation/free-programming-books/blob/master/LICENSE) of this repository.
|
||
11 years ago
|
|
||
9 years ago
|
## Contributor Code of Conduct
|
||
3 years ago
|
By contributing you agree to respect the [Code of Conduct](https://github.com/EbookFoundation/free-programming-books/blob/master/CODE_OF_CONDUCT.md) of this repository. ] ([translations](../README.md#translations))
|
||
9 years ago
|
|
||
9 years ago
|
## In a nutshell
|
||
7 years ago
|
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. We do not accept links to pages that *require* working email addresses to obtain books, but we welcome listings that request them.
|
||
6 years ago
|
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](https://github.com/EbookFoundation/free-programming-books/issues) with your links propositions.
|
||
|
- If you know Git, please Fork the repo and send pull requests.
|
||
9 years ago
|
3. We have 5 kinds of lists. Choose the right one:
|
||
8 years ago
|
|
||
9 years ago
|
- *Books* : PDF, HTML, ePub, a gitbook.io based site, a Git repo, etc.
|
||
7 years ago
|
- *Courses* : A course is a learning material which is not a book. [This is a course](http://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-006-introduction-to-algorithms-fall-2011/).
|
||
9 years ago
|
- *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).
|
||
7 years ago
|
- *Podcasts and Screencasts* : Podcasts and screencasts.
|
||
9 years ago
|
- *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.
|
||
9 years ago
|
|
||
6 years ago
|
4. Make sure to follow the [guidelines below](#guidelines) and respect the [Markdown formatting](#formatting) of the files.
|
||
9 years ago
|
|
||
3 years ago
|
5. GitHub Actions will run tests to make sure your lists are alphabetized and formatting rules are followed. Be sure to check that your changes pass the tests.
|
||
8 years ago
|
|
||
9 years ago
|
### Guidelines
|
||
8 years ago
|
- make sure a book is free. Double-check if needed. It helps the admins if you comment in the PR as to why you think the book is free.
|
||
3 years ago
|
- we don't accept files hosted on Google Drive, Dropbox, Mega, Scribd, Issuu and other similar file upload platforms
|
||
9 years ago
|
- insert your links in alphabetical order. If you see a misplaced link, please reorder it and submit a PR
|
||
3 years ago
|
- use the link with the most authoritative source (meaning the author's website is better than the editor's website, which is better than a third party website)
|
||
9 years ago
|
+ no file hosting services (this includes (but is not limited to) Dropbox and Google Drive links)
|
||
9 years ago
|
- 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:
|
||
3 years ago
|
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 is available but the link is still accessible through `https` by adding an exception to the browser or ignoring the warning.
|
||
|
3. *remove it* otherwise.
|
||
9 years ago
|
- 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)
|
||
3 years ago
|
+ 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 (see [Issue #2353](https://github.com/EbookFoundation/free-programming-books/issues/2353) to contribute to the discussion on formatting.)
|
||
9 years ago
|
- 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)
|
||
6 years ago
|
- if the book is older, include the publication date with the title.
|
||
8 years ago
|
- include the author name or names where appropriate. You can shorten author lists with "et al."
|
||
7 years ago
|
- if the book is not finished, and is still being worked on, add the "in process" notation, as described [below.](#in_process)
|
||
3 years ago
|
- if a resource is restored using the Internet Archive's Wayback Machine (or similar), add the "archived" notation, as described [below](#archived). The best versions to use are recent and complete.
|
||
7 years ago
|
- if an email address or account setup is requested before download is enabled, add language-appropriate notes in parentheses, e.g.: `(email address *requested*, not required)`
|
||
11 years ago
|
|
||
|
### Formatting
|
||
9 years ago
|
- All lists are `.md` files. Try to learn [Markdown](https://guides.github.com/features/mastering-markdown/) syntax. It's simple!
|
||
9 years ago
|
- 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 (`####`).
|
||
11 years ago
|
|
||
3 years ago
|
The idea is to have:
|
||
|
- `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.
|
||
9 years ago
|
|
||
|
Example:
|
||
11 years ago
|
|
||
9 years ago
|
[...]
|
||
9 years ago
|
* [An Awesome Book](http://example.com/example.html)
|
||
9 years ago
|
(blank line)
|
||
|
(blank line)
|
||
9 years ago
|
### Example
|
||
9 years ago
|
(blank line)
|
||
9 years ago
|
* [Another Awesome Book](http://example.com/book.html)
|
||
|
* [Some Other Book](http://example.com/other.html)
|
||
11 years ago
|
|
||
6 years ago
|
- Don't put spaces between `]` and `(`:
|
||
11 years ago
|
|
||
9 years ago
|
```
|
||
|
BAD : * [Another Awesome Book] (http://example.com/book.html)
|
||
|
GOOD: * [Another Awesome Book](http://example.com/book.html)
|
||
|
```
|
||
11 years ago
|
|
||
6 years ago
|
- If you include the author, use ` - ` (a dash surrounded by single spaces):
|
||
11 years ago
|
|
||
9 years ago
|
```
|
||
9 years ago
|
BAD : * [Another Awesome Book](http://example.com/book.html)- John Doe
|
||
|
GOOD: * [Another Awesome Book](http://example.com/book.html) - John Doe
|
||
9 years ago
|
```
|
||
11 years ago
|
|
||
6 years ago
|
- Put a single space between the link and its format:
|
||
11 years ago
|
|
||
9 years ago
|
```
|
||
7 years ago
|
BAD : * [A Very Awesome Book](https://example.org/book.pdf)(PDF)
|
||
|
GOOD: * [A Very Awesome Book](https://example.org/book.pdf) (PDF)
|
||
9 years ago
|
```
|
||
11 years ago
|
|
||
9 years ago
|
- Author comes before format:
|
||
11 years ago
|
|
||
9 years ago
|
```
|
||
6 years ago
|
BAD : * [A Very Awesome Book](https://example.org/book.pdf)- (PDF) Jane Roe
|
||
7 years ago
|
GOOD: * [A Very Awesome Book](https://example.org/book.pdf) - Jane Roe (PDF)
|
||
9 years ago
|
```
|
||
9 years ago
|
|
||
|
- 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)
|
||
|
```
|
||
8 years ago
|
|
||
|
- Include publication year in title for older books:
|
||
|
|
||
|
```
|
||
6 years ago
|
BAD : * [A Very Awesome Book](https://example.org/book.html) - Jane Roe - 1970
|
||
7 years ago
|
GOOD: * [A Very Awesome Book (1970)](https://example.org/book.html) - Jane Roe
|
||
|
```
|
||
|
|
||
|
<a name="in_process"></a>
|
||
6 years ago
|
- In-process books:
|
||
7 years ago
|
|
||
|
```
|
||
3 years ago
|
GOOD: * [Will Be An Awesome Book Soon](http://example.com/book2.html) - John Doe (HTML) (:construction: *in process*)
|
||
8 years ago
|
```
|
||
5 years ago
|
|
||
3 years ago
|
<a name="archived"></a>
|
||
|
- Archived link:
|
||
|
|
||
|
```
|
||
|
GOOD: * [A Way-backed Interesting Book](https://web.archive.org/web/20211016123456/http://example.com/) - John Doe (HTML) *(:card_file_box: archived)*
|
||
|
```
|
||
|
|
||
4 years ago
|
### Notes
|
||
|
|
||
|
While the basics are relatively simple, there is a great diversity in the resources we list. Here are some notes on how we deal with this diversity.
|
||
|
|
||
|
#### Metadata
|
||
|
|
||
|
Our lists provide a minimal set of metadata: titles, URLs, creators, platforms, and access notes.
|
||
|
|
||
|
##### Titles
|
||
|
|
||
|
- No invented titles. We try to take titles from the resources themselves; contributors are admonished not to invent titles or use them editorially if this can be avoided. An exception is for older works; if they are primarily of historical interest, a year in parentheses appended to the title helps users know if they are of interest.
|
||
3 years ago
|
- No ALLCAPS titles. Usually title case is appropriate, but when doubt use the capitalization from the source
|
||
4 years ago
|
|
||
|
##### URLs
|
||
|
|
||
|
- We don't permit shortened URLs.
|
||
|
- Tracking codes must be removed from the URL.
|
||
|
- International URLs should be escaped. Browser bars typically render these to Unicode, but use copy and paste, please.
|
||
|
- Secure (https) URLs are always preferred over non-secure (http) urls where https has been implemented.
|
||
|
- We don't like URLs that point to webpages that don't host the listed resource, but instead point elsewhere.
|
||
|
|
||
|
##### Creators
|
||
|
|
||
|
- We want to credit the creators of free resources where appropriate, including translators!
|
||
|
- For translated works the original author should be credited.
|
||
|
- We do not permit links for Creators.
|
||
3 years ago
|
- For compilation or remixed works, the "creator" may need a description. For example, "GoalKicker" or "RIP Tutorial" books are credited as "Compiled from StackOverflow documentation"
|
||
4 years ago
|
|
||
|
##### Platforms and Access Notes
|
||
|
|
||
3 years ago
|
- Courses. Especially for our course lists, the platform is an important part of the resource description. This is because course platforms have different affordances and access models. While we usually won't list a book that requires a registration, many course platforms have affordances that don't work without some sort of account. Example course platforms include Coursera, EdX, Udacity, and Udemy. When a course depends on a platform, the platform name should be listed in parentheses.
|
||
4 years ago
|
- YouTube. We have many courses which consist of YouTube playlists. We do not list Youtube as a platform, we try to list the Youtube creator, which is often a sub-platform.
|
||
|
- YouTube videos. We usually don't link to individual YouTube videos unless they are more than an hour long and are structured like a course or a tutorial.
|
||
|
- Leanpub. Leanpub hosts books with a variety of access models. Sometimes a book can be read without registration; sometimes a book requires a Leanpub account for free access. Given quality of the books and the mixture and fluidity of Leanpub access models, we permit listing of the latter with the access note *(Leanpub account or valid email requested)*
|
||
|
|
||
|
#### Genres
|
||
|
|
||
|
The first rule in deciding which list a resource belongs in is to see how the resource describes itself. If it calls itself a book, then maybe it's a book.
|
||
|
|
||
|
##### Genres we don't list
|
||
|
|
||
|
Because the Internet is vast, we don't include in our lists:
|
||
|
|
||
|
- blogs
|
||
|
- blog posts
|
||
|
- articles
|
||
|
- websites (except for those that host LOTS of items that we list.)
|
||
|
- videos that aren't courses or screencasts.
|
||
|
- book chapters
|
||
|
- teaser samples from books
|
||
|
- IRC or Telegram channels
|
||
|
- Slacks or mailing lists
|
||
|
|
||
|
Our competitive programming lists are not as strict about these exclusions. The scope of the repo is determined by the community; if you want to suggest a change or addition to the scope, please use an issue to make the suggestion.
|
||
|
|
||
|
|
||
|
##### Books vs. Other Stuff
|
||
|
|
||
|
We're not that fussy about book-ness. Here are some attributes that signify that a resource is a book:
|
||
|
|
||
3 years ago
|
- it has an ISBN (International Standard Book Number)
|
||
4 years ago
|
- it has a Table of Contents
|
||
3 years ago
|
- a downloadable version is offered, especially ePub files.
|
||
4 years ago
|
- it has editions
|
||
|
- it doesn't depend on interactive content or videos
|
||
|
- it tries to comprehensively cover a topic
|
||
|
- it's self-contained
|
||
|
|
||
|
There are lots of books that we list that don't have these attributes; it can depend on context.
|
||
|
|
||
|
|
||
|
##### Books vs. Courses
|
||
|
|
||
|
Sometimes these can be hard to distinguish!
|
||
|
|
||
4 years ago
|
Courses often have associated textbooks, which we would list in our books lists. Courses have lectures, exercises, tests, notes or other didactic aids. A single lecture or video by itself is not a course. A powerpoint is not a course.
|
||
4 years ago
|
|
||
|
|
||
|
##### Interactive Tutorials vs. Other stuff
|
||
|
|
||
|
If you can print it out and retain its essence, it's not an Interactive Tutorial.
|
||
|
|
||
|
|
||
5 years ago
|
### Automation
|
||
4 years ago
|
|
||
3 years ago
|
- Formatting rules enforcement is automated via [GitHub Actions](https://github.com/features/actions) using [fpb-lint](https://github.com/vhf/free-programming-books-lint) (see [.github/workflows/fpb-lint.yml](.github/workflows/fpb-lint.yml))
|
||
5 years ago
|
- URL validation uses [awesome_bot](https://github.com/dkhamsing/awesome_bot)
|
||
|
- To trigger URL validation, push a commit that includes a commit message containing `check_urls=file_to_check`:
|
||
|
|
||
|
```
|
||
|
check_urls=free-programming-books.md free-programming-books-en.md
|
||
|
```
|
||
|
|
||
|
- You may specify more than one file to check, using a single space to separate each entry.
|
||
3 years ago
|
- If you specify more than one file, results of the build are based on the result of the last file checked. You should be aware that you may get passing green builds due to this so be sure to inspect the build log at the end of the pull request by clicking on "Show all checks" -> "Details".
|