Module: Ryo::YAML

Extended by:
YAML
Included in:
YAML
Defined in:
lib/ryo/yaml.rb

Overview

The Ryo::YAML module provides a number of options for coercing YAML data into a Ryo object. The methods of this module are available as singleton methods on the Ryo module

Instance Method Summary collapse

Instance Method Details

#from_yaml(path: nil, string: nil, object: Ryo::Object) ⇒ Ryo::Object, Ryo::BasicObject

Returns a Ryo object

Examples:

Ryo.from_yaml(path: "/foo/bar/baz.yaml")
Ryo.from_yaml(string: "---\nfoo: bar\n")

Parameters:

  • path (String) (defaults to: nil)

    The path to a YAML file

  • string (String) (defaults to: nil)

    A blob of YAML

  • object (Ryo) (defaults to: Ryo::Object)

Returns:

Raises:

  • (SystemCallError)

    Might raise a number of Errno exceptions



26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/ryo/yaml.rb', line 26

def from_yaml(path: nil, string: nil, object: Ryo::Object)
  if path && string
    raise ArgumentError, "Provide a path or string but not both"
  elsif path
    require "yaml" unless defined?(YAML)
    object.from YAML.load_file(path)
  elsif string
    require "yaml" unless defined?(YAML)
    object.from YAML.load(string)
  else
    raise ArgumentError, "No path or string provided"
  end
end