aboutsummaryrefslogtreecommitdiffstats
path: root/lib/fabpot-yaml/doc/01-Usage.markdown
blob: 644cf11e934b3e62f7ae3448eae7977d24f2ee86 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
Using Symfony YAML
==================

The Symfony YAML library is very simple and consists of two main classes: one
to parse YAML strings (`sfYamlParser`), and the other to dump a PHP array to
a YAML string (`sfYamlDumper`).

On top of these two core classes, the main `sfYaml` class acts as a thin
wrapper and simplifies common uses.

Reading YAML Files
------------------

The `sfYamlParser::parse()` method parses a YAML string and converts it to a
PHP array:

    [php]
    $yaml = new sfYamlParser();
    $value = $yaml->parse(file_get_contents('/path/to/file.yaml'));

If an error occurs during parsing, the parser throws an exception indicating
the error type and the line in the original YAML string where the error
occurred:

    [php]
    try
    {
      $value = $yaml->parse(file_get_contents('/path/to/file.yaml'));
    }
    catch (InvalidArgumentException $e)
    {
      // an error occurred during parsing
      echo "Unable to parse the YAML string: ".$e->getMessage();
    }

>**TIP**
>As the parser is reentrant, you can use the same parser object to load
>different YAML strings.

When loading a YAML file, it is sometimes better to use the `sfYaml::load()`
wrapper method:

    [php]
    $loader = sfYaml::load('/path/to/file.yml');

The `sfYaml::load()` static method takes a YAML string or a file containing
YAML. Internally, it calls the `sfYamlParser::parse()` method, but with some
added bonuses:

  * It executes the YAML file as if it was a PHP file, so that you can embed
    PHP commands in YAML files;

  * When a file cannot be parsed, it automatically adds the file name to the
    error message, simplifying debugging when your application is loading
    several YAML files.

Writing YAML Files
------------------

The `sfYamlDumper` dumps any PHP array to its YAML representation:

    [php]
    $array = array('foo' => 'bar', 'bar' => array('foo' => 'bar', 'bar' => 'baz'));

    $dumper = new sfYamlDumper();
    $yaml = $dumper->dump($array);
    file_put_contents('/path/to/file.yaml', $yaml);

>**NOTE**
>Of course, the Symfony YAML dumper is not able to dump resources. Also,
>even if the dumper is able to dump PHP objects, it is to be considered
>an alpha feature.

If you only need to dump one array, you can use the `sfYaml::dump()` static
method shortcut:

    [php]
    $yaml = sfYaml::dump($array, $inline);

The YAML format supports two kind of representation for arrays, the expanded
one, and the inline one. By default, the dumper uses the inline
representation:

    [yml]
    { foo: bar, bar: { foo: bar, bar: baz } }

The second argument of the `dump()` method customizes the level at which the
output switches from the expanded representation to the inline one:

    [php]
    echo $dumper->dump($array, 1);

-

    [yml]
    foo: bar
    bar: { foo: bar, bar: baz }

-

    [php]
    echo $dumper->dump($array, 2);

-

    [yml]
    foo: bar
    bar:
      foo: bar
      bar: baz