diff options
Diffstat (limited to 'meta/classes/devtool-source.bbclass')
| -rw-r--r-- | meta/classes/devtool-source.bbclass | 80 | 
1 files changed, 14 insertions, 66 deletions
| diff --git a/meta/classes/devtool-source.bbclass b/meta/classes/devtool-source.bbclass index 4158c20c7e..2e0070486b 100644 --- a/meta/classes/devtool-source.bbclass +++ b/meta/classes/devtool-source.bbclass | |||
| @@ -26,8 +26,6 @@ | |||
| 26 | 26 | ||
| 27 | 27 | ||
| 28 | DEVTOOL_TEMPDIR ?= "" | 28 | DEVTOOL_TEMPDIR ?= "" | 
| 29 | DEVTOOL_PATCH_SRCDIR = "${DEVTOOL_TEMPDIR}/patchworkdir" | ||
| 30 | |||
| 31 | 29 | ||
| 32 | python() { | 30 | python() { | 
| 33 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 31 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 
| @@ -60,7 +58,6 @@ python() { | |||
| 60 | else: | 58 | else: | 
| 61 | unpacktask = 'do_unpack' | 59 | unpacktask = 'do_unpack' | 
| 62 | d.appendVarFlag(unpacktask, 'postfuncs', ' devtool_post_unpack') | 60 | d.appendVarFlag(unpacktask, 'postfuncs', ' devtool_post_unpack') | 
| 63 | d.prependVarFlag('do_patch', 'prefuncs', ' devtool_pre_patch') | ||
| 64 | d.appendVarFlag('do_patch', 'postfuncs', ' devtool_post_patch') | 61 | d.appendVarFlag('do_patch', 'postfuncs', ' devtool_post_patch') | 
| 65 | 62 | ||
| 66 | # NOTE: in order for the patch stuff to be fully functional, | 63 | # NOTE: in order for the patch stuff to be fully functional, | 
| @@ -79,69 +76,25 @@ python devtool_post_unpack() { | |||
| 79 | 76 | ||
| 80 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 77 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 
| 81 | workdir = d.getVar('WORKDIR') | 78 | workdir = d.getVar('WORKDIR') | 
| 79 | unpackdir = d.getVar('UNPACKDIR') | ||
| 82 | srcsubdir = d.getVar('S') | 80 | srcsubdir = d.getVar('S') | 
| 83 | 81 | ||
| 84 | def _move_file(src, dst): | 82 | # Add locally copied files to gitignore as we add back to the metadata directly | 
| 85 | """Move a file. Creates all the directory components of destination path.""" | ||
| 86 | dst_d = os.path.dirname(dst) | ||
| 87 | if dst_d: | ||
| 88 | bb.utils.mkdirhier(dst_d) | ||
| 89 | shutil.move(src, dst) | ||
| 90 | |||
| 91 | def _ls_tree(directory): | ||
| 92 | """Recursive listing of files in a directory""" | ||
| 93 | ret = [] | ||
| 94 | for root, dirs, files in os.walk(directory): | ||
| 95 | ret.extend([os.path.relpath(os.path.join(root, fname), directory) for | ||
| 96 | fname in files]) | ||
| 97 | return ret | ||
| 98 | |||
| 99 | is_kernel_yocto = bb.data.inherits_class('kernel-yocto', d) | ||
| 100 | # Move local source files into separate subdir | ||
| 101 | recipe_patches = [os.path.basename(patch) for patch in | ||
| 102 | oe.recipeutils.get_recipe_patches(d)] | ||
| 103 | local_files = oe.recipeutils.get_recipe_local_files(d) | 83 | local_files = oe.recipeutils.get_recipe_local_files(d) | 
| 104 | |||
| 105 | if is_kernel_yocto: | ||
| 106 | for key in [f for f in local_files if f.endswith('scc')]: | ||
| 107 | with open(local_files[key], 'r') as sccfile: | ||
| 108 | for l in sccfile: | ||
| 109 | line = l.split() | ||
| 110 | if line and line[0] in ('kconf', 'patch'): | ||
| 111 | cfg = os.path.join(os.path.dirname(local_files[key]), line[-1]) | ||
| 112 | if cfg not in local_files.values(): | ||
| 113 | local_files[line[-1]] = cfg | ||
| 114 | shutil.copy2(cfg, workdir) | ||
| 115 | |||
| 116 | # Ignore local files with subdir={BP} | ||
| 117 | srcabspath = os.path.abspath(srcsubdir) | 84 | srcabspath = os.path.abspath(srcsubdir) | 
| 118 | local_files = [fname for fname in local_files if | 85 | local_files = [fname for fname in local_files if | 
| 119 | os.path.exists(os.path.join(workdir, fname)) and | 86 | os.path.exists(os.path.join(unpackdir, fname)) and | 
| 120 | (srcabspath == workdir or not | 87 | srcabspath == unpackdir] | 
| 121 | os.path.join(workdir, fname).startswith(srcabspath + | ||
| 122 | os.sep))] | ||
| 123 | if local_files: | 88 | if local_files: | 
| 124 | for fname in local_files: | 89 | with open(os.path.join(tempdir, '.gitignore'), 'a+') as f: | 
| 125 | _move_file(os.path.join(workdir, fname), | 90 | f.write('# Ignore local files, by default. Remove following lines' | 
| 126 | os.path.join(tempdir, 'oe-local-files', fname)) | 91 | 'if you want to commit the directory to Git\n') | 
| 127 | with open(os.path.join(tempdir, 'oe-local-files', '.gitignore'), | 92 | for fname in local_files: | 
| 128 | 'w') as f: | 93 | f.write('%s\n' % fname) | 
| 129 | f.write('# Ignore local files, by default. Remove this file ' | 94 | |
| 130 | 'if you want to commit the directory to Git\n*\n') | 95 | if srcsubdir.startswith(unpackdir) and os.path.dirname(srcsubdir) != unpackdir: | 
| 131 | |||
| 132 | if srcsubdir == workdir: | ||
| 133 | # Find non-patch non-local sources that were "unpacked" to srctree | ||
| 134 | # directory | ||
| 135 | src_files = [fname for fname in _ls_tree(workdir) if | ||
| 136 | os.path.basename(fname) not in recipe_patches] | ||
| 137 | srcsubdir = d.getVar('DEVTOOL_PATCH_SRCDIR') | ||
| 138 | # Move source files to S | ||
| 139 | for path in src_files: | ||
| 140 | _move_file(os.path.join(workdir, path), | ||
| 141 | os.path.join(srcsubdir, path)) | ||
| 142 | elif os.path.dirname(srcsubdir) != workdir: | ||
| 143 | # Handle if S is set to a subdirectory of the source | 96 | # Handle if S is set to a subdirectory of the source | 
| 144 | srcsubdir = os.path.join(workdir, os.path.relpath(srcsubdir, workdir).split(os.sep)[0]) | 97 | srcsubdir = os.path.normpath(os.path.join(unpackdir, os.path.relpath(srcsubdir, unpackdir).split(os.sep)[0])) | 
| 145 | 98 | ||
| 146 | scriptutils.git_convert_standalone_clone(srcsubdir) | 99 | scriptutils.git_convert_standalone_clone(srcsubdir) | 
| 147 | 100 | ||
| @@ -164,11 +117,6 @@ python devtool_post_unpack() { | |||
| 164 | f.write(srcsubdir) | 117 | f.write(srcsubdir) | 
| 165 | } | 118 | } | 
| 166 | 119 | ||
| 167 | python devtool_pre_patch() { | ||
| 168 | if d.getVar('S') == d.getVar('WORKDIR'): | ||
| 169 | d.setVar('S', '${DEVTOOL_PATCH_SRCDIR}') | ||
| 170 | } | ||
| 171 | |||
| 172 | python devtool_post_patch() { | 120 | python devtool_post_patch() { | 
| 173 | import shutil | 121 | import shutil | 
| 174 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 122 | tempdir = d.getVar('DEVTOOL_TEMPDIR') | 
| @@ -231,9 +179,9 @@ python devtool_post_patch() { | |||
| 231 | # (otherwise we'd likely be left with identical commits that have different hashes) | 179 | # (otherwise we'd likely be left with identical commits that have different hashes) | 
| 232 | bb.process.run('git rebase devtool-no-overrides', cwd=srcsubdir) | 180 | bb.process.run('git rebase devtool-no-overrides', cwd=srcsubdir) | 
| 233 | bb.process.run('git checkout %s' % devbranch, cwd=srcsubdir) | 181 | bb.process.run('git checkout %s' % devbranch, cwd=srcsubdir) | 
| 234 | bb.process.run('git tag -f devtool-patched', cwd=srcsubdir) | 182 | bb.process.run('git tag -f --no-sign devtool-patched', cwd=srcsubdir) | 
| 235 | if os.path.exists(os.path.join(srcsubdir, '.gitmodules')): | 183 | if os.path.exists(os.path.join(srcsubdir, '.gitmodules')): | 
| 236 | bb.process.run('git submodule foreach --recursive "git tag -f devtool-patched"', cwd=srcsubdir) | 184 | bb.process.run('git submodule foreach --recursive "git tag -f --no-sign devtool-patched"', cwd=srcsubdir) | 
| 237 | 185 | ||
| 238 | } | 186 | } | 
| 239 | 187 | ||
