list-tree.py
29 lines
| 686 B
| text/x-python
|
PythonLexer
/ tests / list-tree.py
Augie Fackler
|
r35250 | from __future__ import ( | ||
absolute_import, | ||||
print_function, | ||||
) | ||||
import argparse | ||||
import os | ||||
ap = argparse.ArgumentParser() | ||||
ap.add_argument('path', nargs='+') | ||||
opts = ap.parse_args() | ||||
Augie Fackler
|
r43346 | |||
Augie Fackler
|
r35250 | def gather(): | ||
for p in opts.path: | ||||
if not os.path.exists(p): | ||||
return | ||||
if os.path.isdir(p): | ||||
yield p + os.path.sep | ||||
for dirpath, dirs, files in os.walk(p): | ||||
for d in dirs: | ||||
yield os.path.join(dirpath, d) + os.path.sep | ||||
for f in files: | ||||
yield os.path.join(dirpath, f) | ||||
else: | ||||
yield p | ||||
Augie Fackler
|
r43346 | |||
Matt Harbison
|
r35381 | print('\n'.join(sorted(gather(), key=lambda x: x.replace(os.path.sep, '/')))) | ||