203 lines
4.2 KiB
YAML
203 lines
4.2 KiB
YAML
--- %YAML:1.0
|
|
test: Simple Sequence
|
|
brief: |
|
|
You can specify a list in YAML by placing each
|
|
member of the list on a new line with an opening
|
|
dash. These lists are called sequences.
|
|
yaml: |
|
|
- apple
|
|
- banana
|
|
- carrot
|
|
php: |
|
|
['apple', 'banana', 'carrot']
|
|
---
|
|
test: Sequence With Item Being Null In The Middle
|
|
brief: |
|
|
You can specify a list in YAML by placing each
|
|
member of the list on a new line with an opening
|
|
dash. These lists are called sequences.
|
|
yaml: |
|
|
- apple
|
|
-
|
|
- carrot
|
|
php: |
|
|
['apple', null, 'carrot']
|
|
---
|
|
test: Sequence With Last Item Being Null
|
|
brief: |
|
|
You can specify a list in YAML by placing each
|
|
member of the list on a new line with an opening
|
|
dash. These lists are called sequences.
|
|
yaml: |
|
|
- apple
|
|
- banana
|
|
-
|
|
php: |
|
|
['apple', 'banana', null]
|
|
---
|
|
test: Nested Sequences
|
|
brief: |
|
|
You can include a sequence within another
|
|
sequence by giving the sequence an empty
|
|
dash, followed by an indented list.
|
|
yaml: |
|
|
-
|
|
- foo
|
|
- bar
|
|
- baz
|
|
php: |
|
|
[['foo', 'bar', 'baz']]
|
|
---
|
|
test: Mixed Sequences
|
|
brief: |
|
|
Sequences can contain any YAML data,
|
|
including strings and other sequences.
|
|
yaml: |
|
|
- apple
|
|
-
|
|
- foo
|
|
- bar
|
|
- x123
|
|
- banana
|
|
- carrot
|
|
php: |
|
|
['apple', ['foo', 'bar', 'x123'], 'banana', 'carrot']
|
|
---
|
|
test: Deeply Nested Sequences
|
|
brief: |
|
|
Sequences can be nested even deeper, with each
|
|
level of indentation representing a level of
|
|
depth.
|
|
yaml: |
|
|
-
|
|
-
|
|
- uno
|
|
- dos
|
|
php: |
|
|
[[['uno', 'dos']]]
|
|
---
|
|
test: Simple Mapping
|
|
brief: |
|
|
You can add a keyed list (also known as a dictionary or
|
|
hash) to your document by placing each member of the
|
|
list on a new line, with a colon separating the key
|
|
from its value. In YAML, this type of list is called
|
|
a mapping.
|
|
yaml: |
|
|
foo: whatever
|
|
bar: stuff
|
|
php: |
|
|
['foo' => 'whatever', 'bar' => 'stuff']
|
|
---
|
|
test: Sequence in a Mapping
|
|
brief: |
|
|
A value in a mapping can be a sequence.
|
|
yaml: |
|
|
foo: whatever
|
|
bar:
|
|
- uno
|
|
- dos
|
|
php: |
|
|
['foo' => 'whatever', 'bar' => ['uno', 'dos']]
|
|
---
|
|
test: Nested Mappings
|
|
brief: |
|
|
A value in a mapping can be another mapping.
|
|
yaml: |
|
|
foo: whatever
|
|
bar:
|
|
fruit: apple
|
|
name: steve
|
|
sport: baseball
|
|
php: |
|
|
[
|
|
'foo' => 'whatever',
|
|
'bar' => [
|
|
'fruit' => 'apple',
|
|
'name' => 'steve',
|
|
'sport' => 'baseball'
|
|
]
|
|
]
|
|
---
|
|
test: Mixed Mapping
|
|
brief: |
|
|
A mapping can contain any assortment
|
|
of mappings and sequences as values.
|
|
yaml: |
|
|
foo: whatever
|
|
bar:
|
|
-
|
|
fruit: apple
|
|
name: steve
|
|
sport: baseball
|
|
- more
|
|
-
|
|
python: rocks
|
|
perl: papers
|
|
ruby: scissorses
|
|
php: |
|
|
[
|
|
'foo' => 'whatever',
|
|
'bar' => [
|
|
[
|
|
'fruit' => 'apple',
|
|
'name' => 'steve',
|
|
'sport' => 'baseball'
|
|
],
|
|
'more',
|
|
[
|
|
'python' => 'rocks',
|
|
'perl' => 'papers',
|
|
'ruby' => 'scissorses'
|
|
]
|
|
]
|
|
]
|
|
---
|
|
test: Mapping-in-Sequence Shortcut
|
|
todo: true
|
|
brief: |
|
|
If you are adding a mapping to a sequence, you
|
|
can place the mapping on the same line as the
|
|
dash as a shortcut.
|
|
yaml: |
|
|
- work on YAML.py:
|
|
- work on Store
|
|
php: |
|
|
[['work on YAML.py' => ['work on Store']]]
|
|
---
|
|
test: Sequence-in-Mapping Shortcut
|
|
todo: true
|
|
brief: |
|
|
The dash in a sequence counts as indentation, so
|
|
you can add a sequence inside of a mapping without
|
|
needing spaces as indentation.
|
|
yaml: |
|
|
allow:
|
|
- 'localhost'
|
|
- '%.sourceforge.net'
|
|
- '%.freepan.org'
|
|
php: |
|
|
['allow' => ['localhost', '%.sourceforge.net', '%.freepan.org']]
|
|
---
|
|
todo: true
|
|
test: Merge key
|
|
brief: |
|
|
A merge key ('<<') can be used in a mapping to insert other mappings. If
|
|
the value associated with the merge key is a mapping, each of its key/value
|
|
pairs is inserted into the current mapping.
|
|
yaml: |
|
|
mapping:
|
|
name: Joe
|
|
job: Accountant
|
|
<<:
|
|
age: 38
|
|
php: |
|
|
[
|
|
'mapping' =>
|
|
[
|
|
'name' => 'Joe',
|
|
'job' => 'Accountant',
|
|
'age' => 38
|
|
]
|
|
]
|