Create gh-pages branch via GitHub

gh-pages
Krzysztof Gabis 9 years ago
parent 1dcb778e8c
commit d9318845fd
  1. 189
      index.html
  2. 2
      params.json
  3. 116
      stylesheets/github-light.css
  4. 424
      stylesheets/normalize.css
  5. 582
      stylesheets/stylesheet.css

@ -1,36 +1,25 @@
<!doctype html> <!DOCTYPE html>
<html> <html lang="en-us">
<head> <head>
<meta charset="utf-8"> <meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="chrome=1">
<title>parson by kgabis</title> <title>parson by kgabis</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="stylesheets/styles.css"> <link rel="stylesheet" type="text/css" href="stylesheets/normalize.css" media="screen">
<link rel="stylesheet" href="stylesheets/pygment_trac.css"> <link href='http://fonts.googleapis.com/css?family=Open+Sans:400,700' rel='stylesheet' type='text/css'>
<script src="javascripts/scale.fix.js"></script> <link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no"> <link rel="stylesheet" type="text/css" href="stylesheets/github-light.css" media="screen">
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
</head> </head>
<body> <body>
<div class="wrapper"> <section class="page-header">
<header> <h1 class="project-name">parson</h1>
<h1 class="header">parson</h1> <h2 class="project-tagline">Lightweight json library written in C.</h2>
<p class="header">Lightweight json library written in C.</p> <a href="https://github.com/kgabis/parson" class="btn">View on GitHub</a>
<a href="https://github.com/kgabis/parson/zipball/master" class="btn">Download .zip</a>
<ul> <a href="https://github.com/kgabis/parson/tarball/master" class="btn">Download .tar.gz</a>
<li class="download"><a class="buttons" href="https://github.com/kgabis/parson/zipball/master">Download ZIP</a></li> </section>
<li class="download"><a class="buttons" href="https://github.com/kgabis/parson/tarball/master">Download TAR</a></li>
<li><a class="buttons github" href="https://github.com/kgabis/parson">View On GitHub</a></li> <section class="main-content">
</ul> <h2>
<p class="header">This project is maintained by <a class="header name" href="https://github.com/kgabis">kgabis</a></p>
</header>
<section>
<h2>
<a id="about" class="anchor" href="#about" aria-hidden="true"><span class="octicon octicon-link"></span></a>About</h2> <a id="about" class="anchor" href="#about" aria-hidden="true"><span class="octicon octicon-link"></span></a>About</h2>
<p>Parson is a lighweight <a href="http://json.org">json</a> library written in C.</p> <p>Parson is a lighweight <a href="http://json.org">json</a> library written in C.</p>
@ -67,44 +56,44 @@
<p>Here is a function, which prints basic commit info (date, sha and author) from a github repository. </p> <p>Here is a function, which prints basic commit info (date, sha and author) from a github repository. </p>
<div class="highlight highlight-c"><pre><span class="pl-st">void</span> <span class="pl-en">print_commits_info</span>(<span class="pl-s">const</span> <span class="pl-st">char</span> *username, <span class="pl-s">const</span> <span class="pl-st">char</span> *repo) { <div class="highlight highlight-c"><pre><span class="pl-k">void</span> <span class="pl-en">print_commits_info</span>(<span class="pl-k">const</span> <span class="pl-k">char</span> *username, <span class="pl-k">const</span> <span class="pl-k">char</span> *repo) {
JSON_Value *root_value; JSON_Value *root_value;
JSON_Array *commits; JSON_Array *commits;
JSON_Object *commit; JSON_Object *commit;
<span class="pl-s3">size_t</span> i; <span class="pl-c1">size_t</span> i;
<span class="pl-st">char</span> curl_command[<span class="pl-c1">512</span>]; <span class="pl-k">char</span> curl_command[<span class="pl-c1">512</span>];
<span class="pl-st">char</span> cleanup_command[<span class="pl-c1">256</span>]; <span class="pl-k">char</span> cleanup_command[<span class="pl-c1">256</span>];
<span class="pl-st">char</span> output_filename[] = <span class="pl-s1"><span class="pl-pds">"</span>commits.json<span class="pl-pds">"</span></span>; <span class="pl-k">char</span> output_filename[] = <span class="pl-s"><span class="pl-pds">"</span>commits.json<span class="pl-pds">"</span></span>;
<span class="pl-c">/* it ain't pretty, but it's not a libcurl tutorial */</span> <span class="pl-c">/* it ain't pretty, but it's not a libcurl tutorial */</span>
<span class="pl-s3">sprintf</span>(curl_command, <span class="pl-c1">sprintf</span>(curl_command,
<span class="pl-s1"><span class="pl-pds">"</span>curl -s <span class="pl-cce">\"</span>https://api.github.com/repos/<span class="pl-c1">%s</span>/<span class="pl-c1">%s</span>/commits<span class="pl-cce">\"</span> &gt; <span class="pl-c1">%s</span><span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>curl -s <span class="pl-cce">\"</span>https://api.github.com/repos/<span class="pl-c1">%s</span>/<span class="pl-c1">%s</span>/commits<span class="pl-cce">\"</span> &gt; <span class="pl-c1">%s</span><span class="pl-pds">"</span></span>,
username, repo, output_filename); username, repo, output_filename);
<span class="pl-s3">sprintf</span>(cleanup_command, <span class="pl-s1"><span class="pl-pds">"</span>rm -f <span class="pl-c1">%s</span><span class="pl-pds">"</span></span>, output_filename); <span class="pl-c1">sprintf</span>(cleanup_command, <span class="pl-s"><span class="pl-pds">"</span>rm -f <span class="pl-c1">%s</span><span class="pl-pds">"</span></span>, output_filename);
<span class="pl-s3">system</span>(curl_command); <span class="pl-c1">system</span>(curl_command);
<span class="pl-c">/* parsing json and validating output */</span> <span class="pl-c">/* parsing json and validating output */</span>
root_value = <span class="pl-s3">json_parse_file</span>(output_filename); root_value = <span class="pl-c1">json_parse_file</span>(output_filename);
<span class="pl-k">if</span> (<span class="pl-s3">json_value_get_type</span>(root_value) != JSONArray) { <span class="pl-k">if</span> (<span class="pl-c1">json_value_get_type</span>(root_value) != JSONArray) {
<span class="pl-s3">system</span>(cleanup_command); <span class="pl-c1">system</span>(cleanup_command);
<span class="pl-k">return</span>; <span class="pl-k">return</span>;
} }
<span class="pl-c">/* getting array from root value and printing commit info */</span> <span class="pl-c">/* getting array from root value and printing commit info */</span>
commits = <span class="pl-s3">json_value_get_array</span>(root_value); commits = <span class="pl-c1">json_value_get_array</span>(root_value);
<span class="pl-s3">printf</span>(<span class="pl-s1"><span class="pl-pds">"</span><span class="pl-c1">%-10.10s</span> <span class="pl-c1">%-10.10s</span> <span class="pl-c1">%s</span><span class="pl-cce">\n</span><span class="pl-pds">"</span></span>, <span class="pl-s1"><span class="pl-pds">"</span>Date<span class="pl-pds">"</span></span>, <span class="pl-s1"><span class="pl-pds">"</span>SHA<span class="pl-pds">"</span></span>, <span class="pl-s1"><span class="pl-pds">"</span>Author<span class="pl-pds">"</span></span>); <span class="pl-c1">printf</span>(<span class="pl-s"><span class="pl-pds">"</span><span class="pl-c1">%-10.10s</span> <span class="pl-c1">%-10.10s</span> <span class="pl-c1">%s</span><span class="pl-cce">\n</span><span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>Date<span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>SHA<span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>Author<span class="pl-pds">"</span></span>);
<span class="pl-k">for</span> (i = <span class="pl-c1">0</span>; i &lt; <span class="pl-s3">json_array_get_count</span>(commits); i++) { <span class="pl-k">for</span> (i = <span class="pl-c1">0</span>; i &lt; <span class="pl-c1">json_array_get_count</span>(commits); i++) {
commit = <span class="pl-s3">json_array_get_object</span>(commits, i); commit = <span class="pl-c1">json_array_get_object</span>(commits, i);
<span class="pl-s3">printf</span>(<span class="pl-s1"><span class="pl-pds">"</span><span class="pl-c1">%.10s</span> <span class="pl-c1">%.10s</span> <span class="pl-c1">%s</span><span class="pl-cce">\n</span><span class="pl-pds">"</span></span>, <span class="pl-c1">printf</span>(<span class="pl-s"><span class="pl-pds">"</span><span class="pl-c1">%.10s</span> <span class="pl-c1">%.10s</span> <span class="pl-c1">%s</span><span class="pl-cce">\n</span><span class="pl-pds">"</span></span>,
<span class="pl-s3">json_object_dotget_string</span>(commit, <span class="pl-s1"><span class="pl-pds">"</span>commit.author.date<span class="pl-pds">"</span></span>), <span class="pl-c1">json_object_dotget_string</span>(commit, <span class="pl-s"><span class="pl-pds">"</span>commit.author.date<span class="pl-pds">"</span></span>),
<span class="pl-s3">json_object_get_string</span>(commit, <span class="pl-s1"><span class="pl-pds">"</span>sha<span class="pl-pds">"</span></span>), <span class="pl-c1">json_object_get_string</span>(commit, <span class="pl-s"><span class="pl-pds">"</span>sha<span class="pl-pds">"</span></span>),
<span class="pl-s3">json_object_dotget_string</span>(commit, <span class="pl-s1"><span class="pl-pds">"</span>commit.author.name<span class="pl-pds">"</span></span>)); <span class="pl-c1">json_object_dotget_string</span>(commit, <span class="pl-s"><span class="pl-pds">"</span>commit.author.name<span class="pl-pds">"</span></span>));
} }
<span class="pl-c">/* cleanup code */</span> <span class="pl-c">/* cleanup code */</span>
<span class="pl-s3">json_value_free</span>(root_value); <span class="pl-c1">json_value_free</span>(root_value);
<span class="pl-s3">system</span>(cleanup_command); <span class="pl-c1">system</span>(cleanup_command);
} }
</pre></div> </pre></div>
@ -125,22 +114,22 @@
<p>In this example I'm using parson to save user information to a file and then load it and validate later.</p> <p>In this example I'm using parson to save user information to a file and then load it and validate later.</p>
<div class="highlight highlight-c"><pre><span class="pl-st">void</span> <span class="pl-en">persistence_example</span>(<span class="pl-st">void</span>) { <div class="highlight highlight-c"><pre><span class="pl-k">void</span> <span class="pl-en">persistence_example</span>(<span class="pl-k">void</span>) {
JSON_Value *schema = <span class="pl-s3">json_parse_string</span>(<span class="pl-s1"><span class="pl-pds">"</span>{<span class="pl-cce">\"</span>name<span class="pl-cce">\"</span>:<span class="pl-cce">\"\"</span>}<span class="pl-pds">"</span></span>); JSON_Value *schema = <span class="pl-c1">json_parse_string</span>(<span class="pl-s"><span class="pl-pds">"</span>{<span class="pl-cce">\"</span>name<span class="pl-cce">\"</span>:<span class="pl-cce">\"\"</span>}<span class="pl-pds">"</span></span>);
JSON_Value *user_data = <span class="pl-s3">json_parse_file</span>(<span class="pl-s1"><span class="pl-pds">"</span>user_data.json<span class="pl-pds">"</span></span>); JSON_Value *user_data = <span class="pl-c1">json_parse_file</span>(<span class="pl-s"><span class="pl-pds">"</span>user_data.json<span class="pl-pds">"</span></span>);
<span class="pl-st">char</span> buf[<span class="pl-c1">256</span>]; <span class="pl-k">char</span> buf[<span class="pl-c1">256</span>];
<span class="pl-s">const</span> <span class="pl-st">char</span> *name = <span class="pl-c1">NULL</span>; <span class="pl-k">const</span> <span class="pl-k">char</span> *name = <span class="pl-c1">NULL</span>;
<span class="pl-k">if</span> (user_data == <span class="pl-c1">NULL</span> || <span class="pl-s3">json_validate</span>(schema, user_data) != JSONSuccess) { <span class="pl-k">if</span> (user_data == <span class="pl-c1">NULL</span> || <span class="pl-c1">json_validate</span>(schema, user_data) != JSONSuccess) {
<span class="pl-s3">puts</span>(<span class="pl-s1"><span class="pl-pds">"</span>Enter your name:<span class="pl-pds">"</span></span>); <span class="pl-c1">puts</span>(<span class="pl-s"><span class="pl-pds">"</span>Enter your name:<span class="pl-pds">"</span></span>);
<span class="pl-s3">scanf</span>(<span class="pl-s1"><span class="pl-pds">"</span><span class="pl-c1">%s</span><span class="pl-pds">"</span></span>, buf); <span class="pl-c1">scanf</span>(<span class="pl-s"><span class="pl-pds">"</span><span class="pl-c1">%s</span><span class="pl-pds">"</span></span>, buf);
user_data = <span class="pl-s3">json_value_init_object</span>(); user_data = <span class="pl-c1">json_value_init_object</span>();
<span class="pl-s3">json_object_set_string</span>(<span class="pl-s3">json_object</span>(user_data), <span class="pl-s1"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>, buf); <span class="pl-c1">json_object_set_string</span>(<span class="pl-c1">json_object</span>(user_data), <span class="pl-s"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>, buf);
<span class="pl-s3">json_serialize_to_file</span>(user_data, <span class="pl-s1"><span class="pl-pds">"</span>user_data.json<span class="pl-pds">"</span></span>); <span class="pl-c1">json_serialize_to_file</span>(user_data, <span class="pl-s"><span class="pl-pds">"</span>user_data.json<span class="pl-pds">"</span></span>);
} }
name = <span class="pl-s3">json_object_get_string</span>(<span class="pl-s3">json_object</span>(user_data), <span class="pl-s1"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>); name = <span class="pl-c1">json_object_get_string</span>(<span class="pl-c1">json_object</span>(user_data), <span class="pl-s"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>);
<span class="pl-s3">printf</span>(<span class="pl-s1"><span class="pl-pds">"</span>Hello, <span class="pl-c1">%s</span>.<span class="pl-pds">"</span></span>, name); <span class="pl-c1">printf</span>(<span class="pl-s"><span class="pl-pds">"</span>Hello, <span class="pl-c1">%s</span>.<span class="pl-pds">"</span></span>, name);
<span class="pl-s3">json_value_free</span>(schema); <span class="pl-c1">json_value_free</span>(schema);
<span class="pl-s3">json_value_free</span>(user_data); <span class="pl-c1">json_value_free</span>(user_data);
<span class="pl-k">return</span>; <span class="pl-k">return</span>;
}</pre></div> }</pre></div>
@ -151,35 +140,35 @@
Object hierarchy is automatically created when addressing specific fields. Object hierarchy is automatically created when addressing specific fields.
In the following example I create a simple JSON value containing basic information about a person.</p> In the following example I create a simple JSON value containing basic information about a person.</p>
<div class="highlight highlight-c"><pre><span class="pl-st">void</span> <span class="pl-en">serialization_example</span>(<span class="pl-st">void</span>) { <div class="highlight highlight-c"><pre><span class="pl-k">void</span> <span class="pl-en">serialization_example</span>(<span class="pl-k">void</span>) {
JSON_Value *root_value = <span class="pl-s3">json_value_init_object</span>(); JSON_Value *root_value = <span class="pl-c1">json_value_init_object</span>();
JSON_Object *root_object = <span class="pl-s3">json_value_get_object</span>(root_value); JSON_Object *root_object = <span class="pl-c1">json_value_get_object</span>(root_value);
<span class="pl-st">char</span> *serialized_string = <span class="pl-c1">NULL</span>; <span class="pl-k">char</span> *serialized_string = <span class="pl-c1">NULL</span>;
<span class="pl-s3">json_object_set_string</span>(root_object, <span class="pl-s1"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>, <span class="pl-s1"><span class="pl-pds">"</span>John Smith<span class="pl-pds">"</span></span>); <span class="pl-c1">json_object_set_string</span>(root_object, <span class="pl-s"><span class="pl-pds">"</span>name<span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>John Smith<span class="pl-pds">"</span></span>);
<span class="pl-s3">json_object_set_number</span>(root_object, <span class="pl-s1"><span class="pl-pds">"</span>age<span class="pl-pds">"</span></span>, <span class="pl-c1">25</span>); <span class="pl-c1">json_object_set_number</span>(root_object, <span class="pl-s"><span class="pl-pds">"</span>age<span class="pl-pds">"</span></span>, <span class="pl-c1">25</span>);
<span class="pl-s3">json_object_dotset_string</span>(root_object, <span class="pl-s1"><span class="pl-pds">"</span>address.city<span class="pl-pds">"</span></span>, <span class="pl-s1"><span class="pl-pds">"</span>Cupertino<span class="pl-pds">"</span></span>); <span class="pl-c1">json_object_dotset_string</span>(root_object, <span class="pl-s"><span class="pl-pds">"</span>address.city<span class="pl-pds">"</span></span>, <span class="pl-s"><span class="pl-pds">"</span>Cupertino<span class="pl-pds">"</span></span>);
<span class="pl-s3">json_object_dotset_value</span>(root_object, <span class="pl-s1"><span class="pl-pds">"</span>contact.emails<span class="pl-pds">"</span></span>, <span class="pl-s3">json_parse_string</span>(<span class="pl-s1"><span class="pl-pds">"</span>[<span class="pl-cce">\"</span>email@example.com<span class="pl-cce">\"</span>,<span class="pl-cce">\"</span>email2@example.com<span class="pl-cce">\"</span>]<span class="pl-pds">"</span></span>)); <span class="pl-c1">json_object_dotset_value</span>(root_object, <span class="pl-s"><span class="pl-pds">"</span>contact.emails<span class="pl-pds">"</span></span>, <span class="pl-c1">json_parse_string</span>(<span class="pl-s"><span class="pl-pds">"</span>[<span class="pl-cce">\"</span>email@example.com<span class="pl-cce">\"</span>,<span class="pl-cce">\"</span>email2@example.com<span class="pl-cce">\"</span>]<span class="pl-pds">"</span></span>));
serialized_string = <span class="pl-s3">json_serialize_to_string</span>(root_value); serialized_string = <span class="pl-c1">json_serialize_to_string_pretty</span>(root_value);
<span class="pl-s3">puts</span>(serialized_string); <span class="pl-c1">puts</span>(serialized_string);
<span class="pl-s3">json_free_serialized_string</span>(serialized_string); <span class="pl-c1">json_free_serialized_string</span>(serialized_string);
<span class="pl-s3">json_value_free</span>(root_value); <span class="pl-c1">json_value_free</span>(root_value);
} }
</pre></div> </pre></div>
<p>Created value (after formatting outside parson):</p> <p>Output:</p>
<pre><code>{ <pre><code>{
"name":"John Smith", "name": "John Smith",
"age":25, "age": 25,
"address":{ "address": {
"city":"Cupertino" "city": "Cupertino"
}, },
"contact":{ "contact": {
"emails":[ "emails": [
"email@example.com", "email@example.com",
"email2@example.com" "email2@example.com"
] ]
} }
} }
</code></pre> </code></pre>
@ -194,13 +183,16 @@ Remember to follow parson's code style and write appropriate tests.</p>
<a id="license" class="anchor" href="#license" aria-hidden="true"><span class="octicon octicon-link"></span></a>License</h2> <a id="license" class="anchor" href="#license" aria-hidden="true"><span class="octicon octicon-link"></span></a>License</h2>
<p><a href="http://opensource.org/licenses/mit-license.php">The MIT License (MIT)</a></p> <p><a href="http://opensource.org/licenses/mit-license.php">The MIT License (MIT)</a></p>
</section>
<footer> <footer class="site-footer">
<p><small>Hosted on <a href="http://pages.github.com">GitHub Pages</a> using the Dinky theme</small></p> <span class="site-footer-owner"><a href="https://github.com/kgabis/parson">parson</a> is maintained by <a href="https://github.com/kgabis">kgabis</a>.</span>
<span class="site-footer-credits">This page was generated by <a href="https://pages.github.com">GitHub Pages</a> using the <a href="https://github.com/jasonlong/cayman-theme">Cayman theme</a> by <a href="https://twitter.com/jasonlong">Jason Long</a>.</span>
</footer> </footer>
</div>
<!--[if !IE]><script>fixScale(document);</script><![endif]--> </section>
<script type="text/javascript">
<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www."); var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E")); document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script> </script>
@ -213,3 +205,4 @@ Remember to follow parson's code style and write appropriate tests.</p>
</body> </body>
</html> </html>

