3 RPMBUILD="rpmbuild --short-circuit ${RPMOPTS}"
6 RPMBUILDPATH="${WORKDIR}/rpm"
8 RPMOPTS="--rcfile=${WORKDIR}/rpmrc"
9 RPMOPTS="--rcfile=${WORKDIR}/rpmrc --target ${TARGET_SYS}"
12 python write_specfile() {
13 from bb import data, build
16 version = bb.data.getVar('PV', d, 1)
17 version = version.replace('-', '+')
18 bb.data.setVar('RPMPV', version, d)
23 "DESCRIPTION": "%description",
27 "pkg_postinst": "%post",
28 "pkg_preinst": "%pre",
31 root = bb.data.getVar('ROOT', d)
34 filesvar = bb.data.expand(bb.data.getVar('FILES', d), d) or ""
36 files = filesvar.split()
41 files[files.index(file)] = newfile
45 realfile = os.path.join(root, './'+file)
46 if not glob(realfile):
47 todelete.append(files[files.index(newfile)])
50 del files[files.index(r)]
53 if not files and bb.data.getVar('ALLOW_EMPTY', d) != "1":
55 note("Not creating empty archive for %s" % (bb.data.expand('${PKG}-${PV}-${PR}${DISTRO_PR}', d, True)))
58 # output .spec using this metadata store
60 from __builtin__ import file
61 if not bb.data.getVar('OUTSPECFILE', d):
63 specfile = file(bb.data.getVar('OUTSPECFILE', d), 'w')
65 raise bb.build.FuncFailed("unable to open spec file for writing.")
68 for var in out_vartranslate.keys():
69 if out_vartranslate[var][0] == "%":
71 val = bb.data.getVar(var, d, 1)
73 fd.write("%s\t: %s\n" % (out_vartranslate[var], val))
75 fd.write("AutoReqProv: no\n")
77 def fix_dep_versions(varname):
78 depends = bb.utils.explode_dep_versions(bb.data.getVar(varname, d, True) or "")
84 subd = read_subpkgdata_dict(dep, d)
86 reppv = pv.replace('-', '+')
87 ver = ver.replace(pv, reppv)
88 newdeps.append("%s (%s)" % (dep, ver))
91 bb.data.setVar(varname, " ".join(newdeps), d)
93 fix_dep_versions('RDEPENDS')
94 fix_dep_versions('RRECOMMENDS')
96 bb.build.exec_func("mapping_rename_hook", d)
98 def write_dep_field(varname, outstring):
99 depends = bb.utils.explode_dep_versions(bb.data.getVar(varname, d, True) or "")
103 fd.write("%s: %s %s\n" % (outstring, dep, ver))
105 fd.write("%s: %s\n" % (outstring, dep))
107 write_dep_field('RDEPENDS', 'Requires')
108 write_dep_field('RRECOMMENDS', 'Recommends')
109 write_dep_field('RPROVIDES', 'Provides')
111 fd.write("Release\t: %s\n" % bb.data.expand('${PR}${DISTRO_PR}', d, True))
112 fd.write("Summary\t: .\n")
114 for var in out_vartranslate.keys():
115 if out_vartranslate[var][0] != "%":
117 val = bb.data.getVar(var, d)
119 fd.write(out_vartranslate[var] + "\n")
120 fd.write(val + "\n\n")
126 fd.write("%s\n" % file)
130 # call out rpm -bb on the .spec, thereby creating an rpm
132 bb.note(bb.data.expand("${RPMBUILD} -bb ${OUTSPECFILE}", d))
134 bb.data.setVar('BUILDSPEC', "${RPMBUILD} -bb ${OUTSPECFILE}\n", d)
135 bb.data.setVarFlag('BUILDSPEC', 'func', '1', d)
136 bb.build.exec_func('BUILDSPEC', d)
138 # move the rpm into the pkgoutdir
139 rpm = bb.data.expand('${RPMBUILDPATH}/RPMS/${TARGET_ARCH}/${PKG}-${RPMPV}-${PR}${DISTRO_PR}.${TARGET_ARCH}.rpm', d)
140 outrpm = bb.data.expand('${DEPLOY_DIR_RPM}/${PACKAGE_ARCH}/${PKG}-${RPMPV}-${PR}.${TARGET_ARCH}.rpm', d)
141 bb.movefile(rpm, outrpm)
145 if [ ! -e ${WORKDIR}/rpmrc ]; then
146 mkdir -p ${RPMBUILDPATH}/{SPECS,RPMS/{i386,i586,i686,noarch,ppc,mips,mipsel,arm},SRPMS,SOURCES,BUILD}
147 echo 'macrofiles:${STAGING_DIR_NATIVE}/usr/lib/rpm/macros:${WORKDIR}/macros' > ${WORKDIR}/rpmrc
148 echo '%_topdir ${RPMBUILDPATH}' > ${WORKDIR}/macros
149 echo '%_repackage_dir ${WORKDIR}' >> ${WORKDIR}/macros
153 python do_package_rpm () {
154 workdir = bb.data.getVar('WORKDIR', d, 1)
156 bb.error("WORKDIR not defined, unable to package")
159 import os # path manipulations
160 outdir = bb.data.getVar('DEPLOY_DIR_RPM', d, 1)
162 bb.error("DEPLOY_DIR_RPM not defined, unable to package")
166 packages = bb.data.getVar('PACKAGES', d, 1)
168 bb.debug(1, "PACKAGES not defined, nothing to package")
172 bb.debug(1, "No packages; nothing to do")
175 # If "rpm" comes into overrides the presence of this function causes problems.
176 # Since we don't need it, remove it for now - hacky.
177 bb.data.delVar("do_package_write_rpm", d)
179 for pkg in packages.split():
180 localdata = bb.data.createCopy(d)
181 pkgdest = bb.data.getVar('PKGDEST', d, 1)
182 root = "%s/%s" % (pkgdest, pkg)
184 lf = bb.utils.lockfile(root + ".lock")
186 bb.data.setVar('ROOT', '', localdata)
187 bb.data.setVar('ROOT_%s' % pkg, root, localdata)
188 pkgname = bb.data.getVar('PKG_%s' % pkg, localdata, 1)
191 bb.data.setVar('PKG', pkgname, localdata)
193 overrides = bb.data.getVar('OVERRIDES', localdata)
195 raise bb.build.FuncFailed('OVERRIDES not defined')
196 overrides = bb.data.expand(overrides, localdata)
197 bb.data.setVar('OVERRIDES', overrides + ':' + pkg, localdata)
199 bb.data.update_data(localdata)
201 basedir = os.path.join(os.path.dirname(root))
202 pkgoutdir = os.path.join(outdir, bb.data.getVar('PACKAGE_ARCH', localdata, 1))
203 bb.mkdirhier(pkgoutdir)
204 bb.data.setVar('OUTSPECFILE', os.path.join(workdir, "%s.spec" % pkg), localdata)
205 # Save the value of RPMBUILD expanded into the new dictonary so any
206 # changes in the compoents that make up workdir don't break packaging
207 bb.data.setVar('RPMBUILD', bb.data.getVar("RPMBUILD", d, True), localdata)
208 bb.data.setVar('RPMBUILDPATH', bb.data.getVar("RPMBUILDPATH", d, True), localdata)
209 bb.build.exec_func('write_specfile', localdata)
210 bb.utils.unlockfile(lf)
215 if bb.data.getVar('PACKAGES', d, True) != '':
216 deps = (bb.data.getVarFlag('do_package_write_rpm', 'depends', d) or "").split()
217 deps.append('rpm-native:do_populate_staging')
218 deps.append('fakeroot-native:do_populate_staging')
219 bb.data.setVarFlag('do_package_write_rpm', 'depends', " ".join(deps), d)
223 python do_package_write_rpm () {
224 bb.build.exec_func("read_subpackage_metadata", d)
225 bb.build.exec_func("rpm_prep", d)
226 bb.build.exec_func("do_package_rpm", d)
228 do_package_write_rpm[dirs] = "${D}"
229 addtask package_write_rpm before do_package_write after do_package