DRY Yaml

code • September 2, 2014

For the class that I’m teaching this Fall, I created a Jekyll site to hold the course materials. I’m in the camp that Jekyll can do anything and I want to use it always.

While working on variables in the config, I wondered if there’s a better way to write the following:

coursename: Intermediate Interactive Design
description:
  Intermediate Interactive Design, Informatics Department, University at Albany,
  Fall 2014

After some “concatenate Yaml” googling, I found that you can’t concatenate, but you can repeat nodes.

I tidied up and followed the patterns:

coursename: &course_name Intermediate Interactive Design
description:
  - \*course_name
  - Informatics Department
  - University at Albany
  - Fall 2014

Repeating nodes works by creating a keyword and placing it in the variable to be repeated. In this case, I used &course_name. Next, I dropped *course_name where I want &course_name to be repeated.

You set the variable with &keyword and recall it using *keyword.

Repeated nodes (objects) are first identified by an anchor (marked with the ampersand - “&”), and are then aliased (referenced with an asterisk - “*”) thereafter. Yaml Spec

You can repeat more than one node:

coursename: &course_name Intermediate Interactive Design
semester: &this_semester Fall 2014
description:
  - \*course_name
  - Informatics Department
  - University at Albany
  - \*this_semester

Now I can use either variable as I normally would and the repeated node will slide in smooth.

You might notice that I moved the description to an array. This gives me a little more flexibility with output.

Now I can use {{ site.description | join: ", " }} or even {{ site.description | join: "<br>" }} to output the array nicely.

Keep reading code