mirror of
https://github.com/moparisthebest/android.moparisthebest.org
synced 2025-01-14 07:08:01 -05:00
104 lines
3.5 KiB
Markdown
104 lines
3.5 KiB
Markdown
---
|
|
layout: page
|
|
title: "Sharing Code Snippets"
|
|
date: 2011-07-19 18:10
|
|
sidebar: false
|
|
footer: false
|
|
---
|
|
|
|
Sharing code is important, and blogging about it should be easy and beautiful.
|
|
That's why Octopress is packed with features to make blogging your code a breeze.
|
|
Though Jekyll comes with support for [Pygments syntax highlighting](http://pygments.org),
|
|
Octopress makes it way better. Here's how.
|
|
|
|
- A Sass port of [Solarized syntax highlighting](http://ethanschoonover.com/solarized) created specifically for Octopress
|
|
- Gist code embedding - by [Brandon Tilly](https://gist.github.com/1027674)
|
|
- Insert code snippets from your filesystem with a download link.
|
|
- Easy inline code blocks with `<figure>` and `<figcaption>` and optional download links.
|
|
- Pygments caching - a [Jekyll community plugin](https://github.com/rsim/blog.rayapps.com/blob/master/_plugins/pygments_cache_patch.rb)
|
|
- Table based line numbers added with javascript
|
|
|
|
## Gist Code embedding
|
|
All you need is the gist's id and you can easily embed it in your page. This actually downloads a cache of the gist and embeds it in a `<noscript>` tag for RSS
|
|
readers and search engines, while still using Github's javascript gist embed code for browsers.
|
|
|
|
#### Syntax
|
|
|
|
{{ "{% gist gist_id [filename]" }} %}
|
|
|
|
#### Example
|
|
|
|
{{ "{% gist 996818" }} %}
|
|
|
|
{% gist 996818 %}
|
|
|
|
If you have a gist with multiple files, you can include files one at a time by adding the name after the gist id.
|
|
|
|
{{ "{% gist 1059334 svg_bullets.rb" }} %}
|
|
{{ "{% gist 1059334 usage.scss" }} %}
|
|
|
|
## Include Code Snippets
|
|
Import files on your filesystem into any blog post as embedded code snippets with syntax highlighting and a download link.
|
|
In the `_config.yml` you can set your `code_dir` but the default is `source/downloads/code`. Simply put a file anywhere under that directory and
|
|
use the following tag to embed it in a post.
|
|
|
|
#### Syntax
|
|
|
|
{{ "{% include_code [title] url" }} %}
|
|
|
|
#### Example 1
|
|
|
|
{{ "{% include_code javascripts/test.js" }} %}
|
|
|
|
#### Example 2 (with optional title)
|
|
|
|
{{ "{% include_code Testing include_code javascripts/test.js" }} %}
|
|
|
|
This includes a file from `source/downloads/code/javascripts/test.js`. By default the `<figcaption>` will be the filename, but you can add a title before the filepath if you like.
|
|
|
|
#### Demo of Example 2
|
|
|
|
{% include_code Testing include_code javascripts/test.js %}
|
|
|
|
## Inline Codeblocks
|
|
You can also write blocks of code directly in your posts.
|
|
|
|
#### Syntax
|
|
|
|
{{ "{% codeblock [title] [url] [link text]" }} %}
|
|
|
|
#### Example 1
|
|
|
|
{{ "{% codeblock" }} %}
|
|
Awesome code snippet
|
|
{{ "{% endcodeblock" }} %}
|
|
|
|
{% codeblock %}
|
|
Awesome code snippet
|
|
{% endcodeblock %}
|
|
|
|
#### Example 2
|
|
|
|
# Including a file extension in the title enables highlighting
|
|
{{ "{% codeblock Time to be Awesome - awesome.rb" }} %}
|
|
puts "Awesome!" unless lame
|
|
{{ "{% endcodeblock" }} %}
|
|
|
|
{% codeblock Time to be Awesome - awesome.rb %}
|
|
puts "Awesome!" unless lame
|
|
{% endcodeblock %}
|
|
|
|
#### Example 3
|
|
|
|
# Add an optional URL to enable downloading or linking to source
|
|
{{ "{% codeblock Got pain? painreleif.sh http://example.com/painreleief.sh Download it!" }} %}
|
|
$ rm -rf ~/PAIN
|
|
{{ "{% endcodeblock" }} %}
|
|
|
|
{% codeblock Javascript Array Syntax (array.js) https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array MDN Documentation %}
|
|
var arr1 = new Array(arrayLength);
|
|
var arr2 = new Array(element0, element1, ..., elementN);
|
|
{% endcodeblock %}
|
|
|
|
The last argument `link_text` is optional. You may want to link to a source for download file, or documentation on some other site.
|