2018-09-15 12:09:13 +02:00
|
|
|
```
|
|
|
|
% pandoc -s -t native
|
|
|
|
---
|
|
|
|
foobar_: this should be ignored
|
|
|
|
foo:
|
|
|
|
bar_: as should this
|
|
|
|
---
|
|
|
|
^D
|
2021-09-19 21:09:51 +02:00
|
|
|
Pandoc
|
2021-09-29 06:17:53 +02:00
|
|
|
Meta
|
|
|
|
{ unMeta = fromList [ ( "foo" , MetaMap (fromList []) ) ] }
|
|
|
|
[]
|
2018-09-15 12:09:13 +02:00
|
|
|
```
|
|
|
|
```
|
|
|
|
% pandoc -s -t native
|
|
|
|
---
|
|
|
|
# For precedence, see multiple-metadata-blocks.md and vars-and-metadata.md
|
|
|
|
# For Bools, see also 4819.md
|
|
|
|
# For Multiline strings, see yaml-with-chomp.md
|
|
|
|
int: 7
|
|
|
|
float: 1.5
|
|
|
|
scientific: 3.7e-5
|
|
|
|
bool: true
|
|
|
|
more: False
|
|
|
|
nothing: null
|
2020-10-14 21:32:51 +02:00
|
|
|
empty: []
|
2018-09-15 12:09:13 +02:00
|
|
|
nested:
|
|
|
|
int: 8
|
|
|
|
float: 2.5
|
|
|
|
bool: true
|
|
|
|
more: False
|
|
|
|
nothing: null
|
2020-10-14 21:32:51 +02:00
|
|
|
empty: []
|
2018-09-15 12:09:13 +02:00
|
|
|
scientific: 3.7e-5
|
|
|
|
---
|
|
|
|
^D
|
2021-09-19 21:09:51 +02:00
|
|
|
Pandoc
|
2021-09-29 06:17:53 +02:00
|
|
|
Meta
|
|
|
|
{ unMeta =
|
|
|
|
fromList
|
|
|
|
[ ( "bool" , MetaBool True )
|
|
|
|
, ( "empty" , MetaList [] )
|
|
|
|
, ( "float" , MetaInlines [ Str "1.5" ] )
|
|
|
|
, ( "int" , MetaInlines [ Str "7" ] )
|
|
|
|
, ( "more" , MetaBool False )
|
|
|
|
, ( "nested"
|
|
|
|
, MetaMap
|
|
|
|
(fromList
|
|
|
|
[ ( "bool" , MetaBool True )
|
|
|
|
, ( "empty" , MetaList [] )
|
|
|
|
, ( "float" , MetaInlines [ Str "2.5" ] )
|
|
|
|
, ( "int" , MetaInlines [ Str "8" ] )
|
|
|
|
, ( "more" , MetaBool False )
|
Switch back from HsYAML to yaml.
Reasons:
- Performance: HsYAML is around 20 times slower in parsing
large YAML bibliographies (#6084).
- An issue was submitted to HsYAML, but it hasn't gotten
any attention. HsYAML seems borderline unmaintained; it hasn't
had a commit in over a year.
- Unfortunately this goes back on our attempts to free ourselves
from C dependencies (#4535). But I don't see a better alternative
until a better pure Haskell parser is available.
Closes #6084.
Notes:
- We've removed the FromYAML instances for all types that had
them, since this is a HsYAML-specific typeclass [API change].
(The yaml package just uses From/ToJSON.)
- Unlike HsYAML (in the configuration we were using), yaml
parses 'Y', 'N', 'Yes', 'No', 'On', 'Off' as boolean values.
Users may need to quote these when they are meant to be
interpreted as strings. Similarly, 'null' is parsed as
a YAML null value (and will be treated as an empty string
by pandoc rather than the string 'null'). Quoting it will
force it to be interpreted as a string.
- Some tests had to be adjusted accordingly.
- Pandoc now behaves better when the YAML metadata contains
escaping errors: instead of just falling back on treating
the section as a table, it raises a YAML parsing error.
2021-10-25 17:48:18 +02:00
|
|
|
, ( "nothing" , MetaString "" )
|
2021-09-29 06:17:53 +02:00
|
|
|
, ( "scientific" , MetaInlines [ Str "3.7e-5" ] )
|
|
|
|
])
|
|
|
|
)
|
Switch back from HsYAML to yaml.
Reasons:
- Performance: HsYAML is around 20 times slower in parsing
large YAML bibliographies (#6084).
- An issue was submitted to HsYAML, but it hasn't gotten
any attention. HsYAML seems borderline unmaintained; it hasn't
had a commit in over a year.
- Unfortunately this goes back on our attempts to free ourselves
from C dependencies (#4535). But I don't see a better alternative
until a better pure Haskell parser is available.
Closes #6084.
Notes:
- We've removed the FromYAML instances for all types that had
them, since this is a HsYAML-specific typeclass [API change].
(The yaml package just uses From/ToJSON.)
- Unlike HsYAML (in the configuration we were using), yaml
parses 'Y', 'N', 'Yes', 'No', 'On', 'Off' as boolean values.
Users may need to quote these when they are meant to be
interpreted as strings. Similarly, 'null' is parsed as
a YAML null value (and will be treated as an empty string
by pandoc rather than the string 'null'). Quoting it will
force it to be interpreted as a string.
- Some tests had to be adjusted accordingly.
- Pandoc now behaves better when the YAML metadata contains
escaping errors: instead of just falling back on treating
the section as a table, it raises a YAML parsing error.
2021-10-25 17:48:18 +02:00
|
|
|
, ( "nothing" , MetaString "" )
|
2021-09-29 06:17:53 +02:00
|
|
|
, ( "scientific" , MetaInlines [ Str "3.7e-5" ] )
|
|
|
|
]
|
2021-09-19 21:09:51 +02:00
|
|
|
}
|
2021-09-29 06:17:53 +02:00
|
|
|
[]
|
2018-09-15 12:09:13 +02:00
|
|
|
```
|
|
|
|
```
|
|
|
|
% pandoc -s -t native
|
|
|
|
---
|
|
|
|
array:
|
|
|
|
- foo: bar
|
|
|
|
- bool: True
|
|
|
|
---
|
|
|
|
^D
|
2021-09-19 21:09:51 +02:00
|
|
|
Pandoc
|
2021-09-29 06:17:53 +02:00
|
|
|
Meta
|
|
|
|
{ unMeta =
|
|
|
|
fromList
|
|
|
|
[ ( "array"
|
|
|
|
, MetaList
|
|
|
|
[ MetaMap
|
|
|
|
(fromList [ ( "foo" , MetaInlines [ Str "bar" ] ) ])
|
|
|
|
, MetaMap (fromList [ ( "bool" , MetaBool True ) ])
|
|
|
|
]
|
|
|
|
)
|
2021-09-19 21:09:51 +02:00
|
|
|
]
|
|
|
|
}
|
2021-09-29 06:17:53 +02:00
|
|
|
[]
|
2018-09-15 12:09:13 +02:00
|
|
|
```
|
2018-09-15 16:47:53 +02:00
|
|
|
```
|
|
|
|
% pandoc -s -t native --metadata-file command/yaml-metadata.yaml
|
|
|
|
---
|
|
|
|
title: document
|
|
|
|
---
|
|
|
|
^D
|
2021-09-19 21:09:51 +02:00
|
|
|
Pandoc
|
2021-09-29 06:17:53 +02:00
|
|
|
Meta
|
|
|
|
{ unMeta =
|
|
|
|
fromList
|
|
|
|
[ ( "other"
|
|
|
|
, MetaInlines
|
|
|
|
[ Emph [ Str "markdown" ] , Space , Str "value" ]
|
|
|
|
)
|
|
|
|
, ( "title" , MetaInlines [ Str "document" ] )
|
|
|
|
]
|
2021-09-19 21:09:51 +02:00
|
|
|
}
|
2021-09-29 06:17:53 +02:00
|
|
|
[]
|
2018-09-15 16:47:53 +02:00
|
|
|
```
|
|
|
|
```
|
|
|
|
% pandoc -s -t native --metadata-file command/yaml-metadata.yaml -M title=cmdline
|
|
|
|
^D
|
2021-09-19 21:09:51 +02:00
|
|
|
Pandoc
|
2021-09-29 06:17:53 +02:00
|
|
|
Meta
|
|
|
|
{ unMeta =
|
|
|
|
fromList
|
|
|
|
[ ( "other"
|
|
|
|
, MetaInlines
|
|
|
|
[ Emph [ Str "markdown" ] , Space , Str "value" ]
|
|
|
|
)
|
|
|
|
, ( "title" , MetaString "cmdline" )
|
|
|
|
]
|
2021-09-19 21:09:51 +02:00
|
|
|
}
|
2021-09-29 06:17:53 +02:00
|
|
|
[]
|
2018-09-15 16:47:53 +02:00
|
|
|
```
|