Unifying the different path splitting routines

This commit is contained in:
Joshua Harlow 2012-03-12 21:50:22 -07:00
parent e19e7de6f4
commit 69351f4fe1

View File

@ -189,6 +189,10 @@ def execute(*cmd, **kwargs):
def abspth(path): def abspth(path):
if not path:
path = ROOT_PATH
if path == "~":
path = gethomedir()
return os.path.abspath(path) return os.path.abspath(path)
@ -246,7 +250,7 @@ def chown_r(path, uid, gid, run_as_root=True):
LOG.audit("Changing ownership of %s to %s:%s" % (path, uid, gid)) LOG.audit("Changing ownership of %s to %s:%s" % (path, uid, gid))
for root, dirs, files in os.walk(path): for root, dirs, files in os.walk(path):
os.chown(root, uid, gid) os.chown(root, uid, gid)
LOG.debug("Changing ownership of %s to %s:%s" % (root, uid, gid)) LOG.audit("Changing ownership of %s to %s:%s" % (root, uid, gid))
for d in dirs: for d in dirs:
os.chown(joinpths(root, d), uid, gid) os.chown(joinpths(root, d), uid, gid)
LOG.audit("Changing ownership of %s to %s:%s" % (joinpths(root, d), uid, gid)) LOG.audit("Changing ownership of %s to %s:%s" % (joinpths(root, d), uid, gid))
@ -257,13 +261,24 @@ def chown_r(path, uid, gid, run_as_root=True):
def _explode_path(path): def _explode_path(path):
parts = list() parts = list()
while path != ROOT_PATH: path = abspth(path)
while path != ROOT_PATH and path:
(path, name) = os.path.split(path) (path, name) = os.path.split(path)
parts.append(name) parts.append(name)
parts.reverse() parts.reverse()
return parts return parts
def _explode_form_path(path):
ret_paths = list()
ret_paths.append(ROOT_PATH)
ex_path = _explode_path(path)
for i in range(len(ex_path)):
to_make = [ROOT_PATH] + ex_path[0:i] + [ex_path[i]]
ret_paths.append(joinpths(*to_make))
return ret_paths
def in_terminal(check_both=False): def in_terminal(check_both=False):
if check_both: if check_both:
return sys.stdout.isatty() or sys.stderr.isatty() return sys.stdout.isatty() or sys.stderr.isatty()
@ -303,19 +318,9 @@ def _array_begins_with(haystack, needle):
def mkdirslist(path): def mkdirslist(path):
LOG.debug("Determining potential paths to create for target path \"%s\"" % (path)) LOG.debug("Determining potential paths to create for target path \"%s\"" % (path))
dirs_possible = set() dirs_possible = _explode_form_path(path)
dirs_possible.add(path)
while True:
(base, _) = os.path.split(path)
if not base:
break
dirs_possible.add(base)
path = base
if path == ROOT_PATH:
break
#sorting is important so that we go in the right order.. (/ before /tmp and so on)
dirs_made = list() dirs_made = list()
for check_path in sorted(dirs_possible): for check_path in dirs_possible:
if not isdir(check_path): if not isdir(check_path):
mkdir(check_path, False) mkdir(check_path, False)
dirs_made.append(check_path) dirs_made.append(check_path)