diff options
author | Xiaofeng Yan <xiaofeng.yan@windriver.com> | 2012-04-01 16:25:50 +0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-04-04 17:17:52 +0100 |
commit | 0aaddbc32b7d125ea754aecfd503ce96fe6e1d0b (patch) | |
tree | 13d60fbcf4263266dad47de31c2e55cd43fe1bb3 /meta/classes/archiver.bbclass | |
parent | 6c73e458da03e79a6b029da758dce60bcad17b33 (diff) | |
download | poky-0aaddbc32b7d125ea754aecfd503ce96fe6e1d0b.tar.gz |
archiver.bbclass: enhance code readability
The modification is as follow:
- Modify some codes with more preferable readability and vague description.
- Use existed functions instead of custom functions.
(From OE-Core rev: 514319c4a15156cd63a4ac3c6ee903f64c98884e)
Signed-off-by: Xiaofeng Yan <xiaofeng.yan@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/archiver.bbclass')
-rw-r--r-- | meta/classes/archiver.bbclass | 227 |
1 files changed, 108 insertions, 119 deletions
diff --git a/meta/classes/archiver.bbclass b/meta/classes/archiver.bbclass index 471430e24f..4e4e964a24 100644 --- a/meta/classes/archiver.bbclass +++ b/meta/classes/archiver.bbclass | |||
@@ -2,28 +2,11 @@ | |||
2 | # It also output building environment to xxx.dump.data and create xxx.diff.gz to record | 2 | # It also output building environment to xxx.dump.data and create xxx.diff.gz to record |
3 | # all content in ${S} to a diff file. | 3 | # all content in ${S} to a diff file. |
4 | 4 | ||
5 | EXCLUDE_FROM ?= ".pc autom4te.cache" | 5 | ARCHIVE_EXCLUDE_FROM ?= ".pc autom4te.cache" |
6 | ARCHIVE_TYPE ?= "TAR SRPM" | 6 | ARCHIVE_TYPE ?= "TAR SRPM" |
7 | DISTRO ?= "poky" | 7 | DISTRO ?= "poky" |
8 | PATCHES_ARCHIVE_WITH_SERIES = 'TRUE' | 8 | PATCHES_ARCHIVE_WITH_SERIES = 'TRUE' |
9 | 9 | ||
10 | def parse_var(d,var): | ||
11 | ''' parse variable like ${PV} in "require xxx_${PV}.inc" to a real value. for example, change "require xxx_${PV}.inc" to "require xxx_1.2.inc" ''' | ||
12 | import re | ||
13 | pat = re.compile('.*\$({(.*)}).*') | ||
14 | if '$' not in var and '/' not in var: | ||
15 | return var | ||
16 | else: | ||
17 | if '/' in var: | ||
18 | return [i for i in var.split('/') if i.endswith('.inc')][0] | ||
19 | elif '$' in var: | ||
20 | m = pat.match(var) | ||
21 | patstr = '\$' + m.group(1) | ||
22 | var_str = m.group(2) | ||
23 | return re.sub(patstr,d.getVar(var_str,True),var) | ||
24 | else: | ||
25 | return var | ||
26 | |||
27 | def get_bb_inc(d): | 10 | def get_bb_inc(d): |
28 | '''create a directory "script-logs" including .bb and .inc file in ${WORKDIR}''' | 11 | '''create a directory "script-logs" including .bb and .inc file in ${WORKDIR}''' |
29 | import re | 12 | import re |
@@ -32,14 +15,18 @@ def get_bb_inc(d): | |||
32 | 15 | ||
33 | bbinc = [] | 16 | bbinc = [] |
34 | pat=re.compile('require\s*([^\s]*\.*)(.*)') | 17 | pat=re.compile('require\s*([^\s]*\.*)(.*)') |
35 | file_dir = d.getVar('FILE', True) | ||
36 | bbdir = os.path.dirname(file_dir) | ||
37 | work_dir = d.getVar('WORKDIR', True) | 18 | work_dir = d.getVar('WORKDIR', True) |
38 | os.chdir(work_dir) | 19 | bbfile = d.getVar('FILE', True) |
39 | bb.mkdirhier("script-logs") | 20 | bbdir = os.path.dirname(bbfile) |
40 | os.chdir(bbdir) | 21 | script_logs = os.path.join(work_dir,'script-logs') |
41 | bbfile = os.path.basename(file_dir) | 22 | bb_inc = os.path.join(script_logs,'bb_inc') |
42 | bbinc.append(bbfile) | 23 | bb.mkdirhier(script_logs) |
24 | bb.mkdirhier(bb_inc) | ||
25 | |||
26 | def find_file(dir,file): | ||
27 | for root, dirs, files in os.walk(dir): | ||
28 | if file in files: | ||
29 | return os.path.join(root,file) | ||
43 | 30 | ||
44 | def get_inc (file): | 31 | def get_inc (file): |
45 | f = open(file,'r') | 32 | f = open(file,'r') |
@@ -49,21 +36,26 @@ def get_bb_inc(d): | |||
49 | else: | 36 | else: |
50 | try: | 37 | try: |
51 | incfile = pat.match(line).group(1) | 38 | incfile = pat.match(line).group(1) |
52 | incfile = parse_var(d,incfile) | 39 | incfile = bb.data.expand(os.path.basename(incfile),d) |
53 | bbinc.append(incfile) | 40 | abs_incfile = find_file(bbdir,incfile) |
54 | get_inc(incfile) | 41 | if abs_incfile: |
55 | except (IOError,AttributeError): | 42 | bbinc.append(abs_incfile) |
43 | get_inc(abs_incfile) | ||
44 | except AttributeError: | ||
56 | pass | 45 | pass |
57 | get_inc(bbfile) | 46 | get_inc(bbfile) |
58 | os.chdir(work_dir) | 47 | bbinc = list(set(bbinc)) |
59 | for root, dirs, files in os.walk(bbdir): | 48 | for bbincfile in bbinc: |
60 | for file in bbinc: | 49 | shutil.copy(bbincfile,bb_inc) |
61 | if file in files: | 50 | |
62 | shutil.copy(root + '/' + file,'script-logs') | 51 | try: |
63 | oe.path.copytree('temp', 'script-logs') | 52 | bb.mkdirhier(os.path.join(script_logs,'temp')) |
64 | return work_dir + '/script-logs' | 53 | oe.path.copytree(os.path.join(work_dir,'temp'), os.path.join(script_logs,'temp')) |
65 | 54 | except (IOError,AttributeError): | |
66 | def get_all_patches(d): | 55 | pass |
56 | return script_logs | ||
57 | |||
58 | def get_series(d): | ||
67 | '''copy patches and series file to a pointed directory which will be archived to tarball in ${WORKDIR}''' | 59 | '''copy patches and series file to a pointed directory which will be archived to tarball in ${WORKDIR}''' |
68 | import shutil | 60 | import shutil |
69 | 61 | ||
@@ -71,11 +63,11 @@ def get_all_patches(d): | |||
71 | pf = d.getVar('PF', True) | 63 | pf = d.getVar('PF', True) |
72 | work_dir = d.getVar('WORKDIR', True) | 64 | work_dir = d.getVar('WORKDIR', True) |
73 | s = d.getVar('S',True) | 65 | s = d.getVar('S',True) |
74 | dest = os.path.join(work_dir, pf + '-patches') | 66 | dest = os.path.join(work_dir, pf + '-series') |
75 | shutil.rmtree(dest, ignore_errors=True) | 67 | shutil.rmtree(dest, ignore_errors=True) |
76 | bb.mkdirhier(dest) | 68 | bb.mkdirhier(dest) |
77 | 69 | ||
78 | src_uri = d.getVar('SRC_URI', 1).split() | 70 | src_uri = d.getVar('SRC_URI', True).split() |
79 | fetch = bb.fetch2.Fetch(src_uri, d) | 71 | fetch = bb.fetch2.Fetch(src_uri, d) |
80 | locals = (fetch.localpath(url) for url in fetch.urls) | 72 | locals = (fetch.localpath(url) for url in fetch.urls) |
81 | for local in locals: | 73 | for local in locals: |
@@ -90,7 +82,8 @@ def get_all_patches(d): | |||
90 | shutil.copy(patch,dest) | 82 | shutil.copy(patch,dest) |
91 | except IOError: | 83 | except IOError: |
92 | if os.path.isdir(patch): | 84 | if os.path.isdir(patch): |
93 | oe.path.copytree(patch,dest) | 85 | bb.mkdirhier(os.path.join(dest,patch)) |
86 | oe.path.copytree(patch, os.path.join(dest,patch)) | ||
94 | return dest | 87 | return dest |
95 | 88 | ||
96 | def get_applying_patches(d): | 89 | def get_applying_patches(d): |
@@ -124,92 +117,85 @@ def not_tarball(d): | |||
124 | else: | 117 | else: |
125 | return False | 118 | return False |
126 | 119 | ||
127 | def get_source_from_downloads(d,middle_name): | 120 | def get_source_from_downloads(d,stage_name): |
128 | '''copy tarball of $P to $WORKDIR when this tarball exists in $DL_DIR''' | 121 | '''copy tarball of $P to $WORKDIR when this tarball exists in $DL_DIR''' |
129 | if middle_name in 'patched' 'configured': | 122 | if stage_name in 'patched' 'configured': |
130 | return | 123 | return |
131 | pf = d.getVar('PF', True) | 124 | pf = d.getVar('PF', True) |
132 | dl_dir = d.getVar('DL_DIR',True) | 125 | dl_dir = d.getVar('DL_DIR',True) |
133 | try: | 126 | try: |
134 | source = os.path.basename(d.getVar('SRC_URI', 1).split()[0]) | 127 | source = os.path.join(dl_dir,os.path.basename(d.getVar('SRC_URI', True).split()[0])) |
135 | os.chdir(dl_dir) | ||
136 | if os.path.exists(source) and not os.path.isdir(source): | 128 | if os.path.exists(source) and not os.path.isdir(source): |
137 | return source | 129 | return source |
138 | except (IndexError, OSError): | 130 | except (IndexError, OSError): |
139 | pass | 131 | pass |
132 | return '' | ||
133 | |||
134 | def do_tarball(workdir,srcdir,tarname): | ||
135 | '''tar "srcdir" under "workdir" to "tarname"''' | ||
136 | import tarfile | ||
140 | 137 | ||
141 | def archive_sources_from_directory(d,middle_name): | 138 | sav_dir = os.getcwd() |
139 | os.chdir(workdir) | ||
140 | if (len(os.listdir(srcdir))) != 0: | ||
141 | tar = tarfile.open(tarname, "w:gz") | ||
142 | tar.add(srcdir) | ||
143 | tar.close() | ||
144 | else: | ||
145 | tarname = '' | ||
146 | os.chdir(sav_dir) | ||
147 | return tarname | ||
148 | |||
149 | def archive_sources_from_directory(d,stage_name): | ||
142 | '''archive sources codes tree to tarball when tarball of $P doesn't exist in $DL_DIR''' | 150 | '''archive sources codes tree to tarball when tarball of $P doesn't exist in $DL_DIR''' |
143 | import tarfile | ||
144 | import shutil | 151 | import shutil |
145 | 152 | ||
146 | s = d.getVar('S',True) | 153 | s = d.getVar('S',True) |
147 | workdir=d.getVar('WORKDIR', True) | 154 | work_dir=d.getVar('WORKDIR', True) |
148 | PF = d.getVar('PF',True) | 155 | PF = d.getVar('PF',True) |
149 | tarname = PF + '-' + middle_name + ".tar.gz" | 156 | tarname = PF + '-' + stage_name + ".tar.gz" |
150 | 157 | ||
151 | if os.path.exists(s) and s is not workdir: | 158 | if os.path.exists(s) and work_dir in s: |
152 | sourcedir = os.path.basename(s) | ||
153 | tarbase = os.path.dirname(s) | ||
154 | if not sourcedir or os.path.dirname(tarbase) == workdir: | ||
155 | sourcedir = os.path.basename(os.path.dirname(s)) | ||
156 | tarbase = os.path.dirname(os.path.dirname(s)) | ||
157 | os.chdir(tarbase) | ||
158 | else: | ||
159 | sourcedir = os.path.basename(s) | ||
160 | if not os.path.exists(sourcedir): | ||
161 | os.mkdir(sourcedir) | ||
162 | try: | 159 | try: |
163 | for file in os.listdir(s): | 160 | source_dir = os.path.join(work_dir,[ i for i in s.replace(work_dir,'').split('/') if i][0]) |
164 | if file is not 'temp' and file is not sourcedir: | 161 | except IndexError: |
165 | shutil.copy(file,sourcedir) | 162 | if not cmp(s,work_dir): |
166 | except (IOError,OSError): | 163 | return '' |
167 | pass | ||
168 | |||
169 | if (len(os.listdir(sourcedir))) != 0: | ||
170 | tar = tarfile.open( tarname, "w:gz") | ||
171 | tar.add(sourcedir) | ||
172 | tar.close() | ||
173 | if cmp(workdir,os.path.dirname(s)) and not os.path.exists(workdir + '/' + tarname): | ||
174 | shutil.move(os.path.dirname(s) + '/' + tarname,workdir) | ||
175 | else: | 164 | else: |
176 | return | 165 | return '' |
177 | return tarname | 166 | source = os.path.basename(source_dir) |
167 | return do_tarball(work_dir,source,tarname) | ||
178 | 168 | ||
179 | def archive_sources(d,middle_name): | 169 | def archive_sources(d,stage_name): |
180 | '''copy tarball from $DL_DIR to $WORKDIR if have tarball, archive source codes tree in $WORKDIR if $P is directory instead of tarball''' | 170 | '''copy tarball from $DL_DIR to $WORKDIR if have tarball, archive source codes tree in $WORKDIR if $P is directory instead of tarball''' |
181 | import shutil | 171 | import shutil |
182 | work_dir = d.getVar('WORKDIR',True) | 172 | work_dir = d.getVar('WORKDIR',True) |
183 | file = get_source_from_downloads(d,middle_name) | 173 | file = get_source_from_downloads(d,stage_name) |
184 | if file: | 174 | if file: |
185 | shutil.copy(file,work_dir) | 175 | shutil.copy(file,work_dir) |
186 | else: | 176 | else: |
187 | file = archive_sources_from_directory(d,middle_name) | 177 | file = archive_sources_from_directory(d,stage_name) |
188 | return file | 178 | return file |
189 | 179 | ||
190 | 180 | ||
191 | def archive_patches(d,patchdir,series): | 181 | def archive_patches(d,patchdir,series): |
192 | '''archive patches to tarball and also include series files if 'series' is True''' | 182 | '''archive patches to tarball and also include series files if 'series' is True''' |
193 | import tarfile | ||
194 | import shutil | 183 | import shutil |
195 | 184 | ||
196 | s = d.getVar('S',True) | 185 | s = d.getVar('S',True) |
197 | work_dir = d.getVar('WORKDIR', True) | 186 | work_dir = d.getVar('WORKDIR', True) |
198 | os.chdir(work_dir) | ||
199 | patch_dir = os.path.basename(patchdir) | 187 | patch_dir = os.path.basename(patchdir) |
200 | tarname = patch_dir + ".tar.gz" | 188 | tarname = patch_dir + ".tar.gz" |
201 | if series == 'all' and os.path.exists(s + '/patches/series'): | 189 | if series == 'all' and os.path.exists(os.path.join(s,'patches/series')): |
202 | shutil.copy(s + '/patches/series',patch_dir) | 190 | shutil.copy(os.path.join(s,'patches/series'),patchdir) |
203 | tar = tarfile.open(tarname, "w:gz") | 191 | tarname = do_tarball(work_dir,patch_dir,tarname) |
204 | tar.add(patch_dir) | 192 | shutil.rmtree(patchdir, ignore_errors=True) |
205 | tar.close() | ||
206 | shutil.rmtree(patch_dir, ignore_errors=True) | ||
207 | return tarname | 193 | return tarname |
208 | 194 | ||
209 | def select_archive_patches(d,option): | 195 | def select_archive_patches(d,option): |
210 | '''select to archive all patches including non-applying and series or applying patches ''' | 196 | '''select to archive all patches including non-applying and series or applying patches ''' |
211 | if option == "all": | 197 | if option == "all": |
212 | patchdir = get_all_patches(d) | 198 | patchdir = get_series(d) |
213 | elif option == "applying": | 199 | elif option == "applying": |
214 | patchdir = get_applying_patches(d) | 200 | patchdir = get_applying_patches(d) |
215 | try: | 201 | try: |
@@ -221,17 +207,15 @@ def select_archive_patches(d,option): | |||
221 | 207 | ||
222 | def archive_logs(d,logdir,bbinc=False): | 208 | def archive_logs(d,logdir,bbinc=False): |
223 | '''archive logs in temp to tarball and .bb and .inc files if bbinc is True ''' | 209 | '''archive logs in temp to tarball and .bb and .inc files if bbinc is True ''' |
224 | import tarfile | ||
225 | import shutil | 210 | import shutil |
226 | 211 | ||
227 | log_dir = os.path.basename(logdir) | ||
228 | pf = d.getVar('PF',True) | 212 | pf = d.getVar('PF',True) |
213 | work_dir = d.getVar('WORKDIR',True) | ||
214 | log_dir = os.path.basename(logdir) | ||
229 | tarname = pf + '-' + log_dir + ".tar.gz" | 215 | tarname = pf + '-' + log_dir + ".tar.gz" |
230 | tar = tarfile.open(tarname, "w:gz") | 216 | tarname = do_tarball(work_dir,log_dir,tarname) |
231 | tar.add(log_dir) | ||
232 | tar.close() | ||
233 | if bbinc: | 217 | if bbinc: |
234 | shutil.rmtree(log_dir, ignore_errors=True) | 218 | shutil.rmtree(logdir, ignore_errors=True) |
235 | return tarname | 219 | return tarname |
236 | 220 | ||
237 | def get_licenses(d): | 221 | def get_licenses(d): |
@@ -258,16 +242,17 @@ def move_tarball_deploy(d,tarball_list): | |||
258 | target_sys = d.getVar('TARGET_SYS', True) | 242 | target_sys = d.getVar('TARGET_SYS', True) |
259 | pf = d.getVar('PF', True) | 243 | pf = d.getVar('PF', True) |
260 | licenses = get_licenses(d) | 244 | licenses = get_licenses(d) |
245 | work_dir = d.getVar('WORKDIR',True) | ||
261 | tar_sources = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf | 246 | tar_sources = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf |
262 | if not os.path.exists(tar_sources): | 247 | if not os.path.exists(tar_sources): |
263 | bb.mkdirhier(tar_sources) | 248 | bb.mkdirhier(tar_sources) |
264 | for source in tarball_list: | 249 | for source in tarball_list: |
265 | if source: | 250 | if source: |
266 | if os.path.exists(tar_sources + '/' + source): | 251 | if os.path.exists(os.path.join(tar_sources, source)): |
267 | os.remove(tar_sources + '/' + source) | 252 | os.remove(os.path.join(tar_sources,source)) |
268 | shutil.move(source,tar_sources) | 253 | shutil.move(os.path.join(work_dir,source),tar_sources) |
269 | 254 | ||
270 | def verify_var(d): | 255 | def check_archiving_type(d): |
271 | '''check the type for archiving package('tar' or 'srpm')''' | 256 | '''check the type for archiving package('tar' or 'srpm')''' |
272 | try: | 257 | try: |
273 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() not in d.getVar('ARCHIVE_TYPE', True).split(): | 258 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() not in d.getVar('ARCHIVE_TYPE', True).split(): |
@@ -278,7 +263,7 @@ def verify_var(d): | |||
278 | def store_package(d,package_name): | 263 | def store_package(d,package_name): |
279 | '''store tarbablls name to file "tar-package"''' | 264 | '''store tarbablls name to file "tar-package"''' |
280 | try: | 265 | try: |
281 | f = open(d.getVar('WORKDIR',True )+ '/tar-package','a') | 266 | f = open(os.path.join(d.getVar('WORKDIR',True),'tar-package'),'a') |
282 | f.write(package_name + ' ') | 267 | f.write(package_name + ' ') |
283 | f.close() | 268 | f.close() |
284 | except IOError: | 269 | except IOError: |
@@ -286,25 +271,27 @@ def store_package(d,package_name): | |||
286 | 271 | ||
287 | def get_package(d): | 272 | def get_package(d): |
288 | '''get tarballs name from "tar-package"''' | 273 | '''get tarballs name from "tar-package"''' |
274 | work_dir = (d.getVar('WORKDIR', True)) | ||
275 | tarpackage = os.path.join(work_dir,'tar-package') | ||
289 | try: | 276 | try: |
290 | os.chdir(d.getVar('WORKDIR', True)) | 277 | f = open(tarpackage,'r') |
291 | f = open('tar-package','r') | ||
292 | line = list(set(f.readline().replace('\n','').split())) | 278 | line = list(set(f.readline().replace('\n','').split())) |
293 | f.close() | ||
294 | return line | ||
295 | except IOError: | 279 | except IOError: |
296 | pass | 280 | pass |
281 | f.close() | ||
282 | return line | ||
297 | 283 | ||
298 | 284 | ||
299 | def archive_sources_patches(d,middle_name): | 285 | def archive_sources_patches(d,stage_name): |
300 | '''archive sources and patches to tarball. middle_name will append strings ${middle_name} to ${PR} as middle name. for example, zlib-1.4.6-prepatch(middle_name).tar.gz ''' | 286 | '''archive sources and patches to tarball. stage_name will append strings ${stage_name} to ${PR} as middle name. for example, zlib-1.4.6-prepatch(stage_name).tar.gz ''' |
301 | import shutil | 287 | import shutil |
302 | verify_var(d) | 288 | |
289 | check_archiving_type(d) | ||
303 | if not_tarball(d): | 290 | if not_tarball(d): |
304 | return | 291 | return |
305 | 292 | ||
306 | source_tar_name = archive_sources(d,middle_name) | 293 | source_tar_name = archive_sources(d,stage_name) |
307 | if middle_name == "prepatch": | 294 | if stage_name == "prepatch": |
308 | if d.getVar('PATCHES_ARCHIVE_WITH_SERIES',True).upper() == 'TRUE': | 295 | if d.getVar('PATCHES_ARCHIVE_WITH_SERIES',True).upper() == 'TRUE': |
309 | patch_tar_name = select_archive_patches(d,"all") | 296 | patch_tar_name = select_archive_patches(d,"all") |
310 | elif d.getVar('PATCHES_ARCHIVE_WITH_SERIES',True).upper() == 'FALSE': | 297 | elif d.getVar('PATCHES_ARCHIVE_WITH_SERIES',True).upper() == 'FALSE': |
@@ -313,14 +300,14 @@ def archive_sources_patches(d,middle_name): | |||
313 | bb.fatal("Please define 'PATCHES_ARCHIVE_WITH_SERIES' is strings 'True' or 'False' ") | 300 | bb.fatal("Please define 'PATCHES_ARCHIVE_WITH_SERIES' is strings 'True' or 'False' ") |
314 | else: | 301 | else: |
315 | patch_tar_name = '' | 302 | patch_tar_name = '' |
316 | 303 | ||
317 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() not in 'SRPM': | 304 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() not in 'SRPM': |
318 | move_tarball_deploy(d,[source_tar_name,patch_tar_name]) | 305 | move_tarball_deploy(d,[source_tar_name,patch_tar_name]) |
319 | else: | 306 | else: |
320 | tarpackage = d.getVar('WORKDIR', True) + '/tar-package' | 307 | tarpackage = os.path.join(d.getVar('WORKDIR', True),'tar-package') |
321 | if os.path.exists(tarpackage): | 308 | if os.path.exists(tarpackage): |
322 | os.remove(tarpackage) | 309 | os.remove(tarpackage) |
323 | for package in source_tar_name, patch_tar_name: | 310 | for package in os.path.basename(source_tar_name), patch_tar_name: |
324 | if package: | 311 | if package: |
325 | store_package(d,str(package) + ' ') | 312 | store_package(d,str(package) + ' ') |
326 | 313 | ||
@@ -328,14 +315,14 @@ def archive_scripts_logs(d): | |||
328 | '''archive scripts and logs. scripts include .bb and .inc files and logs include stuff in "temp".''' | 315 | '''archive scripts and logs. scripts include .bb and .inc files and logs include stuff in "temp".''' |
329 | 316 | ||
330 | work_dir = d.getVar('WORKDIR', True) | 317 | work_dir = d.getVar('WORKDIR', True) |
331 | os.chdir(work_dir) | 318 | temp_dir = os.path.join(work_dir,'temp') |
332 | source_archive_log_with_scripts = d.getVar('SOURCE_ARCHIVE_LOG_WITH_SCRIPTS', True) | 319 | source_archive_log_with_scripts = d.getVar('SOURCE_ARCHIVE_LOG_WITH_SCRIPTS', True) |
333 | if source_archive_log_with_scripts == 'logs_with_scripts': | 320 | if source_archive_log_with_scripts == 'logs_with_scripts': |
334 | logdir = get_bb_inc(d) | 321 | logdir = get_bb_inc(d) |
335 | tarlog = archive_logs(d,logdir,True) | 322 | tarlog = archive_logs(d,logdir,True) |
336 | elif source_archive_log_with_scripts == 'logs': | 323 | elif source_archive_log_with_scripts == 'logs': |
337 | if os.path.exists('temp'): | 324 | if os.path.exists(temp_dir): |
338 | tarlog = archive_logs(d,'temp',False) | 325 | tarlog = archive_logs(d,temp_dir,False) |
339 | else: | 326 | else: |
340 | return | 327 | return |
341 | 328 | ||
@@ -374,14 +361,14 @@ def create_diff_gz(d): | |||
374 | import shutil | 361 | import shutil |
375 | 362 | ||
376 | work_dir = d.getVar('WORKDIR', True) | 363 | work_dir = d.getVar('WORKDIR', True) |
377 | exclude_from = d.getVar('EXCLUDE_FROM', True).split() | 364 | exclude_from = d.getVar('ARCHIVE_EXCLUDE_FROM', True).split() |
378 | pf = d.getVar('PF', True) | 365 | pf = d.getVar('PF', True) |
379 | licenses = get_licenses(d) | 366 | licenses = get_licenses(d) |
380 | target_sys = d.getVar('TARGET_SYS', True) | 367 | target_sys = d.getVar('TARGET_SYS', True) |
381 | diff_dir = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf | 368 | diff_dir = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf |
382 | diff_file = os.path.join(diff_dir, bb.data.expand("${P}-${PR}.diff.gz",d)) | 369 | diff_file = os.path.join(diff_dir, bb.data.expand("${P}-${PR}.diff.gz",d)) |
383 | os.chdir(work_dir) | 370 | |
384 | f = open('temp/exclude-from-file', 'a') | 371 | f = open(os.path.join(work_dir,'temp/exclude-from-file'), 'a') |
385 | for i in exclude_from: | 372 | for i in exclude_from: |
386 | f.write(i) | 373 | f.write(i) |
387 | f.write("\n") | 374 | f.write("\n") |
@@ -394,7 +381,10 @@ def create_diff_gz(d): | |||
394 | bb.mkdirhier(dest) | 381 | bb.mkdirhier(dest) |
395 | for i in os.listdir(os.getcwd()): | 382 | for i in os.listdir(os.getcwd()): |
396 | if os.path.isfile(i): | 383 | if os.path.isfile(i): |
397 | shutil.copy(i, dest) | 384 | try: |
385 | shutil.copy(i, dest) | ||
386 | except IOError: | ||
387 | os.system('fakeroot cp -rf ' + i + " " + dest ) | ||
398 | 388 | ||
399 | bb.note("Creating .diff.gz in ${DEPLOY_DIR_SRC}/${P}-${PR}.diff.gz") | 389 | bb.note("Creating .diff.gz in ${DEPLOY_DIR_SRC}/${P}-${PR}.diff.gz") |
400 | cmd = "LC_ALL=C TZ=UTC0 diff --exclude-from=" + work_dir + "/temp/exclude-from-file -Naur " + s + '.org' + ' ' + s + " | gzip -c > " + diff_file | 390 | cmd = "LC_ALL=C TZ=UTC0 diff --exclude-from=" + work_dir + "/temp/exclude-from-file -Naur " + s + '.org' + ' ' + s + " | gzip -c > " + diff_file |
@@ -445,12 +435,11 @@ do_kernel_checkout[postfuncs] += "do_archive_linux_yocto " | |||
445 | python do_remove_tarball(){ | 435 | python do_remove_tarball(){ |
446 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() == 'SRPM': | 436 | if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True).upper() == 'SRPM': |
447 | work_dir = d.getVar('WORKDIR', True) | 437 | work_dir = d.getVar('WORKDIR', True) |
448 | os.chdir(work_dir) | ||
449 | try: | 438 | try: |
450 | for file in os.listdir(os.getcwd()): | 439 | for file in os.listdir(os.getcwd()): |
451 | if file in get_package(d): | 440 | if file in get_package(d): |
452 | os.remove(file) | 441 | os.remove(file) |
453 | os.remove('tar-package') | 442 | os.remove(os.path.join(work_dir,'tar-package')) |
454 | except (TypeError,OSError): | 443 | except (TypeError,OSError): |
455 | pass | 444 | pass |
456 | } | 445 | } |