mirror of
https://github.com/status-im/NimYAML.git
synced 2025-01-27 11:34:56 +00:00
db1a2c4041
`internalError` and `yAssert` now allow to echo the internal stack traces if the `d:debug` compile flag is set.
53 lines
1.6 KiB
Nim
53 lines
1.6 KiB
Nim
# NimYAML - YAML implementation in Nim
|
|
# (c) Copyright 2016 Felix Krause
|
|
#
|
|
# See the file "copying.txt", included in this
|
|
# distribution, for details about the copyright.
|
|
|
|
template internalError*(s: string) =
|
|
# Note: to get the internal stacktrace that caused the error
|
|
# compile with the `d:debug` flag.
|
|
when not defined(release):
|
|
let ii = instantiationInfo()
|
|
echo "[NimYAML] Error in file ", ii.filename, " at line ", ii.line, ":"
|
|
echo s
|
|
when not defined(JS):
|
|
echo "[NimYAML] Stacktrace:"
|
|
try:
|
|
writeStackTrace()
|
|
when defined(debug):
|
|
echo "Internal stacktrace:"
|
|
let exc = getCurrentException()
|
|
echo getStackTrace(exc.parent)
|
|
except: discard
|
|
echo "[NimYAML] Please report this bug."
|
|
quit 1
|
|
|
|
template yAssert*(e: typed) =
|
|
when not defined(release):
|
|
if not e:
|
|
let ii = instantiationInfo()
|
|
echo "[NimYAML] Error in file ", ii.filename, " at line ", ii.line, ":"
|
|
echo "assertion failed!"
|
|
when not defined(JS):
|
|
echo "[NimYAML] Stacktrace:"
|
|
try:
|
|
writeStackTrace()
|
|
when defined(debug):
|
|
echo "Internal stacktrace:"
|
|
let exc = getCurrentException()
|
|
echo getStackTrace(exc.parent)
|
|
except: discard
|
|
echo "[NimYAML] Please report this bug."
|
|
quit 1
|
|
|
|
proc yamlTestSuiteEscape*(s: string): string =
|
|
result = ""
|
|
for c in s:
|
|
case c
|
|
of '\l': result.add("\\n")
|
|
of '\c': result.add("\\r")
|
|
of '\\': result.add("\\\\")
|
|
of '\b': result.add("\\b")
|
|
of '\t': result.add("\\t")
|
|
else: result.add(c) |