summaryrefslogtreecommitdiffstats
path: root/scripts/lib/devtool/standard.py
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/lib/devtool/standard.py')
-rw-r--r--scripts/lib/devtool/standard.py10
1 files changed, 6 insertions, 4 deletions
diff --git a/scripts/lib/devtool/standard.py b/scripts/lib/devtool/standard.py
index 9ab3aa608c..4cb03f3a54 100644
--- a/scripts/lib/devtool/standard.py
+++ b/scripts/lib/devtool/standard.py
@@ -313,12 +313,14 @@ def modify(args, config, basepath, workspace):
313 (stdout, _) = bb.process.run('git rev-parse HEAD', cwd=args.srctree) 313 (stdout, _) = bb.process.run('git rev-parse HEAD', cwd=args.srctree)
314 initial_rev = stdout.rstrip() 314 initial_rev = stdout.rstrip()
315 315
316 # Handle if S is set to a subdirectory of the source 316 # Check that recipe isn't using a shared workdir
317 s = rd.getVar('S', True) 317 s = rd.getVar('S', True)
318 workdir = rd.getVar('WORKDIR', True) 318 workdir = rd.getVar('WORKDIR', True)
319 if s != workdir and os.path.dirname(s) != workdir: 319 if s.startswith(workdir):
320 srcsubdir = os.sep.join(os.path.relpath(s, workdir).split(os.sep)[1:]) 320 # Handle if S is set to a subdirectory of the source
321 srctree = os.path.join(srctree, srcsubdir) 321 if s != workdir and os.path.dirname(s) != workdir:
322 srcsubdir = os.sep.join(os.path.relpath(s, workdir).split(os.sep)[1:])
323 srctree = os.path.join(srctree, srcsubdir)
322 324
323 appendpath = os.path.join(config.workspace_path, 'appends') 325 appendpath = os.path.join(config.workspace_path, 'appends')
324 if not os.path.exists(appendpath): 326 if not os.path.exists(appendpath):