Welcome to DevCANS C++ Resouces Repository! 😄
Before submitting pull requests, please make sure that you have read all the guidelines. If you have any doubts about this contribution guide, please open an issue and clearly state your concerns.
- First, have a look at open issues. They contain the list of resources we plan to add. Pick an unassigned issue.
- You can also create a new issue for addition of new resource that is not in the list.
- Just make sure that you are assigned for the issue before starting
- Add the resource.
- Send a PR.
- While sending a PR make sure you follow one issue per PR rule.
-
It is recommended to keep your changes grouped logically within individual commits. Maintainers find it easier to understand changes that are logically spilt across multiple commits.
git add file-name.md git commit -m "Commit Message(Title)" -m "Commit Body(Describe changes in brief)"
Examples of commit messages with semantic prefixes:
[ADD] <file-name>
[FIX] <file-name>
[MODIFY] <file-name>
[UPDATE] <file-name>
[REFACTOR] <file-name>
[ADD] RESOURCES.md
Common prefixes and their usecases:
- ADD: Add a new file
- FIX: A bug fix in file
- MODIFY: Change existing stuff/resource in the file
- UPDATE: Add new stuff/resource to the file
- REFACTOR: Restructure a file without changing external working
Example:
This adds RESOURCES.md which consists a curated list of resources for C++
- Maximum of 72 characters.
The recommendation is to add a line break at 72 characters, so that Git has plenty of room to indent text while still keeping everything under 80 characters overall. - Not mandatory - but helps explain what you’re doing.
- First person should not be used here.
- Keeping subject lines at this length ensures that they are readable, and explains the change in a concise way.
- Should describe the change.
- Should not include WIP prefix.
- Make sure your pull request is specific and focused. Instead of contributing "several resources" all at once contribute them all one by one separately (i.e. each pull request should comprise a resource along with its description).
- A pull request message consists of 3 parts:
- Title
- Short Desciption
- Issue reference
Example 1:
Adds Book Reference
This adds a new book resource for learning Standard Template Library(STL).
Closes https://github.com/DevCANS/cpp/issues/1
Example 2:
Fixes RESOURCES.md
Description of what has been fixed
Closes https://github.com/DevCANS/cpp/issues/5
- For a single commit, the title is the subject line of the commit message.
- Otherwise, the title should summarise the set of commits.
- Mention the file or section in file being modified.
- Not mandatory.
- Common prefixes and their usecases:
- ADD: Add a new file
- FIX: A bug fix in file
- MODIFY: Change existing stuff/resource in the file
- UPDATE: Add new stuff/resource to the file
- REFACTOR: Restructure a file without changing external working
- Must state the why and the how for the change.
- Usually this is the body of your commit message.
- Starts with a capital letter.
- Written in imperative present tense (i.e.
Add something
,not Adding something
orAdded something
). - Should describe all the changes in brief.
Example:
Closes https://github.com/DevCANS/cpp/issues/7
- Should use the
Fixes
keyword if your commit fixes a bug, orCloses
if it adds a feature/enhancement. - In some situations, e.g. bugs overcome in documents, the difference between
Fixes
andCloses
may be very small and subjective. If a specific issue may lead to an unintended behaviour from the user or from the program it should be considered a bug, and should be addresed withFixes
. If an issue is labelled withbug
you should always useFixes
. For all other issues useCloses
. - Should use full URL to the issue.
- There should be a single space between the
Fixes
orCloses
and the URL.
Note:
- The issue reference will automatically add the link of the commit in the issue.
- It will also automatically close the issue when the commit is accepted into repository.
- Filename should describe the content of the file. (e.g. :
books.cpp
which contains resources of for the books) - Use lowercase words with
"-"
as separator - For instance
compiler-installation-guidelines.MD is incorrect
CompilerInstallationGuidelines.md is incorrect
compilerInstallationGuidelines.md is incorrect
compiler_installation_guidelines.md is incorrect
compiler-installation-guidelines.md is correct
- Folder name should be in full lowercase. If the name has multiple words, separate them by dashes(-). (e.g. :
getting-started
) - We recommend adding files to existing directories as much as possible.
- New folder should contain
README.md
with proper description of the folder. - Use lowercase words with
"-"
as separator (spaces or"_"
not allowed) - For instance
SomeNewCategory is incorrect
someNewCategory is incorrect
some_new_category is incorrect
some-new-category is correct
- Make sure you describe the resource and how it can be used if not self explanatory.
- If you have modified/added documentation, please ensure that your language is concise and contains no grammar errors.
- Do not update
README.md
along with other changes, first create an issue and then link to that issue in your pull request to suggest specific changes required toREADME.md