From: Evgeniy Dushistov Date: Mon, 26 Jul 2010 16:43:19 +0000 (-0700) Subject: oe.patch: don't error when the symlink already exists and is correct X-Git-Url: http://git.openpandora.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c47c6611be11d3b80f61a75f80187e9398eccbd4;p=openembedded.git oe.patch: don't error when the symlink already exists and is correct Adds oe.path.symlink convenience function. Signed-off-by: Evgeniy Dushistov Signed-off-by: Chris Larson --- diff --git a/lib/oe/patch.py b/lib/oe/patch.py index 607ad44321..d7f4ccb9e9 100644 --- a/lib/oe/patch.py +++ b/lib/oe/patch.py @@ -1,3 +1,5 @@ +import oe.path + class NotFoundError(Exception): def __init__(self, path): self.path = path @@ -230,7 +232,7 @@ class QuiltTree(PatchSet): if not self.initialized: self.InitFromDir() PatchSet.Import(self, patch, force) - os.symlink(patch["file"], self._quiltpatchpath(patch["file"])) + oe.path.symlink(patch["file"], self._quiltpatchpath(patch["file"])) f = open(os.path.join(self.dir, "patches","series"), "a"); f.write(os.path.basename(patch["file"]) + " -p" + patch["strippath"]+"\n") f.close() diff --git a/lib/oe/path.py b/lib/oe/path.py index a145456659..f58c0138bb 100644 --- a/lib/oe/path.py +++ b/lib/oe/path.py @@ -53,3 +53,14 @@ def remove(path): shutil.rmtree(path) elif exc.errno != errno.ENOENT: raise + +def symlink(source, destination, force=False): + """Create a symbolic link""" + import os, errno + try: + if force: + remove(destination) + os.symlink(source, destination) + except OSError, e: + if e.errno != errno.EEXIST or os.readlink(destination) != source: + raise