Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Colon in the front: YAML syntax

I'm currently using Sidekiq in a project and I have the following YAML config file:

:concurrency: 5
:pidfile: /tmp/pids/sidekiq.pid
:logfile: log/sidekiq.log
staging:
  :concurrency: 10
production:
  :concurrency: 20
queues:
  - default

I haven't seen having a colon in front of a key before but omitting that colon produces interesting results. In the case of the :pidfile: for example, with the colon in front it creates/overrides the destination file where is without it, it uses the one already there and does not write to it.

Is this documented somewhere or is this simply how Sidekiq expects certain keys?

like image 432
Maikon Avatar asked Jul 28 '15 10:07

Maikon


2 Answers

YAML keys starting with a colon generate symbolized keys in Ruby, whereas keys without a colon will generate stringified keys:

require 'yaml'

string =<<-END_OF_YAML
:concurrency: 5
:pidfile: /tmp/pids/sidekiq.pid
:logfile: log/sidekiq.log
staging:
  :concurrency: 10
production:
  :concurrency: 20
queues:
  - default
END_OF_YAML

YAML.load(string)
# {
#     :concurrency => 5,
#     :pidfile     => "/tmp/pids/sidekiq.pid",
#     :logfile     => "log/sidekiq.log",
#     "staging"    => {
#         :concurrency => 10
#     },
#     "production" => {
#         :concurrency => 20
#     },
#     "queues"     => [
#         [0] "default"
#     ]
# }

Note: If a gem depends on symbolized keys then the stringified keys will not override its defaults.

like image 136
spickermann Avatar answered Sep 19 '22 04:09

spickermann


It is actually not sidekiq specific. The colon in front of a key just makes this key a symbol instead of a string:

# example.yml
a:
  value: 1
:b:
  value: 2


yaml = YAML.load_file('example.yml')

yaml["a"] => { "value" => 1 }
yaml[:b] => { "value" => 1 }

So if your code accesses the config with key symbols, you should either add a colon in front of the key in the yaml file, or use some conversion of keys like #with_indifferent_access for the result hash (after parsing the yaml file)

like image 22
Yury Lebedev Avatar answered Sep 22 '22 04:09

Yury Lebedev