summary refs log tree commit diff stats
path: root/lib
diff options
context:
space:
mode:
authorOscar Nihlgård <oscarnihlgard@gmail.com>2018-11-26 13:14:52 +0100
committerOscar Nihlgård <oscarnihlgard@gmail.com>2018-11-26 22:08:45 +0100
commite5aae93bfe04225cbad4f4aa3aea943be74f29e0 (patch)
tree89a3d254e795f04b1274035dd3022b451b589234 /lib
parenteeb7cc678008a07dad40a979a5f6679a28390f3f (diff)
downloadNim-e5aae93bfe04225cbad4f4aa3aea943be74f29e0.tar.gz
Add `relative` parameter to walkDirRec
Diffstat (limited to 'lib')
-rw-r--r--lib/pure/os.nim19
1 files changed, 12 insertions, 7 deletions
diff --git a/lib/pure/os.nim b/lib/pure/os.nim
index e2dd872e8..0e43e18ca 100644
--- a/lib/pure/os.nim
+++ b/lib/pure/os.nim
@@ -1564,11 +1564,14 @@ iterator walkDir*(dir: string; relative=false): tuple[kind: PathComponent, path:
               k = getSymlinkFileKind(y)
             yield (k, y)
 
-iterator walkDirRec*(dir: string, yieldFilter = {pcFile},
-                     followFilter = {pcDir}): string {.tags: [ReadDirEffect].} =
+iterator walkDirRec*(dir: string,
+                     yieldFilter = {pcFile}, followFilter = {pcDir},
+                     relative = false): string {.tags: [ReadDirEffect].} =
   ## Recursively walks over the directory `dir` and yields for each file
   ## or directory in `dir`.
-  ## The full path for each file or directory is returned.
+  ## If ``relative`` is true the resulting path is
+  ## shortened to be relative to ``dir``, otherwise the full path is returned.
+  ##
   ## **Warning**:
   ## Modifying the directory structure while the iterator
   ## is traversing may result in undefined behavior!
@@ -1591,13 +1594,15 @@ iterator walkDirRec*(dir: string, yieldFilter = {pcFile},
   ## ``pcLinkToDir``         follow symbolic links to directories
   ## ---------------------   ---------------------------------------------
   ##
-  var stack = @[dir]
+  var stack = @[""]
   while stack.len > 0:
-    for k, p in walkDir(stack.pop()):
+    let d = stack.pop()
+    for k, p in walkDir(dir / d, relative = true):
+      let rel = d / p
       if k in {pcDir, pcLinkToDir} and k in followFilter:
-        stack.add(p)
+        stack.add rel
       if k in yieldFilter:
-        yield p
+        yield if relative: rel else: dir / rel
 
 proc rawRemoveDir(dir: string) {.noNimScript.} =
   when defined(windows):