From 907faf600f4d95eaae4b5c2fc0e8bc06c3efe48e Mon Sep 17 00:00:00 2001 From: Lars Wirzenius Date: Sat, 25 Feb 2012 14:27:43 +0000 Subject: Do not recurse through a symlink given as root --- summain | 2 +- tests/symlink.script | 10 ++++++++++ tests/symlink.stdout | 7 +++++++ 3 files changed, 18 insertions(+), 1 deletion(-) create mode 100755 tests/symlink.script create mode 100644 tests/symlink.stdout diff --git a/summain b/summain index a9e7ead..b82c108 100755 --- a/summain +++ b/summain @@ -122,7 +122,7 @@ class Summain(cliapp.Application): 'choose output format (rfc822, csv, json)') def files(self, root): - if os.path.isdir(root): + if os.path.isdir(root) and not os.path.islink(root): for dirname, dirnames, filenames in os.walk(root): yield dirname dirnames.sort() diff --git a/tests/symlink.script b/tests/symlink.script new file mode 100755 index 0000000..d5dd25e --- /dev/null +++ b/tests/symlink.script @@ -0,0 +1,10 @@ +#!/bin/sh + +set -e + +mkdir "$DATADIR/dir" +touch "$DATADIR/dir/file" +ln -s dir "$DATADIR/symlink" +./summain --exclude=mtime --exclude=uid --exclude=username \ + --exclude=gid --exclude=group --exclude=mode "$DATADIR/symlink" | +sed 's,^Name: /.*/,Name: ,' diff --git a/tests/symlink.stdout b/tests/symlink.stdout new file mode 100644 index 0000000..8288ba8 --- /dev/null +++ b/tests/symlink.stdout @@ -0,0 +1,7 @@ +Name: symlink +Ino: 1 +Dev: 1 +Nlink: 1 +Size: 3 +Target: dir + -- cgit v1.2.1