diff --git a/esv_api.nimble b/esv_api.nimble index e8ac241..1e2a5cd 100644 --- a/esv_api.nimble +++ b/esv_api.nimble @@ -1,6 +1,6 @@ # Package -version = "0.2.3" +version = "0.3.0" author = "Jonathan Bernard" description = "Simple Nim CLI wrapper around the ESV API (api.esv.org)" license = "MIT" diff --git a/src/esv_api.nim b/src/esv_api.nim index 6e49f5c..28849df 100644 --- a/src/esv_api.nim +++ b/src/esv_api.nim @@ -32,6 +32,36 @@ proc formatMarkdown(raw: string): string = result = (wrapped.splitLines --> map("> " & it)). join("\p") & "\p> -- *" & reference & " (ESV)*" +proc formatPlain(raw: string, keepVerseNumbers = true): string = + var reference = "" + var inVerse = false + var verseLines = newSeq[string]() + + for line in raw.splitLines: + if reference.len == 0: reference = line.strip + if inVerse: + if line.startsWith("Footnotes"): inVerse = false + elif line.isEmptyOrWhitespace and verseLines[^1] != "": + verseLines.add("") + elif not line.match(re"^\s+[^\s]"): continue + elif line.match(re"$(.*)\(ESV\)$"): verseLines.add(line[0 ..< ^5]) + else: verseLines.add(line) + elif line.match(re"^\s+\[\d+\]"): + inVerse = true + verseLines.add(line) + + let wrapped = (verseLines --> + map(if it.len > 90: it.strip else: it & " "). + map( + if keepVerseNumbers: + it.multiReplace([(re"\((\d+)\)", ""), (re"\[(\d+)\]", "$1")]) + else: + it.multiReplace([(re"\((\d+)\)", ""), (re"\[(\d+)\]", "")])). + map(wrapWords(it, maxLineWidth = 74, newLine = "\p"))).join("\p") + + result = (wrapped.splitLines --> map(it)). + join("\p") & "\p– " & reference & " (ESV)" + when isMainModule: const USAGE = """Usage: esv_api [options] @@ -44,7 +74,7 @@ Options: command line for debugging purposes. -f, --output-format Select a specific output format. Valid values - are 'raw', 'markdown', 'plain'. + are 'raw', 'markdown', 'plain', 'reading'. -t, --esv-api-token Provide the API token on the command line. By default this will be read either from the @@ -59,7 +89,7 @@ Options: try: # Parse arguments - let args = docopt(USAGE, version = "0.2.3") + let args = docopt(USAGE, version = "0.3.0") if args["--debug"]: consoleLogger.levelThreshold = lvlDebug @@ -86,6 +116,11 @@ Options: let formattedPassages = case $args["--output-format"]: + of "plain": + respJson["passages"].getElems --> map(formatPlain(it.getStr)) + of "reading": + respJson["passages"].getElems --> + map(formatPlain(it.getStr, keepVerseNumbers = false)) of "text": respJson["passages"].getElems --> map(it.getStr.multiReplace([(re"\[(\d+)\]", "$1")]))