Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Fetching contributors…
Cannot retrieve contributors at this time
142 lines (117 sloc) 5.34 KB
<!DOCTYPE html>
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7; IE=EmulateIE9">
<title>Guide to making dygraphs changes</title>
<style type="text/css">
code {
white-space: pre;
border: 1px dashed black;
display: inline-block;
margin-left: 5px;
margin-right: 5px;
padding: 2px;
pre {
white-space: pre;
border: 1px dashed black;
padding: 5px;
body { max-width: 800px; }
ol > li { padding: 5px; }
<h2>Guide to making dygraphs changes</h2>
<p>So you've made a change to dygraphs and would like to contribute it back
to the open source project. Wonderful!</p>
<p>This is a step-by-step guide explaining how to do it.</p>
<h3>dygraphs style</h3>
<p>First of all, please try to follow the style of the existing dygraphs
code. This will make the review process go much more smoothly.<p>
<p>A few salient points:</p>
<li> I try to adhere to Google's <a
JS style guide</a> and would appreciate it if you try to as well. This
<li>No tabs! Indent using two spaces.
<li>Use camelCase for variable and function names.
<li>Limit lines to 80 characters.
<li>Please run '' to see if you've introduced any new violations.
<li>If you've added a new feature, add a test for it (in the tests/
directory) or a gallery entry.
<li>If you've added an option, document it in
dygraph-options-reference.js. You'll get lots of warnings if you don't.
<li>If you've fixed a bug or added a feature, add an auto_test for
This ensures that we won't inadvertently break your feature in the
future. To do this, either add to an existing auto_test in
auto_tests/tests or run "auto_tests/misc/ your-test-name" to
create a new one. You can run your auto_test in any browser by visiting
<h3>Sending a Pull Request</h3>
<p>dygraphs is hosted on github, which uses a "pull request" model. They
have a good writeup <a
href="">here</a>. These
instructions discuss dygraphs more specifically.</p>
<p>The list of steps may look a bit daunting, but it's not too bad,
especially if you have any familiarity with git or github. If you run into
any problems while following the instructions, feel free to contact
<p>Why not just take patches? This process means less work for me (the
maintainer) and it also results in your name appearing in the list of
dygraphs commits. This lets you take credit for your work.</p>
<li>Create an account on <a href="">github</a>. This is
free, painless and will let you claim credit for your changes.
<li>Install git. github has a good writeup <a
<li>Create a fork of the dygraphs repository on github by
clicking <a href="">this link</a> and
then the "Fork" button.
<li>You should see a URL along the lines of
<code></code><br/>Copy this, open up a
terminal and run<br/>
<pre>git clone</pre> This
pulls the dygraphs code down onto your local disk.
<li>cd into the dygraphs directory and make your changes.<br/>
If you've already got them somewhere else, just copy them over.<br/>
<li>Be a good citizen! Make sure your code follows the guidelines
You'll have to do this before I accept your changes, so you may as well
do it now
<li>Commit your changes locally: run
<pre>git add .
git commit</pre>
Type in a description of your change. This will
eventually appear in the dygraphs <a
href="">commit list</a>.
<li>Push your changes to github by running <pre>git push</pre>This will
send your changes to your forked repository on github.
<li>Go to your fork of dygraphs on github (i.e.<br/>
Click the "Pull Request" button.<br/>
This will send me an email with a pointer to your changes.
<li>I'll review your changes and (unless your code is perfect!) give you
some feedback. Make these suggested changes in your local git client and
re-run "git commit" and "git push" so that I can see them.
<li>Once your change is ready, I'll pull it into the main dygraphs
repository and publish it to the web.
<!-- Google Analytics -->
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-769809-2']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
Jump to Line
Something went wrong with that request. Please try again.