File diff suppressed because one or more lines are too long

@ -0,0 +1,116 @@
/*
Copyright 2014 GitHub Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
.pl-c /* comment */ {
color: #969896;
}
.pl-c1 /* constant, markup.raw, meta.diff.header, meta.module-reference, meta.property-name, support, support.constant, support.variable, variable.other.constant */,
.pl-s .pl-v /* string variable */ {
color: #0086b3;
}
.pl-e /* entity */,
.pl-en /* entity.name */ {
color: #795da3;
}
.pl-s .pl-s1 /* string source */,
.pl-smi /* storage.modifier.import, storage.modifier.package, storage.type.java, variable.other, variable.parameter.function */ {
color: #333;
}
.pl-ent /* entity.name.tag */ {
color: #63a35c;
}
.pl-k /* keyword, storage, storage.type */ {
color: #a71d5d;
}
.pl-pds /* punctuation.definition.string, string.regexp.character-class */,
.pl-s /* string */,
.pl-s .pl-pse .pl-s1 /* string punctuation.section.embedded source */,
.pl-sr /* string.regexp */,
.pl-sr .pl-cce /* string.regexp constant.character.escape */,
.pl-sr .pl-sra /* string.regexp string.regexp.arbitrary-repitition */,
.pl-sr .pl-sre /* string.regexp source.ruby.embedded */ {
color: #183691;
}
.pl-v /* variable */ {
color: #ed6a43;
}
.pl-id /* invalid.deprecated */ {
color: #b52a1d;
}
.pl-ii /* invalid.illegal */ {
background-color: #b52a1d;
color: #f8f8f8;
}
.pl-sr .pl-cce /* string.regexp constant.character.escape */ {
color: #63a35c;
font-weight: bold;
}
.pl-ml /* markup.list */ {
color: #693a17;
}
.pl-mh /* markup.heading */,
.pl-mh .pl-en /* markup.heading entity.name */,
.pl-ms /* meta.separator */ {
color: #1d3e81;
font-weight: bold;
}
.pl-mq /* markup.quote */ {
color: #008080;
}
.pl-mi /* markup.italic */ {
color: #333;
font-style: italic;
}
.pl-mb /* markup.bold */ {
color: #333;
font-weight: bold;
}
.pl-md /* markup.deleted, meta.diff.header.from-file */ {
background-color: #ffecec;
color: #bd2c00;
}
.pl-mi1 /* markup.inserted, meta.diff.header.to-file */ {
background-color: #eaffea;
color: #55a532;
}
.pl-mdr /* meta.diff.range */ {
color: #795da3;
font-weight: bold;
}
.pl-mo /* meta.output */ {
color: #1d3e81;
}

