From 67da3ee8090ddb258f7bd7afc3a55c2fc3a0d785 Mon Sep 17 00:00:00 2001 From: Chris Eppstein Date: Tue, 12 Oct 2010 02:30:55 -0700 Subject: [PATCH] Start documentation on how to contribute to compass. --- doc-src/content/CONTRIBUTING.markdown | 159 ++++++++++++++++++++++++++ 1 file changed, 159 insertions(+) create mode 100644 doc-src/content/CONTRIBUTING.markdown diff --git a/doc-src/content/CONTRIBUTING.markdown b/doc-src/content/CONTRIBUTING.markdown new file mode 100644 index 00000000..a3ecbda9 --- /dev/null +++ b/doc-src/content/CONTRIBUTING.markdown @@ -0,0 +1,159 @@ +Contributing to Compass +======================= + +Thank you for your interest in contributing to Compass. Our goal is to make it as easy +as we can for you to contribute changes to compass -- So if there's something here that +seems harder than it aught to be, please let us know. + +Step 1: If you do not have a github account, create one. +Step 2: Fork Compass to your account. + +Now we're at a decision point. What kind of change do you intend to make? + +* [Fix a typo (or some other trivial change)](#trivial-changes) +* [Documentation Changes](#documentation-changes) +* [Stylesheet Changes](#stylesheet-changes) +* [Ruby Changes](#ruby-changes) + +Here's some general information about the project you might find useful along the way: + +* [Submitting Patches](#patches) +* [Project Structure](#project-structure) +* [Project Architecture](#project-architecture) + * [Command Line](#cli-architecture) + * [Extensions](#extensions-architecture) + * [Configuration](#configuration-architecture) +* [General Philosophy](#project-philosophy) +* [Stylesheet Conventions](#api-conventions) +* [In Case of Emergency](#faq) + +

Making Trivial Changes

+ +Thanks to Github, making small changes is super easy. After forking the project navigate +to the file you want to change and click the edit link. Change the file, write a commit +message, and click the `Commit` button. Now you need to get your change [accepted](#patches). + +

Making Documentation Changes

+ +The compass documentation is stored in two places. First, the doc-src directory is +where the documentation lives -- however much of the documentation is generated +from comments in the Sass files themselves. More information on [changing +documentation][documentation]. Once your changes are pushed, you can +[submit them](#patches). + +

Making Stylesheet Changes

+ +TODO + +

Making Ruby Changes

+ +TODO + +

Submitting Patches

+ +It is a good idea to discuss new features ideas with the compass users and developers +before building something. Please don't by shy; send an email to the [compass mailing +list](http://groups.google.com/group/compass-users). + +If you are submitting features that have more than one changeset, please create a topic +branch to hold the changes while they are pending merge and also to track iterations to +the original submission. To create a topic branch: + + $ git checkout -b new_branch_name + ... make more commits if needed ... + $ git push origin new_branch_name + +You can now see these changes online at a url like: + + http://github.com/your_user_name/compass/commits/new_branch_name + +If you have single-commit patches, it is fine to keep them on master. But do keep in +mind that these changesets might be +[cherry-picked](#recovering-from-rebased-or-cherry-picked-changesets). + +Once your changeset(s) are on github, select the appropriate branch containing your +changes and send a pull request. Most of the description of your changes should be +in the commit messages -- so no need to write a whole lot in the pull request message. +However, the pull request message is a good place to provide a rationale or use case +for the change if you think one is needed. More info on [pull requests][pulls]. + +Pull requests are then managed like an issue from the [compass issues page][issues]. +A code review will be performed by a compass core team member, and one of three outcomes +will result: + +1. The change is rejected -- Not all changes are right for [compass's + philosophy](#project-philosophy). If your change is rejected it might be better + suited for a plugin, at least until it matures and/or proves itself with the users. +2. The change is rejected, unless -- Sometimes, there are missing pieces, or + other changes that need to be made before the change can be accepted. Comments + will be left on the commits indicating what issues need to be addressed. +3. The change is accepted -- The change is merged into compass, sometimes minor + changes are then applied by the committer after the merge. + +

Project Structure

+ +TODO + +

Project Architecture

+ +TODO + +

Command Line

+ +TODO + +

Extensions

+ +TODO + +

Configuration

+ +TODO + +

General Philosophy

+ +TODO + +

Stylesheet Conventions

+ +TODO + +

Common Problems/Misc

+ +

Setting up Git

+ +Please follow [these instructions](http://help.github.com/git-email-settings/) +to set up your email address and attribution information. + +Download your git repo: + + git clone git@github.com:your_username/compass.git + +Set up a remote to the main repo: + + cd compass + git remote add chriseppstein git://github.com/chriseppstein/compass.git + +Getting recent changes from the main repo: + + git fetch chriseppstein + +

You cherry-picked/rebased +my changes. What should I do?

+Depending on any number of reasons, including but not limited to the alignment of the stars, +Your changes might not be merged into compass using a simple merge. For instance, we might +decide to place a change against master into stable instead, or we might squish all your +changes together into a single commit at the time of merge, or we might want a change you've +submitted but not a change that it was placed onto top of. In these cases, there are +a couple of ways you can react: + +1. If you have some changes on a branch that were not yet accepted, but other changes on that + branch were accepted then you should run the following command (make sure to fetch first): + `git checkout branch_name; git rebase chriseppstein/master` (assuming the change was applied + to the master branch) +2. If all your changes on the topic branch were accepted or you don't care to keep it around + anymore: `git checkout master; git branch -D branch_name; git push origin :branch_name` + +[pulls]: http://help.github.com/pull-requests/ +[issues]: http://github.com/chriseppstein/compass/issues +[documentation]: http://github.com/chriseppstein/compass/blob/stable/doc-src/README.markdown \ No newline at end of file