Back to home page

EIC code displayed by LXR

 
 

    


Warning, /tutorial-reconstruction-algorithms/bin/boilerplate/CONTRIBUTING.md is written in an unsupported language. File is not indexed.

0001 # Contributing
0002 
0003 [The Carpentries][c-site] ([Software Carpentry][swc-site], [Data Carpentry][dc-site], and [Library Carpentry][lc-site]) are open source projects,
0004 and we welcome contributions of all kinds:
0005 new lessons,
0006 fixes to existing material,
0007 bug reports,
0008 and reviews of proposed changes are all welcome.
0009 
0010 ## Contributor Agreement
0011 
0012 By contributing,
0013 you agree that we may redistribute your work under [our license](LICENSE.md).
0014 In exchange,
0015 we will address your issues and/or assess your change proposal as promptly as we can,
0016 and help you become a member of our community.
0017 Everyone involved in [The Carpentries][c-site]
0018 agrees to abide by our [code of conduct](CODE_OF_CONDUCT.md).
0019 
0020 ## How to Contribute
0021 
0022 The easiest way to get started is to file an issue
0023 to tell us about a spelling mistake,
0024 some awkward wording,
0025 or a factual error.
0026 This is a good way to introduce yourself
0027 and to meet some of our community members.
0028 
0029 1.  If you do not have a [GitHub][github] account,
0030     you can [send us comments by email][email].
0031     However,
0032     we will be able to respond more quickly if you use one of the other methods described below.
0033 
0034 2.  If you have a [GitHub][github] account,
0035     or are willing to [create one][github-join],
0036     but do not know how to use Git,
0037     you can report problems or suggest improvements by [creating an issue][issues].
0038     This allows us to assign the item to someone
0039     and to respond to it in a threaded discussion.
0040 
0041 3.  If you are comfortable with Git,
0042     and would like to add or change material,
0043     you can submit a pull request (PR).
0044     Instructions for doing this are [included below](#using-github).
0045 
0046 ## Where to Contribute
0047 
0048 1.  If you wish to change this lesson,
0049     please work in <https://github.com/swcarpentry/FIXME>,
0050     which can be viewed at <https://swcarpentry.github.io/FIXME>.
0051 
0052 2.  If you wish to change the example lesson,
0053     please work in <https://github.com/carpentries/lesson-example>,
0054     which documents the format of our lessons
0055     and can be viewed at <https://carpentries.github.io/lesson-example>.
0056 
0057 3.  If you wish to change the template used for workshop websites,
0058     please work in <https://github.com/carpentries/workshop-template>.
0059     The home page of that repository explains how to set up workshop websites,
0060     while the extra pages in <https://carpentries.github.io/workshop-template>
0061     provide more background on our design choices.
0062 
0063 4.  If you wish to change CSS style files, tools,
0064     or HTML boilerplate for lessons or workshops stored in `_includes` or `_layouts`,
0065     please work in <https://github.com/carpentries/styles>.
0066 
0067 ## What to Contribute
0068 
0069 There are many ways to contribute,
0070 from writing new exercises and improving existing ones
0071 to updating or filling in the documentation
0072 and submitting [bug reports][issues]
0073 about things that do not work, are not clear, or are missing.
0074 If you are looking for ideas, please see the 'Issues' tab for
0075 a list of issues associated with this repository,
0076 or you may also look at the issues for [Data Carpentry][dc-issues], 
0077 [Software Carpentry][swc-issues], and [Library Carpentry][lc-issues] projects.
0078 
0079 Comments on issues and reviews of pull requests are just as welcome:
0080 we are smarter together than we are on our own.
0081 Reviews from novices and newcomers are particularly valuable:
0082 it is easy for people who have been using these lessons for a while
0083 to forget how impenetrable some of this material can be,
0084 so fresh eyes are always welcome.
0085 
0086 ## What *Not* to Contribute
0087 
0088 Our lessons already contain more material than we can cover in a typical workshop,
0089 so we are usually *not* looking for more concepts or tools to add to them.
0090 As a rule,
0091 if you want to introduce a new idea,
0092 you must (a) estimate how long it will take to teach
0093 and (b) explain what you would take out to make room for it.
0094 The first encourages contributors to be honest about requirements;
0095 the second, to think hard about priorities.
0096 
0097 We are also not looking for exercises or other material that will only run on one platform.
0098 Our workshops typically contain a mixture of Windows, macOS, and Linux users;
0099 in order to be usable,
0100 our lessons must run equally well on all three.
0101 
0102 ## Using GitHub
0103 
0104 If you choose to contribute via GitHub, you may want to look at
0105 [How to Contribute to an Open Source Project on GitHub][how-contribute].
0106 To manage changes, we follow [GitHub flow][github-flow].
0107 Each lesson has at least two maintainers who review issues and pull requests or encourage others to do so.
0108 The maintainers are community volunteers and have final say over what gets merged into the lesson.
0109 To use the web interface for contributing to a lesson:
0110 
0111 1.  Fork the originating repository to your GitHub profile.
0112 2.  Within your version of the forked repository, move to the `gh-pages` branch and
0113 create a new branch for each significant change being made.
0114 3.  Navigate to the file(s) you wish to change within the new branches and make revisions as required.
0115 4.  Commit all changed files within the appropriate branches.
0116 5.  Create individual pull requests from each of your changed branches
0117 to the `gh-pages` branch within the originating repository.
0118 6.  If you receive feedback, make changes using your issue-specific branches of the forked
0119 repository and the pull requests will update automatically.
0120 7.  Repeat as needed until all feedback has been addressed.
0121 
0122 When starting work, please make sure your clone of the originating `gh-pages` branch is up-to-date
0123 before creating your own revision-specific branch(es) from there.
0124 Additionally, please only work from your newly-created branch(es) and *not*
0125 your clone of the originating `gh-pages` branch.
0126 Lastly, published copies of all the lessons are available in the `gh-pages` branch of the originating
0127 repository for reference while revising.
0128 
0129 ## Other Resources
0130 
0131 General discussion of [Software Carpentry][swc-site], [Data Carpentry][dc-site], and [Library Carpentry][lc-site]
0132 happens on the [discussion mailing list][discuss-list],
0133 which everyone is welcome to join.
0134 You can also [reach us by email][email].
0135 
0136 [email]: mailto:team@carpentries.org
0137 [dc-issues]: https://github.com/issues?q=user%3Adatacarpentry
0138 [dc-lessons]: http://datacarpentry.org/lessons/
0139 [dc-site]: http://datacarpentry.org/
0140 [discuss-list]: https://carpentries.topicbox.com/groups/discuss
0141 [github]: https://github.com
0142 [github-flow]: https://guides.github.com/introduction/flow/
0143 [github-join]: https://github.com/join
0144 [how-contribute]: https://app.egghead.io/playlists/how-to-contribute-to-an-open-source-project-on-github
0145 [issues]: https://guides.github.com/features/issues/
0146 [swc-issues]: https://github.com/issues?q=user%3Aswcarpentry
0147 [swc-lessons]: https://software-carpentry.org/lessons/
0148 [swc-site]: https://software-carpentry.org/
0149 [c-site]: https://carpentries.org/
0150 [lc-site]: https://librarycarpentry.org/
0151 [lc-issues]: https://github.com/issues?q=user%3Alibrarycarpentry