From aadbc090ad8ca85ce7e8ca79b2dad8452729131c Mon Sep 17 00:00:00 2001 From: Pietro Peterlongo Date: Sun, 24 Oct 2021 20:16:17 +0200 Subject: [PATCH] fix init from scratch (#40) --- src/nimibook/books.nim | 5 +++++ src/nimibook/tocs.nim | 14 +++++++++----- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/src/nimibook/books.nim b/src/nimibook/books.nim index 0b95e66..679c8d1 100644 --- a/src/nimibook/books.nim +++ b/src/nimibook/books.nim @@ -82,7 +82,12 @@ proc initBookFile(book: Book) = let srcurls = book.files for f in srcurls: if not fileExists(f): + let (dir, _, _) = f.splitFile() + if not dir.dirExists: + echo "[nimibook] creating directory ", dir + createDir(dir) let file = open(f, fmWrite) + echo "[nimibook] creating file ", f file.close() proc init*(book: Book) = diff --git a/src/nimibook/tocs.nim b/src/nimibook/tocs.nim index 7017b06..8b06932 100644 --- a/src/nimibook/tocs.nim +++ b/src/nimibook/tocs.nim @@ -4,16 +4,16 @@ import nimibook / [types, defaults, paths] proc inc(levels: var seq[int]) = levels[levels.high] = levels[levels.high] + 1 -# TODO comment debugEcho before merge proc add(toc: var Toc, entry: Entry) = let fullPath = entry.path # debugEcho "==> toc.add Entry <==\n fullPath>", fullPath if not fileExists(fullPath): - raise newException(IOError, fmt"Error entry {fullpath} doesn't exist.") + echo fmt"[nimibook.warning] Toc entry {fullpath} doesn't exist." toc.entries.add entry template populateAssets*(rootfolder: string, force: bool = false) = const baseRessources = currentSourcePath().parentDir() / "resources" + # debugEcho "[nimibook] baseResources", baseRessources let assetsSrc = baseRessources / "assets" assetsTarget = getCurrentDir() / "docs" / "assets" @@ -25,21 +25,25 @@ template populateAssets*(rootfolder: string, force: bool = false) = # debugEcho("mustacheSrc >> ", mustacheSrc) # debugEcho("mustacheTarget >> ", mustacheTarget) + if not dirExists(mustacheTarget): + echo "[nimibook] creating template directory: ", mustacheTarget + createDir(mustacheTarget) + for file in walkDir(mustacheSrc): let file = file.path let name = file.splitPath().tail # Copy default mustache file if not fileExists(mustacheTarget / name) or force: - # debugEcho "copyFile(", file , ", ", mustacheTarget, ") " + echo fmt"[nimibook] creating/overwriting template file:", mustacheTarget copyFile(file, mustacheTarget / name) if not dirExists(assetsTarget): - # debugEcho "==> copyDir(", assetsSrc, ", ", assetsTarget, ")" + echo "[nimibook] creating assets directory: ", assetsTarget copyDir(assetsSrc, assetsTarget) else: if force: removeDir(assetsTarget) - # debugEcho "==> copyDir(", assetsSrc, ", ", assetsTarget, ")" + echo "[nimibook] removing and creating again assets directory: ", assetsTarget copyDir(assetsSrc, assetsTarget) template newBookFromToc*(booklabel: string, rootfolder: string, body: untyped): Book =