add support for parsing chars in scanf macro (#16240)

This commit is contained in:
Miran
2020-12-03 17:34:30 +01:00
committed by GitHub
parent 545c406cbe
commit 2220aaeaef
4 changed files with 33 additions and 1 deletions

View File

@@ -52,6 +52,9 @@
- `writeStackTrace` is available in JS backend now.
- `strscans.scanf` now supports parsing single characters.
## Language changes
- `nimscript` now handles `except Exception as e`.
@@ -60,6 +63,7 @@
- nil dereference is not allowed at compile time. `cast[ptr int](nil)[]` is rejected at compile time.
## Compiler changes
- Added `--declaredlocs` to show symbol declaration location in messages.

View File

@@ -241,6 +241,10 @@ proc parseIdent*(s: string, start = 0): string =
while i < s.len and s[i] in IdentChars: inc(i)
result = substr(s, start, i-1)
proc parseChar*(s: string, ident: var char, start = 0): int =
ident = s[start]
result = 1
proc skipWhitespace*(s: string, start = 0): int {.inline.} =
## Skips the whitespace starting at ``s[start]``. Returns the number of
## skipped characters.

View File

@@ -37,6 +37,7 @@ substrings starting with ``$``. These constructions are available:
``$h`` Matches a hex integer. This uses ``parseutils.parseHex``.
``$f`` Matches a floating pointer number. Uses ``parseFloat``.
``$w`` Matches an ASCII identifier: ``[A-Za-z_][A-Za-z_0-9]*``.
``$c`` Matches a single ASCII character.
``$s`` Skips optional whitespace.
``$$`` Matches a single dollar sign.
``$.`` Matches if the end of the input string has been reached.
@@ -345,6 +346,12 @@ macro scanf*(input: string; pattern: static[string]; results: varargs[typed]): b
else:
matchError
inc i
of 'c':
if i < results.len and getType(results[i]).typeKind == ntyChar:
matchBind "parseChar"
else:
matchError
inc i
of 'b':
if i < results.len and getType(results[i]).typeKind == ntyInt:
matchBind "parseBin"

View File

@@ -2,7 +2,7 @@ discard """
output: ""
"""
import strscans
import strscans, strutils
block ParsePasswd:
proc parsePasswd(content: string): seq[string] =
@@ -210,3 +210,20 @@ block:
var a: int
discard scanf(test(), ",$i", a)
doAssert count == 1
block:
let input = """1-3 s: abc
15-18 9: def
15-18 A: ghi
15-18 _: jkl
"""
var
lo, hi: int
w: string
c: char
res: int
for line in input.splitLines:
if line.scanf("$i-$i $c: $w", lo, hi, c, w):
inc res
doAssert res == 4