Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
8036af6bc8 | |||
b9a69809eb | |||
9750ac16b3 | |||
969af93425 |
22
cliutils.nim
22
cliutils.nim
@ -1,4 +1,4 @@
|
||||
import docopt, json, osproc, posix, nre, streams, strtabs, terminal, unicode
|
||||
import docopt, json, osproc, posix, nre, streams, strtabs, tables, terminal, unicode
|
||||
import os except sleep
|
||||
import strutils except toUpper, toLower
|
||||
|
||||
@ -10,7 +10,7 @@ type
|
||||
|
||||
TermColor = ForegroundColor or BackgroundColor
|
||||
|
||||
proc getVal*(cfg: CombinedConfig, key, default: string): string =
|
||||
proc getVal*(cfg: CombinedConfig, key: string): string =
|
||||
let argKey = "--" & key
|
||||
let envKey = key.replace('-', '_').toUpper
|
||||
let jsonKey = key.replace(re"(-\w)", proc (m: RegexMatch): string = ($m)[1..1].toUpper)
|
||||
@ -27,8 +27,11 @@ proc getVal*(cfg: CombinedConfig, key, default: string): string =
|
||||
of JNull: return ""
|
||||
of JObject: return $node
|
||||
of JArray: return $node
|
||||
else: return default
|
||||
else: raise newException(ValueError, "cannot find a configuration value for \"" & key & "\"")
|
||||
|
||||
proc getVal*(cfg: CombinedConfig, key, default: string): string =
|
||||
try: return getVal(cfg, key)
|
||||
except: return default
|
||||
|
||||
proc loadEnv*(): StringTableRef =
|
||||
result = newStringTable()
|
||||
@ -188,7 +191,7 @@ let STRIP_ANSI_REGEX = re"\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]"
|
||||
|
||||
proc stripAnsi*(str: string): string = return str.replace(STRIP_ANSI_REGEX, "")
|
||||
|
||||
proc queryParamsToCliArgs*(queryParams: StringTableRef): seq[string] =
|
||||
proc queryParamsToCliArgs*(queryParams: Table[string, string]): seq[string] =
|
||||
result = @[]
|
||||
|
||||
for k,v in queryParams:
|
||||
@ -198,3 +201,14 @@ proc queryParamsToCliArgs*(queryParams: StringTableRef): seq[string] =
|
||||
else :
|
||||
result[1].add("--" & k)
|
||||
if v != "true": result[1].add(v) # support things like ?verbose=true -> cmd --verbose
|
||||
|
||||
proc queryParamsToCliArgs*(queryParams: StringTableRef): seq[string] =
|
||||
result = @[]
|
||||
|
||||
for k,v in queryParams:
|
||||
# support ?arg1=val1&arg2=val2 -> cmd val1 val2
|
||||
if k.startsWith("arg"): result.add(v)
|
||||
|
||||
else :
|
||||
result.add("--" & k)
|
||||
if v != "true": result.add(v) # support things like ?verbose=true -> cmd --verbose
|
||||
|
@ -1,6 +1,6 @@
|
||||
# Package
|
||||
|
||||
version = "0.6.0"
|
||||
version = "0.6.2"
|
||||
author = "Jonathan Bernard"
|
||||
description = "Helper functions for writing command line interfaces."
|
||||
license = "MIT"
|
||||
|
Reference in New Issue
Block a user