package_rpm: fix move wrong generated rpm name - closes #5078
[vuplus_openembedded] / classes / package_rpm.bbclass
1 inherit package
2
3 RPMBUILD="rpmbuild --short-circuit ${RPMOPTS}"
4 IMAGE_PKGTYPE ?= "rpm"
5
6 RPMBUILDPATH="${WORKDIR}/rpm"
7
8 RPMOPTS="--rcfile=${WORKDIR}/rpmrc"
9 RPMOPTS="--rcfile=${WORKDIR}/rpmrc --target ${TARGET_SYS}"
10 RPM="rpm ${RPMOPTS}"
11
12 python write_specfile() {
13         from bb import data, build
14         import sys
15
16         version = bb.data.getVar('PV', d, 1)
17         version = version.replace('-', '+')
18         bb.data.setVar('RPMPV', version, d)
19
20         out_vartranslate = {
21                 "PKG": "Name",
22                 "RPMPV": "Version",
23                 "DESCRIPTION": "%description",
24                 "ROOT": "BuildRoot",
25                 "LICENSE": "License",
26                 "SECTION": "Group",
27                 "pkg_postinst": "%post",
28                 "pkg_preinst": "%pre",
29         }
30
31         root = bb.data.getVar('ROOT', d)
32
33         # get %files
34         filesvar = bb.data.expand(bb.data.getVar('FILES', d), d) or ""
35         from glob import glob
36         files = filesvar.split()
37         todelete = []
38         for file in files:
39                 if file[0] == '.':
40                         newfile = file[1:]
41                         files[files.index(file)] = newfile
42                         file = newfile
43                 else:
44                         newfile = file
45                 realfile = os.path.join(root, './'+file)
46                 if not glob(realfile):
47                         todelete.append(files[files.index(newfile)])
48         for r in todelete:
49                 try:
50                         del files[files.index(r)]
51                 except ValueError:
52                         pass
53         if not files and bb.data.getVar('ALLOW_EMPTY', d) != "1":
54                 from bb import note
55                 note("Not creating empty archive for %s" % (bb.data.expand('${PKG}-${PV}-${PR}${DISTRO_PR}', d, True)))
56                 return
57
58         # output .spec using this metadata store
59         try:
60                 from __builtin__ import file
61                 if not bb.data.getVar('OUTSPECFILE', d):
62                         raise OSError('eek!')
63                 specfile = file(bb.data.getVar('OUTSPECFILE', d), 'w')
64         except OSError:
65                 raise bb.build.FuncFailed("unable to open spec file for writing.")
66
67         fd = specfile
68         for var in out_vartranslate.keys():
69                 if out_vartranslate[var][0] == "%":
70                         continue
71                 val = bb.data.getVar(var, d, 1)
72                 if val:
73                         fd.write("%s\t: %s\n" % (out_vartranslate[var], val))
74
75         fd.write("AutoReqProv: no\n")
76
77         def fix_dep_versions(varname):
78                 depends = bb.utils.explode_dep_versions(bb.data.getVar(varname, d, True) or "")
79                 newdeps = []
80                 for dep in depends:
81                         ver = depends[dep]
82                         if dep and ver:
83                                 if '-' in ver:
84                                         subd = read_subpkgdata_dict(dep, d)
85                                         pv = subd['PV']
86                                         reppv = pv.replace('-', '+')
87                                         ver = ver.replace(pv, reppv)
88                                 newdeps.append("%s (%s)" % (dep, ver))
89                         elif dep:
90                                 newdeps.append(dep)
91                 bb.data.setVar(varname, " ".join(newdeps), d)
92
93         fix_dep_versions('RDEPENDS')
94         fix_dep_versions('RRECOMMENDS')
95
96         bb.build.exec_func("mapping_rename_hook", d)
97
98         def write_dep_field(varname, outstring):
99                 depends = bb.utils.explode_dep_versions(bb.data.getVar(varname, d, True) or "")
100                 for dep in depends:
101                         ver = depends[dep]
102                         if dep and ver:
103                                 fd.write("%s: %s %s\n" % (outstring, dep, ver))
104                         elif dep:
105                                 fd.write("%s: %s\n" % (outstring, dep))
106
107         write_dep_field('RDEPENDS', 'Requires')
108         write_dep_field('RRECOMMENDS', 'Recommends')
109         write_dep_field('RPROVIDES', 'Provides')
110
111         fd.write("Release\t: %s\n" % bb.data.expand('${PR}${DISTRO_PR}', d, True))
112         fd.write("Summary\t: .\n")
113
114         for var in out_vartranslate.keys():
115                 if out_vartranslate[var][0] != "%":
116                         continue
117                 val = bb.data.getVar(var, d)
118                 if val:
119                         fd.write(out_vartranslate[var] + "\n")
120                         fd.write(val + "\n\n")
121
122         fd.write("%files\n")
123         for file in files:
124                 if file[0] != '/':
125                         fd.write('/')
126                 fd.write("%s\n" % file)
127
128         fd.close()
129
130         # call out rpm -bb on the .spec, thereby creating an rpm
131
132         bb.note(bb.data.expand("${RPMBUILD} -bb ${OUTSPECFILE}", d))
133
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)
137
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)
142 }
143
144 rpm_prep() {
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
150         fi
151 }
152
153 python do_package_rpm () {
154         workdir = bb.data.getVar('WORKDIR', d, 1)
155         if not workdir:
156                 bb.error("WORKDIR not defined, unable to package")
157                 return
158
159         import os # path manipulations
160         outdir = bb.data.getVar('DEPLOY_DIR_RPM', d, 1)
161         if not outdir:
162                 bb.error("DEPLOY_DIR_RPM not defined, unable to package")
163                 return
164         bb.mkdirhier(outdir)
165
166         packages = bb.data.getVar('PACKAGES', d, 1)
167         if not packages:
168                 bb.debug(1, "PACKAGES not defined, nothing to package")
169                 return
170
171         if packages == []:
172                 bb.debug(1, "No packages; nothing to do")
173                 return
174
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)
178
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)
183
184                 lf = bb.utils.lockfile(root + ".lock")
185
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)
189                 if not pkgname:
190                         pkgname = pkg
191                 bb.data.setVar('PKG', pkgname, localdata)
192
193                 overrides = bb.data.getVar('OVERRIDES', localdata)
194                 if not overrides:
195                         raise bb.build.FuncFailed('OVERRIDES not defined')
196                 overrides = bb.data.expand(overrides, localdata)
197                 bb.data.setVar('OVERRIDES', overrides + ':' + pkg, localdata)
198
199                 bb.data.update_data(localdata)
200
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)
211 }
212
213 python () {
214     import bb
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)
220 }
221
222
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)
227 }
228 do_package_write_rpm[dirs] = "${D}"
229 addtask package_write_rpm before do_package_write after do_package