class TOML::Dumper

def bare_key?(key)

def bare_key?(key)
  !!key.to_s.match(/^[a-zA-Z0-9_-]*$/)
end

def dump_nested_pairs(nested_pairs, prefix)

def dump_nested_pairs(nested_pairs, prefix)
  nested_pairs.each do |key, val|
    key = quote_key(key) unless bare_key? key
    visit val, prefix + [key], false
  end
end

def dump_simple_pairs(simple_pairs)

def dump_simple_pairs(simple_pairs)
  simple_pairs.each do |key, val|
    key = quote_key(key) unless bare_key? key
    @toml_str << "#{key} = #{to_toml(val)}\n"
  end
end

def dump_table_array_pairs(table_array_pairs, prefix)

def dump_table_array_pairs(table_array_pairs, prefix)
  table_array_pairs.each do |key, val|
    key = quote_key(key) unless bare_key? key
    aux_prefix = prefix + [key]
    val.each do |child|
      if child.empty?
        print_prefix aux_prefix, true
      else
        visit child, aux_prefix, true
      end
    end
  end
end

def initialize(hash)

def initialize(hash)
  @toml_str = ''
  visit(hash, [])
end

def print_prefix(prefix, extra_brackets = false)

def print_prefix(prefix, extra_brackets = false)
  new_prefix = prefix.join('.')
  new_prefix = '[' + new_prefix + ']' if extra_brackets
  @toml_str += "[" + new_prefix + "]\n"
end

def quote_key(key)

def quote_key(key)
  '"' + key.gsub('"', '\\"') + '"'
end

def sort_pairs(hash)

def sort_pairs(hash)
  nested_pairs = []
  simple_pairs = []
  table_array_pairs = []
  hash.keys.sort.each do |key|
    val = hash[key]
    element = [key, val]
    if val.is_a? Hash
      nested_pairs << element
    elsif val.is_a?(Array) && val.first.is_a?(Hash)
      table_array_pairs << element
    else
      simple_pairs << element
    end
  end
  [simple_pairs, nested_pairs, table_array_pairs]
end

def to_toml(obj)

def to_toml(obj)
  if obj.is_a? Time
    obj.strftime('%Y-%m-%dT%H:%M:%SZ')
  else
    obj.inspect
  end
end

def visit(hash, prefix, extra_brackets = false)

def visit(hash, prefix, extra_brackets = false)
  simple_pairs, nested_pairs, table_array_pairs = sort_pairs hash
  unless prefix.empty? || simple_pairs.empty?
    print_prefix prefix, extra_brackets
  end
  # First add simple pairs, under the prefix
  dump_simple_pairs simple_pairs
  dump_nested_pairs nested_pairs, prefix
  dump_table_array_pairs table_array_pairs, prefix
end