From: Paul Eggleton Date: Thu, 19 Feb 2015 16:40:02 +0000 (+0000) Subject: devtool: modify: handle recipes that use a shared workdir X-Git-Tag: lucaceresoli/bug-15201-perf-libtraceevent-missing~31140 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=7392ecd559ef71241405c704a65da171ee216ca1;p=thirdparty%2Fopenembedded%2Fopenembedded-core-contrib.git devtool: modify: handle recipes that use a shared workdir If S is outside of WORKDIR then we shouldn't try to get the relative path in order to work out where the source subdirectory is as we do by default. Signed-off-by: Paul Eggleton Signed-off-by: Richard Purdie --- diff --git a/scripts/lib/devtool/standard.py b/scripts/lib/devtool/standard.py index 9ab3aa608cf..4cb03f3a54a 100644 --- a/scripts/lib/devtool/standard.py +++ b/scripts/lib/devtool/standard.py @@ -313,12 +313,14 @@ def modify(args, config, basepath, workspace): (stdout, _) = bb.process.run('git rev-parse HEAD', cwd=args.srctree) initial_rev = stdout.rstrip() - # Handle if S is set to a subdirectory of the source + # Check that recipe isn't using a shared workdir s = rd.getVar('S', True) workdir = rd.getVar('WORKDIR', True) - if s != workdir and os.path.dirname(s) != workdir: - srcsubdir = os.sep.join(os.path.relpath(s, workdir).split(os.sep)[1:]) - srctree = os.path.join(srctree, srcsubdir) + if s.startswith(workdir): + # Handle if S is set to a subdirectory of the source + if s != workdir and os.path.dirname(s) != workdir: + srcsubdir = os.sep.join(os.path.relpath(s, workdir).split(os.sep)[1:]) + srctree = os.path.join(srctree, srcsubdir) appendpath = os.path.join(config.workspace_path, 'appends') if not os.path.exists(appendpath):