mirror of
https://github.com/status-im/NimYAML.git
synced 2025-01-26 19:19:24 +00:00
940675a52e
* moved load procs to yaml/loading.nim * moved input YamlStream into ConstructionContext * made ConstructionContext a non-ref object * harmonized code style & comments * renamed yaml/serialization.nim to yaml/native.nim
132 lines
3.7 KiB
Nim
132 lines
3.7 KiB
Nim
# NimYAML - YAML implementation in Nim
|
|
# (c) Copyright 2015-2023 Felix Krause
|
|
#
|
|
# See the file "copying.txt", included in this
|
|
# distribution, for details about the copyright.
|
|
|
|
## ===================
|
|
## Module yaml/dumping
|
|
## ===================
|
|
##
|
|
## The dumping API enables you to dump native Nim values as
|
|
## YAML character stream. Along with the loading API, this
|
|
## forms the highest-level API of NimYAML.
|
|
|
|
import std/streams
|
|
import presenter, native, private/internal
|
|
export native
|
|
|
|
type
|
|
Dumper* = object
|
|
## Holds configuration for dumping Nim values.
|
|
presentation* : PresentationOptions
|
|
serialization*: SerializationOptions
|
|
|
|
proc setMinimalStyle*(dumper: var Dumper) =
|
|
## Output preset. Tries to output single line flow-only output.
|
|
dumper.presentation = PresentationOptions(
|
|
newlines: nlNone,
|
|
containers: cFlow,
|
|
directivesEnd: deIfNecessary,
|
|
suppressAttrs: false,
|
|
quoting: sqJson,
|
|
condenseFlow: true,
|
|
explicitKeys: false
|
|
)
|
|
dumper.serialization = SerializationOptions(
|
|
tagStyle: tsNone,
|
|
anchorStyle: asTidy
|
|
)
|
|
|
|
proc minimalDumper*(): Dumper =
|
|
result.setMinimalStyle()
|
|
|
|
proc setCanonicalStyle*(dumper: var Dumper) =
|
|
## Output preset. Generates specific tags for all nodes, uses flow style,
|
|
## quotes all string scalars.
|
|
dumper.presentation = PresentationOptions(
|
|
containers: cFlow,
|
|
directivesEnd: deAlways,
|
|
suppressAttrs: false,
|
|
quoting: sqDouble,
|
|
condenseFlow: false,
|
|
explicitKeys: true
|
|
)
|
|
dumper.serialization = SerializationOptions(
|
|
tagStyle: tsAll,
|
|
anchorStyle: asTidy
|
|
)
|
|
|
|
proc canonicalDumper*(): Dumper =
|
|
result.setCanonicalStyle()
|
|
|
|
proc setDefaultStyle*(dumper: var Dumper) =
|
|
## Output preset. Uses block style by default, but flow style for collections
|
|
## that only contain scalar values.
|
|
dumper.presentation = PresentationOptions()
|
|
dumper.serialization = SerializationOptions()
|
|
|
|
proc setJsonStyle*(dumper: var Dumper) =
|
|
## Output preset. Uses flow style, omits tags, anchors and all other non-JSON
|
|
## entities, formats all scalars as corresponding JSON values.
|
|
dumper.presentation = PresentationOptions(
|
|
containers: cFlow,
|
|
directivesEnd: deNever,
|
|
suppressAttrs: true,
|
|
quoting: sqJson,
|
|
condenseFlow: false,
|
|
explicitKeys: false,
|
|
outputVersion: ovNone
|
|
)
|
|
dumper.serialization = SerializationOptions(
|
|
tagStyle: tsNone,
|
|
anchorStyle: asNone
|
|
)
|
|
|
|
proc jsonDumper*(): Dumper =
|
|
result.setJsonStyle()
|
|
|
|
proc setBlockOnlyStyle*(dumper: var Dumper) =
|
|
## Output preset. Uses block style exclusively.
|
|
dumper.presentation = PresentationOptions(
|
|
containers: cBlock,
|
|
directivesEnd: deIfNecessary,
|
|
suppressAttrs: false,
|
|
quoting: sqUnset,
|
|
condenseFlow: true,
|
|
explicitKeys: false
|
|
)
|
|
dumper.serialization = SerializationOptions(
|
|
tagStyle: tsNone,
|
|
anchorStyle: asTidy
|
|
)
|
|
|
|
proc blockOnlyDumper*(): Dumper =
|
|
result.setBlockOnlyStyle()
|
|
|
|
proc dump*[K](
|
|
dumper: Dumper,
|
|
value: K,
|
|
target: Stream,
|
|
) {.raises: [
|
|
YamlPresenterJsonError, YamlPresenterOutputError,
|
|
YamlSerializationError
|
|
].} =
|
|
## Dump a Nim value as YAML into the given stream.
|
|
var events = represent(value, dumper.serialization)
|
|
try: present(events, target, dumper.presentation)
|
|
except YamlStreamError as e:
|
|
internalError("Unexpected exception: " & $e.name)
|
|
|
|
proc dump*[K](
|
|
dumper: Dumper,
|
|
value: K,
|
|
): string {.hint[XCannotRaiseY]: off, raises: [
|
|
YamlPresenterJsonError, YamlPresenterOutputError,
|
|
YamlSerializationError
|
|
].} =
|
|
## Dump a Nim value as YAML into a string.
|
|
var events = represent(value, dumper.serialization)
|
|
try: result = present(events, dumper.presentation)
|
|
except YamlStreamError as e:
|
|
internalError("Unexpected exception: " & $e.name) |