layout | title |
---|---|
default |
Author's Guide |
Look at the source of other recipe pages and follow that page structure. Start with the Developer’s Guide to get a test version of the cookbook up and running on your machine, and get to work!
- Feel free to add new pages, or even chapters. Just keep them organized. (See “How to Add a Chapter” below)
- Try to write well-styled, idiomatic CoffeeScript.
- Try to stay within the Problem/Solution/Discussion format. If you can’t think of a good problem for your recipe… hang onto it for a while.
- Sharing code that you think might only be used rarely is fine. Sharing esoteric code tricks is less so. There’s a difference between sharing a translator for an obscure format and sharing a weird bit-shifting trick that does fast but inaccurate multiplication.
A typical cookbook page will have three sections (four if you count the title):
- Problem A one- or two-sentence description of the problem, such as “You want to access parts of a string” or “You want to format a floating point number as currency, with a leading dollar sign, two digits of precision and comma-separated triples.” Where possible, phrase the problem as though speaking directly to the reader: “You want to…”, “You have an X but you want a Y”, etc.
- Solution State the solution as briefly as possible, ideally as a single sentence that identifies the strategy you would use, and give example code. It’s tempting to explain the solution, but don’t do it yet. Remember that the reader will look this solution up many times after the first time, and that they will be looking for a quick reference each time. You’re going to explain the solution in the Discussion, and the first time reader will read your solution, think about it, and then proceed to the discussion if necessary. For example, for “accessing parts of a string”, a good Solution sentence might be “Use CoffeeScript’s array range subscripts, or JavaScript’s slice function.”
- Discussion Here you should explain why your solution works, or give further examples such as edge cases. If your solution can break on some edge cases, be sure to note them here. For example, if a percentage function crashes when given a zero, you could note this in the discussion and give a workaround. NOTE: If your solution has really dangerous edge cases, so dangerous that you would include them in the solution, please consider whether your recipe should be included at all. Remember, this Cookbook is for good code!
…that’s a lot of fancy words that mean “don’t forget to put the layout, chapter and page title at the top of the file in a YAML block”. For example, the string interpolation page begins with
—-
layout: recipe
title: String Interpolation
chapter: Strings
-
Turn on syntax highlighting for CoffeeScript with highlight coffeescript.
{% highlight coffeescript %}
# Calculate the square of a number
square = (x) → x * x
square(16)
# => 256
{% endhighlight %}
This produces the following:
{% highlight coffeescript %}
- Calculate the square of a number
square = (x) → x * x
square(16)
- => 256
{% endhighlight %}
Create a new textile page. The filename should be about the problem, e.g. finding-last-day-of-the-month.textile or reversing-arrays.textile. In your file, start with the following template:
{% highlight text %}
-
layout: recipe
title: Title of The Recipe
chapter: Chapter Name
-
You have a problem.
Do this about it.
Here’s why.
{% endhighlight %}
One fussy little bit, the chapter name should match the directory the chapter is in, otherwise the page won’t render correctly. For example, if you’re writing a recipe for arrays, make sure the chapter is “Arrays”, not “arrays” or “aray” …or especially not “Chapter Name”.
- Open chapters/index.textile and your chapter’s name to the yaml list of chapters.
- cd into chapters/ and create the directory for the chapter name. Downcase the name and replace spaces with underscores.
For example, to add a chapter called “Dates and Times”, you would add it to the chapters array:
{% highlight yaml }
chapters:
- Syntax
- Objects
- Arrays
- Dates and Times
{ endhighlight %}
…and then create that chapter in the file system:
{% highlight bash }
cd chapters
mkdir dates_and_times
{ endhighlight %}
Now create a new page in that chapter (remember to add its YAML front matter) and once jekyll regenerates the chapter index, your new page should appear.
Maybe! The real question is, is it really useful, or is it just clever? If you have a formatter for a weird Albanian GIS format, that’s a real problem that almost nobody would ever have—but when somebody DOES have that problem, they REALLY need a solution. If you have a bit shifting trick that can swap two numbers using three xor-equals operations, that’s a really clever solution but it’s not very good CoffeeScript. (For one thing, x ^= y ^= x ^= y is not idiomatic, while [x,y]=[y,x] is. For another, there’s a bug in that code. And once you fix it, there’s another bug caused by extrapolating this register trick to a reference-based language where—look, it’s just a bad idea, okay?)
If you have a cool but weird recipe, ask yourself if a reader would genuinely find it useful. Here are two very good questions to consider:
- Does it really solve a problem that an actual person might have?
- If somebody really does have that problem, would your recipe really be the best solution?
If the answer to either question is no, you might have some code that is a “clever solution in search of a problem”. If in doubt, ask.
If it solves a problem to which the alternative is to not solve the problem, share it. Let the reader decide if they want to use it. Sometimes we want tight efficient code, other times we want a robust featureset. If the code has abysmal performance characteristics, be sure to warn the reader in the Discussion.
Yes. Please improve anything and everything! Be sure to test your changes and make sure that your solution really is better.
I Have a Really Efficient Solution, But It’s Not As Readable As the Existing Recipe. Should I Add It?
See the “Weird Recipe” note above. Do real people in the real world ever hit the performance constraint? If so, then by all means, add your strategy to the existing solution, and be sure to explain why your solution is not idiomatic. If a reader really has that problem, they’ll be glad for the extra options.
Yes! CoffeeScript compiles to JavaScript, and that means that some of its functionality comes straight from JavaScript. (For example, see Reversing Arrays.) But if you’re programming in CoffeeScript and you need to reverse an array, this Cookbook should stand ready to tell you it’s available to you in CoffeeScript—even if it’s just a straight call into a JavaScript library.
Absolutely!