@ -0,0 +1,424 @@
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
* user zoom.
*/
html {
font-family: sans-serif; /* 1 */
-ms-text-size-adjust: 100%; /* 2 */
-webkit-text-size-adjust: 100%; /* 2 */
}
/**
* Remove default margin.
*/
body {
margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
display: inline-block; /* 1 */
vertical-align: baseline; /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
display: none;
height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
background-color: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
border-bottom: 1px dotted;
}
/**
* Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
font-weight: bold;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
font-size: 2em;
margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
background: #ff0;
color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sup {
top: -0.5em;
}
sub {
bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
box-sizing: content-box;
height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
font-family: monospace, monospace;
font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
* Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
color: inherit; /* 1 */
font: inherit; /* 2 */
margin: 0; /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
* and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
* `input` and others.
*/
button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
-webkit-appearance: button; /* 2 */
cursor: pointer; /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
border: 0;
padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `!important` in
* the UA stylesheet.
*/
input {
line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
box-sizing: border-box; /* 1 */
padding: 0; /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
* (include `-moz` to future-proof).
*/
input[type="search"] {
-webkit-appearance: textfield; /* 1 */ /* 2 */
box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
border: 0; /* 1 */
padding: 0; /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
font-weight: bold;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
border-collapse: collapse;
border-spacing: 0;
}
td,
th {
padding: 0;
}

@ -1,371 +1,245 @@
/* http://meyerweb.com/eric/tools/css/reset/ * {
v2.0 | 20110126 box-sizing: border-box; }
License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
/* LAYOUT STYLES */
body { body {
font-size: 1em; padding: 0;
line-height: 1.5; margin: 0;
background: #e7e7e7 url(../images/body-bg.png) 0 0 repeat; font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
font-family: 'Helvetica Neue', Helvetica, Arial, serif; font-size: 16px;
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.8); line-height: 1.5;
color: #6d6d6d; color: #606c71; }
}
a { a {
color: #d5000d; color: #1e6bb8;
} text-decoration: none; }
a:hover { a:hover {
color: #c5000c; text-decoration: underline; }
}
.btn {
header { display: inline-block;
padding-top: 35px; margin-bottom: 1rem;
padding-bottom: 25px; color: rgba(255, 255, 255, 0.7);
} background-color: rgba(255, 255, 255, 0.08);
border-color: rgba(255, 255, 255, 0.2);
header h1 { border-style: solid;
font-family: 'Chivo', 'Helvetica Neue', Helvetica, Arial, serif; font-weight: 900; border-width: 1px;
letter-spacing: -1px; border-radius: 0.3rem;
font-size: 48px; transition: color 0.2s, background-color 0.2s, border-color 0.2s; }
color: #303030; .btn + .btn {
line-height: 1.2; margin-left: 1rem; }
}
.btn:hover {
header h2 { color: rgba(255, 255, 255, 0.8);
letter-spacing: -1px; text-decoration: none;
font-size: 24px; background-color: rgba(255, 255, 255, 0.2);
color: #aaa; border-color: rgba(255, 255, 255, 0.3); }
@media screen and (min-width: 64em) {
.btn {
padding: 0.75rem 1rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.btn {
padding: 0.6rem 0.9rem;
font-size: 0.9rem; } }
@media screen and (max-width: 42em) {
.btn {
display: block;
width: 100%;
padding: 0.75rem;
font-size: 0.9rem; }
.btn + .btn {
margin-top: 1rem;
margin-left: 0; } }
.page-header {
color: #fff;
text-align: center;
background-color: #159957;
background-image: linear-gradient(120deg, #155799, #159957); }
@media screen and (min-width: 64em) {
.page-header {
padding: 5rem 6rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.page-header {
padding: 3rem 4rem; } }
@media screen and (max-width: 42em) {
.page-header {
padding: 2rem 1rem; } }
.project-name {
margin-top: 0;
margin-bottom: 0.1rem; }
@media screen and (min-width: 64em) {
.project-name {
font-size: 3.25rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.project-name {
font-size: 2.25rem; } }
@media screen and (max-width: 42em) {
.project-name {
font-size: 1.75rem; } }
.project-tagline {
margin-bottom: 2rem;
font-weight: normal; font-weight: normal;
line-height: 1.3; opacity: 0.7; }
}
@media screen and (min-width: 64em) {
#container { .project-tagline {
background: transparent url(../images/highlight-bg.jpg) 50% 0 no-repeat; font-size: 1.25rem; } }
min-height: 595px;
} @media screen and (min-width: 42em) and (max-width: 64em) {
.project-tagline {
.inner { font-size: 1.15rem; } }
width: 620px;
margin: 0 auto; @media screen and (max-width: 42em) {
} .project-tagline {
font-size: 1rem; } }
#container .inner img {
max-width: 100%; .main-content :first-child {
} margin-top: 0; }
.main-content img {
#downloads { max-width: 100%; }
margin-bottom: 40px; .main-content h1, .main-content h2, .main-content h3, .main-content h4, .main-content h5, .main-content h6 {
} margin-top: 2rem;
margin-bottom: 1rem;
a.button { font-weight: normal;
-moz-border-radius: 30px; color: #159957; }
-webkit-border-radius: 30px; .main-content p {
border-radius: 30px; margin-bottom: 1em; }
border-top: solid 1px #cbcbcb; .main-content code {
border-left: solid 1px #b7b7b7; padding: 2px 4px;
border-right: solid 1px #b7b7b7; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace;
border-bottom: solid 1px #b3b3b3; font-size: 0.9rem;
color: #303030; color: #383e41;
line-height: 25px; background-color: #f3f6fa;
font-weight: bold; border-radius: 0.3rem; }
font-size: 15px; .main-content pre {
padding: 12px 8px 12px 8px; padding: 0.8rem;
display: block; margin-top: 0;
float: left; margin-bottom: 1rem;
width: 179px; font: 1rem Consolas, "Liberation Mono", Menlo, Courier, monospace;
margin-right: 14px; color: #567482;
background: #fdfdfd; /* Old browsers */ word-wrap: normal;
background: -moz-linear-gradient(top, #fdfdfd 0%, #f2f2f2 100%); /* FF3.6+ */ background-color: #f3f6fa;
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fdfdfd), color-stop(100%,#f2f2f2)); /* Chrome,Safari4+ */ border: solid 1px #dce6f0;
background: -webkit-linear-gradient(top, #fdfdfd 0%,#f2f2f2 100%); /* Chrome10+,Safari5.1+ */ border-radius: 0.3rem; }
background: -o-linear-gradient(top, #fdfdfd 0%,#f2f2f2 100%); /* Opera 11.10+ */ .main-content pre > code {
background: -ms-linear-gradient(top, #fdfdfd 0%,#f2f2f2 100%); /* IE10+ */ padding: 0;
background: linear-gradient(top, #fdfdfd 0%,#f2f2f2 100%); /* W3C */ margin: 0;
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fdfdfd', endColorstr='#f2f2f2',GradientType=0 ); /* IE6-9 */ font-size: 0.9rem;
-webkit-box-shadow: 10px 10px 5px #888; color: #567482;
-moz-box-shadow: 10px 10px 5px #888; word-break: normal;
box-shadow: 0px 1px 5px #e8e8e8; white-space: pre;
} background: transparent;
a.button:hover { border: 0; }
border-top: solid 1px #b7b7b7; .main-content .highlight {
border-left: solid 1px #b3b3b3; margin-bottom: 1rem; }
border-right: solid 1px #b3b3b3; .main-content .highlight pre {
border-bottom: solid 1px #b3b3b3; margin-bottom: 0;
background: #fafafa; /* Old browsers */ word-break: normal; }
background: -moz-linear-gradient(top, #fdfdfd 0%, #f6f6f6 100%); /* FF3.6+ */ .main-content .highlight pre, .main-content pre {
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fdfdfd), color-stop(100%,#f6f6f6)); /* Chrome,Safari4+ */ padding: 0.8rem;
background: -webkit-linear-gradient(top, #fdfdfd 0%,#f6f6f6 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top, #fdfdfd 0%,#f6f6f6 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top, #fdfdfd 0%,#f6f6f6 100%); /* IE10+ */
background: linear-gradient(top, #fdfdfd 0%,#f6f6f6, 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fdfdfd', endColorstr='#f6f6f6',GradientType=0 ); /* IE6-9 */
}
a.button span {
padding-left: 50px;
display: block;
height: 23px;
}
#download-zip span {
background: transparent url(../images/zip-icon.png) 12px 50% no-repeat;
}
#download-tar-gz span {
background: transparent url(../images/tar-gz-icon.png) 12px 50% no-repeat;
}
#view-on-github span {
background: transparent url(../images/octocat-icon.png) 12px 50% no-repeat;
}
#view-on-github {
margin-right: 0;
}
code, pre {
font-family: Monaco, "Bitstream Vera Sans Mono", "Lucida Console", Terminal;
color: #222;
margin-bottom: 30px;
font-size: 14px;
}
code {
background-color: #f2f2f2;
border: solid 1px #ddd;
padding: 0 3px;
}
pre {
padding: 20px;
background: #303030;
color: #f2f2f2;
text-shadow: none;
overflow: auto; overflow: auto;
} font-size: 0.9rem;
pre code { line-height: 1.45;
color: #f2f2f2; border-radius: 0.3rem; }
background-color: #303030; .main-content pre code, .main-content pre tt {
border: none; display: inline;
max-width: initial;
padding: 0; padding: 0;
} margin: 0;
overflow: initial;
ul, ol, dl { line-height: inherit;
margin-bottom: 20px; word-wrap: normal;
} background-color: transparent;
border: 0; }
.main-content pre code:before, .main-content pre code:after, .main-content pre tt:before, .main-content pre tt:after {
/* COMMON STYLES */ content: normal; }
.main-content ul, .main-content ol {
hr { margin-top: 0; }
height: 1px; .main-content blockquote {
line-height: 1px; padding: 0 1rem;
margin-top: 1em; margin-left: 0;
padding-bottom: 1em; color: #819198;
border: none; border-left: 0.3rem solid #dce6f0; }
background: transparent url('../images/hr.png') 50% 0 no-repeat; .main-content blockquote > :first-child {
} margin-top: 0; }
.main-content blockquote > :last-child {
strong { margin-bottom: 0; }
font-weight: bold; .main-content table {
} display: block;
em {
font-style: italic;
}
table {
width: 100%; width: 100%;
border: 1px solid #ebebeb; overflow: auto;
} word-break: normal;
word-break: keep-all; }
th { .main-content table th {
font-weight: 500; font-weight: bold; }
} .main-content table th, .main-content table td {
padding: 0.5rem 1rem;
td { border: 1px solid #e9ebec; }
border: 1px solid #ebebeb; .main-content dl {
text-align: center; padding: 0; }
font-weight: 300; .main-content dl dt {
} padding: 0;
margin-top: 1rem;
form { font-size: 1rem;
background: #f2f2f2; font-weight: bold; }
padding: 20px; .main-content dl dd {
padding: 0;
} margin-bottom: 1rem; }
.main-content hr {
height: 2px;
/* GENERAL ELEMENT TYPE STYLES */ padding: 0;
margin: 1rem 0;
h1 { background-color: #eff0f1;
font-size: 32px; border: 0; }
}
@media screen and (min-width: 64em) {
h2 { .main-content {
font-size: 22px; max-width: 64rem;
font-weight: bold; padding: 2rem 6rem;
color: #303030; margin: 0 auto;
margin-bottom: 8px; font-size: 1.1rem; } }
}
h3 {
color: #d5000d;
font-size: 18px;
font-weight: bold;
margin-bottom: 8px;
}
h4 {
font-size: 16px;
color: #303030;
font-weight: bold;
}
h5 {
font-size: 1em;
color: #303030;
}
h6 {
font-size: .8em;
color: #303030;
}
p {
font-weight: 300;
margin-bottom: 20px;
}
a {
text-decoration: none;
}
p a {
font-weight: 400;
}
blockquote {
font-size: 1.6em;
border-left: 10px solid #e9e9e9;
margin-bottom: 20px;
padding: 0 0 0 30px;
}
ul li {
list-style: disc inside;
padding-left: 20px;
}
ol li {
list-style: decimal inside;
padding-left: 3px;
}
dl dt { @media screen and (min-width: 42em) and (max-width: 64em) {
color: #303030; .main-content {
} padding: 2rem 4rem;
font-size: 1.1rem; } }
footer { @media screen and (max-width: 42em) {
background: transparent url('../images/hr.png') 0 0 no-repeat; .main-content {
margin-top: 40px; padding: 2rem 1rem;
padding-top: 20px; font-size: 1rem; } }
padding-bottom: 30px;
font-size: 13px;
color: #aaa;
}
footer a { .site-footer {
color: #666; padding-top: 2rem;
} margin-top: 2rem;
footer a:hover { border-top: solid 1px #eff0f1; }
color: #444;
}
/* MISC */ .site-footer-owner {
.clearfix:after {
clear: both;
content: '.';
display: block; display: block;
visibility: hidden; font-weight: bold; }
height: 0;
}
.clearfix {display: inline-block;}
* html .clearfix {height: 1%;}
.clearfix {display: block;}
/* #Media Queries .site-footer-credits {
================================================== */ color: #819198; }
/* Smaller than standard 960 (devices and browsers) */ @media screen and (min-width: 64em) {
@media only screen and (max-width: 959px) {} .site-footer {
font-size: 1rem; } }
/* Tablet Portrait size to standard 960 (devices and browsers) */
@media only screen and (min-width: 768px) and (max-width: 959px) {}
/* All Mobile Sizes (devices and browser) */
@media only screen and (max-width: 767px) {
header {
padding-top: 10px;
padding-bottom: 10px;
}
#downloads {
margin-bottom: 25px;
}
#download-zip, #download-tar-gz {
display: none;
}
.inner {
width: 94%;
margin: 0 auto;
}
}
/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */ @media screen and (min-width: 42em) and (max-width: 64em) {
@media only screen and (min-width: 480px) and (max-width: 767px) {} .site-footer {
font-size: 1rem; } }
/* Mobile Portrait Size to Mobile Landscape Size (devices and browsers) */ @media screen and (max-width: 42em) {
@media only screen and (max-width: 479px) {} .site-footer {
font-size: 0.9rem; } }

Loading…
Cancel
Save