summaryrefslogtreecommitdiffstats
path: root/meta/classes
diff options
context:
space:
mode:
authorLianhao Lu <lianhao.lu@intel.com>2011-01-30 14:07:50 +0800
committerRichard Purdie <richard.purdie@linuxfoundation.org>2011-02-01 23:59:37 +0000
commit382075a9c2a5877d198a217161558da6ad2d5f89 (patch)
tree33b53b274eb1c921721f71cf87904e24851c7627 /meta/classes
parentb94f9ccd05a339a5e3e8ec4c7bd8c727ca575871 (diff)
downloadpoky-382075a9c2a5877d198a217161558da6ad2d5f89.tar.gz
rootfs_rpm/package_rpm.bbclass: Move func from rootfs_rpm to package_rpm
package_deb.bbclass: 1. Modified package_update_index_rpm() and package_generate_rpm_conf() to generate sperate depsolver db and rpm configuration, for target packages and host packages respectively. 2. Added new function package_install_internal_rpm() to install a list deb packages to a specified root directory, with the specified package architecutre information. 3. Added new function resolve_package_rpm() to resolve package names to filepaths. rootfs_deb.bbclass: Used the above new functions to install the rootfs. [sgw: merged changes for createrepo] Signed-off-by: Lianhao Lu <lianhao.lu@intel.com> Signed-off-by: Saul Wold <sgw@linux.intel.com>
Diffstat (limited to 'meta/classes')
-rw-r--r--meta/classes/package_rpm.bbclass230
-rw-r--r--meta/classes/rootfs_rpm.bbclass145
2 files changed, 234 insertions, 141 deletions
diff --git a/meta/classes/package_rpm.bbclass b/meta/classes/package_rpm.bbclass
index 8891f06ffa..cc262dc831 100644
--- a/meta/classes/package_rpm.bbclass
+++ b/meta/classes/package_rpm.bbclass
@@ -15,6 +15,8 @@ python package_rpm_install () {
15 bb.fatal("package_rpm_install not implemented!") 15 bb.fatal("package_rpm_install not implemented!")
16} 16}
17 17
18RPMCONF_TARGET_BASE = "${DEPLOY_DIR_RPM}/solvedb"
19RPMCONF_HOST_BASE = "${DEPLOY_DIR_RPM}/solvedb-sdk"
18# 20#
19# Update the Packages depsolver db in ${DEPLOY_DIR_RPM} 21# Update the Packages depsolver db in ${DEPLOY_DIR_RPM}
20# 22#
@@ -26,15 +28,18 @@ package_update_index_rpm () {
26 fi 28 fi
27 29
28 packagedirs="" 30 packagedirs=""
31 packagedirs_sdk=""
29 for arch in $rpmarchs ; do 32 for arch in $rpmarchs ; do
30 sdkarch=`echo $arch | sed -e 's/${HOST_ARCH}/${SDK_ARCH}/'` 33 sdkarch=`echo $arch | sed -e 's/${HOST_ARCH}/${SDK_ARCH}/'`
34 extension="-nativesdk"
35 if [ "$sdkarch" = "all" -o "$sdkarch" = "any" -o "$sdkarch" = "noarch" ]; then
36 extension=""
37 fi
31 packagedirs="$packagedirs ${DEPLOY_DIR_RPM}/$arch" 38 packagedirs="$packagedirs ${DEPLOY_DIR_RPM}/$arch"
32 #packagedirs="$packagedirs ${DEPLOY_DIR_RPM}/$sdkarch-nativesdk" 39 packagedirs_sdk="$packagedirs_sdk ${DEPLOY_DIR_RPM}/$sdkarch$extension"
33 done 40 done
34 41
35 #packagedirs="$packagedirs ${DEPLOY_DIR_RPM}/${SDK_ARCH}-${TARGET_ARCH}-canadian" 42 cat /dev/null > ${RPMCONF_TARGET_BASE}.conf
36
37 cat /dev/null > ${DEPLOY_DIR_RPM}/solvedb.conf
38 for pkgdir in $packagedirs; do 43 for pkgdir in $packagedirs; do
39 if [ -e $pkgdir/ ]; then 44 if [ -e $pkgdir/ ]; then
40 echo "Generating solve db for $pkgdir..." 45 echo "Generating solve db for $pkgdir..."
@@ -48,7 +53,25 @@ package_update_index_rpm () {
48 --ignoresize --nosignature --nodigest \ 53 --ignoresize --nosignature --nodigest \
49 -D "__dbi_txn create nofsync" \ 54 -D "__dbi_txn create nofsync" \
50 $pkgdir/solvedb/manifest 55 $pkgdir/solvedb/manifest
51 echo $pkgdir/solvedb >> ${DEPLOY_DIR_RPM}/solvedb.conf 56 echo $pkgdir/solvedb >> ${RPMCONF_TARGET_BASE}.conf
57 fi
58 done
59
60 cat /dev/null > ${RPMCONF_HOST_BASE}.conf
61 for pkgdir in $packagedirs_sdk; do
62 if [ -e $pkgdir/ ]; then
63 echo "Generating solve db for $pkgdir..."
64 rm -rf $pkgdir/solvedb
65 mkdir -p $pkgdir/solvedb
66 echo "# Dynamically generated solve manifest" >> $pkgdir/solvedb/manifest
67 find $pkgdir -maxdepth 1 -type f >> $pkgdir/solvedb/manifest
68 ${RPM} -i --replacepkgs --replacefiles --oldpackage \
69 -D "_dbpath $pkgdir/solvedb" --justdb \
70 --noaid --nodeps --noorder --noscripts --notriggers --noparentdirs --nolinktos --stats \
71 --ignoresize --nosignature --nodigest \
72 -D "__dbi_txn create nofsync" \
73 $pkgdir/solvedb/manifest
74 echo $pkgdir/solvedb >> ${RPMCONF_HOST_BASE}.conf
52 fi 75 fi
53 done 76 done
54} 77}
@@ -58,16 +81,27 @@ package_update_index_rpm () {
58# generated depsolver db's... 81# generated depsolver db's...
59# 82#
60package_generate_rpm_conf () { 83package_generate_rpm_conf () {
61 printf "_solve_dbpath " > ${DEPLOY_DIR_RPM}/solvedb.macro 84 printf "_solve_dbpath " > ${RPMCONF_TARGET_BASE}.macro
85 colon=false
86 for each in `cat ${RPMCONF_TARGET_BASE}.conf` ; do
87 if [ "$colon" == true ]; then
88 printf ":" >> ${RPMCONF_TARGET_BASE}.macro
89 fi
90 printf "%s" $each >> ${RPMCONF_TARGET_BASE}.macro
91 colon=true
92 done
93 printf "\n" >> ${RPMCONF_TARGET_BASE}.macro
94
95 printf "_solve_dbpath " > ${RPMCONF_HOST_BASE}.macro
62 colon=false 96 colon=false
63 for each in `cat ${DEPLOY_DIR_RPM}/solvedb.conf` ; do 97 for each in `cat ${RPMCONF_HOST_BASE}.conf` ; do
64 if [ "$colon" == true ]; then 98 if [ "$colon" == true ]; then
65 printf ":" >> ${DEPLOY_DIR_RPM}/solvedb.macro 99 printf ":" >> ${RPMCONF_HOST_BASE}.macro
66 fi 100 fi
67 printf "%s" $each >> ${DEPLOY_DIR_RPM}/solvedb.macro 101 printf "%s" $each >> ${RPMCONF_HOST_BASE}.macro
68 colon=true 102 colon=true
69 done 103 done
70 printf "\n" >> ${DEPLOY_DIR_RPM}/solvedb.macro 104 printf "\n" >> ${RPMCONF_HOST_BASE}.macro
71} 105}
72 106
73rpm_log_check() { 107rpm_log_check() {
@@ -90,6 +124,182 @@ rpm_log_check() {
90 true 124 true
91} 125}
92 126
127
128#
129# Resolve package names to filepaths
130# resolve_pacakge <pkgname> <solvdb conffile>
131#
132resolve_package_rpm () {
133 local pkg="$1"
134 local conffile="$2"
135 local pkg_name=""
136 for solve in `cat ${conffile}`; do
137 pkg_name=$(${RPM} -D "_dbpath $solve" -D "__dbi_txn create nofsync" -q --yaml $pkg | grep -i 'Packageorigin' | cut -d : -f 2)
138 if [ -n "$pkg_name" ]; then
139 break;
140 fi
141 done
142 echo $pkg_name
143}
144
145#
146# install a bunch of packages using rpm
147# the following shell variables needs to be set before calling this func:
148# INSTALL_ROOTFS_RPM - install root dir
149# INSTALL_PLATFORM_RPM - main platform
150# INSTALL_PLATFORM_EXTRA_RPM - extra platform
151# INSTALL_CONFBASE_RPM - configuration file base name
152# INSTALL_PACKAGES_NORMAL_RPM - packages to be installed
153# INSTALL_PACKAGES_ATTEMPTONLY_RPM - packages attemped to be installed only
154# INSTALL_PACKAGES_LINGUAS_RPM - additional packages for uclibc
155# INSTALL_PROVIDENAME_RPM - content for provide name
156# INSTALL_TASK_RPM - task name
157
158package_install_internal_rpm () {
159
160 local target_rootfs="${INSTALL_ROOTFS_RPM}"
161 local platform="${INSTALL_PLATFORM_RPM}"
162 local platform_extra="${INSTALL_PLATFORM_EXTRA_RPM}"
163 local confbase="${INSTALL_CONFBASE_RPM}"
164 local package_to_install="${INSTALL_PACKAGES_NORMAL_RPM}"
165 local package_attemptonly="${INSTALL_PACKAGES_ATTEMPTONLY_RPM}"
166 local package_lingusa="${INSTALL_PACKAGES_LINGUAS_RPM}"
167 local providename="${INSTALL_PROVIDENAME_RPM}"
168 local task="${INSTALL_TASK_RPM}"
169
170 # Setup base system configuration
171 mkdir -p ${target_rootfs}/etc/rpm/
172 echo "${platform}-unknown-linux" >${target_rootfs}/etc/rpm/platform
173 if [ ! -z "$platform_extra" ]; then
174 for pt in $platform_extra ; do
175 echo "$pt-unknown-linux" >> ${target_rootfs}/etc/rpm/platform
176 done
177 fi
178
179 # Tell RPM that the "/" directory exist and is available
180 mkdir -p ${target_rootfs}/etc/rpm/sysinfo
181 echo "/" >${target_rootfs}/etc/rpm/sysinfo/Dirnames
182 if [ ! -z "$providename" ]; then
183 >>${target_rootfs}/etc/rpm/sysinfo/Providename
184 for provide in $providename ; do
185 echo $provide >> ${target_rootfs}/etc/rpm/sysinfo/Providename
186 done
187 fi
188
189 # Setup manifest of packages to install...
190 mkdir -p ${target_rootfs}/install
191 echo "# Install manifest" > ${target_rootfs}/install/install.manifest
192
193 # Uclibc builds don't provide this stuff...
194 if [ x${TARGET_OS} = "xlinux" ] || [ x${TARGET_OS} = "xlinux-gnueabi" ] ; then
195 if [ ! -z "${package_lingusa}" ]; then
196 for pkg in ${package_lingusa}; do
197 echo "Processing $pkg..."
198 pkg_name=$(resolve_package_rpm $pkg ${confbase}.conf)
199 if [ -z "$pkg_name" ]; then
200 echo "Unable to find package $pkg!"
201 exit 1
202 fi
203 echo $pkg_name >> ${IMAGE_ROOTFS}/install/install.manifest
204 done
205 fi
206 fi
207
208 if [ ! -z "${package_to_install}" ]; then
209 for pkg in ${package_to_install} ; do
210 echo "Processing $pkg..."
211 pkg_name=$(resolve_package_rpm $pkg ${confbase}.conf)
212 if [ -z "$pkg_name" ]; then
213 echo "Unable to find package $pkg!"
214 exit 1
215 fi
216 echo $pkg_name >> ${target_rootfs}/install/install.manifest
217 done
218 fi
219
220 # Generate an install solution by doing a --justdb install, then recreate it with
221 # an actual package install!
222 ${RPM} -D "_rpmds_sysinfo_path ${target_rootfs}/etc/rpm/sysinfo" \
223 -D "_dbpath ${target_rootfs}/install" -D "`cat ${confbase}.macro`" \
224 -D "__dbi_txn create nofsync" \
225 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
226 ${target_rootfs}/install/install.manifest
227
228 if [ ! -z "${package_attemptonly}" ]; then
229 echo "Adding attempt only packages..."
230 for pkg in ${package_attemptonly} ; do
231 echo "Processing $pkg..."
232 pkg_name=$(resolve_package_rpm $pkg ${confbase}.conf)
233 if [ -z "$pkg_name" ]; then
234 echo "Unable to find package $pkg!"
235 exit 1
236 fi
237 echo "Attempting $pkg_name..." >> "${WORKDIR}/temp/log.do_${task}_attemptonly.${PID}"
238 ${RPM} -D "_rpmds_sysinfo_path ${target_rootfs}/etc/rpm/sysinfo" \
239 -D "_dbpath ${target_rootfs}/install" -D "`cat ${confbase}.macro`" \
240 -D "__dbi_txn create nofsync private" \
241 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
242 $pkg_name >> "${WORKDIR}/temp/log.do_${task}_attemptonly.${PID}" || true
243 done
244 fi
245
246 #### Note: 'Recommends' is an arbitrary tag that means _SUGGESTS_ in Poky..
247 # Add any recommended packages to the image
248 # RPM does not solve for recommended packages because they are optional...
249 # So we query them and tree them like the ATTEMPTONLY packages above...
250 # Change the loop to "1" to run this code...
251 loop=0
252 if [ $loop -eq 1 ]; then
253 echo "Processing recommended packages..."
254 cat /dev/null > ${target_rootfs}/install/recommend.list
255 while [ $loop -eq 1 ]; do
256 # Dump the full set of recommends...
257 ${RPM} -D "_rpmds_sysinfo_path ${target_rootfs}/etc/rpm/sysinfo" \
258 -D "_dbpath ${IMAGE_ROOTFS}/install" -D "`cat ${confbase}.macro`" \
259 -D "__dbi_txn create nofsync private" \
260 -qa --qf "[%{RECOMMENDS}\n]" | sort -u > ${target_rootfs}/install/recommend
261 # Did we add more to the list?
262 grep -v -x -F -f ${target_rootfs}/install/recommend.list ${target_rootfs}/install/recommend > ${target_rootfs}/install/recommend.new || true
263 # We don't want to loop unless there is a change to the list!
264 loop=0
265 cat ${target_rootfs}/install/recommend.new | \
266 while read pkg ; do
267 # Ohh there was a new one, we'll need to loop again...
268 loop=1
269 echo "Processing $pkg..."
270 pkg_name=$(resolve_package $pkg ${confbase}.conf)
271 if [ -z "$pkg_name" ]; then
272 echo "Unable to find package $pkg." >> "${WORKDIR}/temp/log.do_${task}_recommend.${PID}"
273 continue
274 fi
275 echo "Attempting $pkg_name..." >> "${WORKDIR}/temp/log.do_{task}_recommend.${PID}"
276 ${RPM} -D "_rpmds_sysinfo_path ${target_rootfs}/etc/rpm/sysinfo" \
277 -D "_dbpath ${target_rootfs}/install" -D "`cat ${confbase}.macro`" \
278 -D "__dbi_txn create nofsync private" \
279 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
280 $pkg_name >> "${WORKDIR}/temp/log.do_${task}_recommend.${PID}" 2>&1 || true
281 done
282 cat ${target_rootfs}/install/recommend.list ${target_rootfs}/install/recommend.new | sort -u > ${target_rootfs}/install/recommend.new.list
283 mv -f ${target_rootfs}/install/recommend.new.list ${target_rootfs}/install/recommend.list
284 rm ${target_rootfs}/install/recommend ${target_rootfs}/install/recommend.new
285 done
286 fi
287
288 # Now that we have a solution, pull out a list of what to install...
289 echo "Manifest: ${target_rootfs}/install/install.manifest"
290 ${RPM} -D "_dbpath ${target_rootfs}/install" -qa --yaml \
291 -D "__dbi_txn create nofsync private" \
292 | grep -i 'Packageorigin' | cut -d : -f 2 > ${target_rootfs}/install/install_solution.manifest
293
294 # Attempt install
295 ${RPM} --root ${target_rootfs} \
296 -D "_rpmds_sysinfo_path ${target_rootfs}/etc/rpm/sysinfo" \
297 -D "_dbpath ${rpmlibdir}" \
298 --noscripts --notriggers --noparentdirs --nolinktos \
299 -D "__dbi_txn create nofsync private" \
300 -Uhv ${target_rootfs}/install/install_solution.manifest
301}
302
93python write_specfile () { 303python write_specfile () {
94 import textwrap 304 import textwrap
95 305
diff --git a/meta/classes/rootfs_rpm.bbclass b/meta/classes/rootfs_rpm.bbclass
index 26aaa1f8c3..d9a9c7d8a8 100644
--- a/meta/classes/rootfs_rpm.bbclass
+++ b/meta/classes/rootfs_rpm.bbclass
@@ -37,7 +37,7 @@ RPM="rpm ${RPMOPTS}"
37do_rootfs[lockfiles] += "${DEPLOY_DIR_RPM}/rpm.lock" 37do_rootfs[lockfiles] += "${DEPLOY_DIR_RPM}/rpm.lock"
38 38
39fakeroot rootfs_rpm_do_rootfs () { 39fakeroot rootfs_rpm_do_rootfs () {
40 set +x 40 #set +x
41 41
42 ${RPM_PREPROCESS_COMMANDS} 42 ${RPM_PREPROCESS_COMMANDS}
43 43
@@ -46,123 +46,18 @@ fakeroot rootfs_rpm_do_rootfs () {
46 # Setup base system configuration 46 # Setup base system configuration
47 mkdir -p ${IMAGE_ROOTFS}/etc/rpm/ 47 mkdir -p ${IMAGE_ROOTFS}/etc/rpm/
48 48
49 # Default arch is the top.. 49 #install pacakges
50 echo "${TARGET_ARCH}-unknown-linux" >${IMAGE_ROOTFS}/etc/rpm/platform 50 export INSTALL_ROOTFS_RPM="${IMAGE_ROOTFS}"
51 # Add the rest in sort order.. 51 export INSTALL_PLATFORM_RPM="${TARGET_ARCH}"
52 for each in ${PACKAGE_ARCHS} ; do 52 export INSTALL_PLATFORM_EXTRA_RPM="${PACKAGE_ARCHS}"
53 echo "$each""-unknown-linux" >>${IMAGE_ROOTFS}/etc/rpm/platform 53 export INSTALL_CONFBASE_RPM="${RPMCONF_TARGET_BASE}"
54 done 54 export INSTALL_PACKAGES_NORMAL_RPM="${PACKAGE_INSTALL}"
55 55 export INSTALL_PACKAGES_ATTEMPTONLY_RPM="${PACKAGE_INSTALL_ATTEMPTONLY}"
56 # Tell RPM that the "/" directory exist and is available 56 export INSTALL_PACKAGES_LINGUAS_RPM="${LINGUAS_INSTALL}"
57 mkdir -p ${IMAGE_ROOTFS}/etc/rpm/sysinfo 57 export INSTALL_PROVIDENAME_RPM=""
58 echo "/" >${IMAGE_ROOTFS}/etc/rpm/sysinfo/Dirnames 58 export INSTALL_TASK_RPM="populate_sdk"
59
60 # Setup manifest of packages to install...
61 mkdir -p ${IMAGE_ROOTFS}/install
62 echo "# Install manifest" > ${IMAGE_ROOTFS}/install/install.manifest
63
64 # Uclibc builds don't provide this stuff...
65 if [ x${TARGET_OS} = "xlinux" ] || [ x${TARGET_OS} = "xlinux-gnueabi" ] ; then
66 if [ ! -z "${LINGUAS_INSTALL}" ]; then
67 for pkg in ${LINGUAS_INSTALL}; do
68 echo "Processing $pkg..."
69 pkg_name=$(resolve_package $pkg)
70 if [ -z "$pkg_name" ]; then
71 echo "Unable to find package $pkg!"
72 exit 1
73 fi
74 echo $pkg_name >> ${IMAGE_ROOTFS}/install/install.manifest
75 done
76 fi
77 fi
78 59
79 if [ ! -z "${PACKAGE_INSTALL}" ]; then 60 package_install_internal_rpm
80 for pkg in ${PACKAGE_INSTALL} ; do
81 echo "Processing $pkg..."
82 pkg_name=$(resolve_package $pkg)
83 if [ -z "$pkg_name" ]; then
84 echo "Unable to find package $pkg!"
85 exit 1
86 fi
87 echo $pkg_name >> ${IMAGE_ROOTFS}/install/install.manifest
88 done
89 fi
90
91 # Generate an install solution by doing a --justdb install, then recreate it with
92 # an actual package install!
93 ${RPM} -D "_dbpath ${IMAGE_ROOTFS}/install" -D "`cat ${DEPLOY_DIR_RPM}/solvedb.macro`" \
94 -D "__dbi_txn create nofsync" \
95 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
96 ${IMAGE_ROOTFS}/install/install.manifest
97
98 if [ ! -z "${PACKAGE_INSTALL_ATTEMPTONLY}" ]; then
99 echo "Adding attempt only packages..."
100 for pkg in ${PACKAGE_INSTALL_ATTEMPTONLY} ; do
101 echo "Processing $pkg..."
102 pkg_name=$(resolve_package $pkg)
103 if [ -z "$pkg_name" ]; then
104 echo "Unable to find package $pkg!"
105 exit 1
106 fi
107 echo "Attempting $pkg_name..." >> "${WORKDIR}/temp/log.do_rootfs_attemptonly.${PID}"
108 ${RPM} -D "_dbpath ${IMAGE_ROOTFS}/install" -D "`cat ${DEPLOY_DIR_RPM}/solvedb.macro`" \
109 -D "__dbi_txn create nofsync private" \
110 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
111 $pkg_name >> "${WORKDIR}/temp/log.do_rootfs_attemptonly.${PID}" || true
112 done
113 fi
114
115#### Note: 'Recommends' is an arbitrary tag that means _SUGGESTS_ in Poky..
116 # Add any recommended packages to the image
117 # RPM does not solve for recommended packages because they are optional...
118 # So we query them and tree them like the ATTEMPTONLY packages above...
119 # Change the loop to "1" to run this code...
120 loop=0
121 if [ $loop -eq 1 ]; then
122 echo "Processing recommended packages..."
123 cat /dev/null > ${IMAGE_ROOTFS}/install/recommend.list
124 while [ $loop -eq 1 ]; do
125 # Dump the full set of recommends...
126 ${RPM} -D "_dbpath ${IMAGE_ROOTFS}/install" -D "`cat ${DEPLOY_DIR_RPM}/solvedb.macro`" \
127 -D "__dbi_txn create nofsync private" \
128 -qa --qf "[%{RECOMMENDS}\n]" | sort -u > ${IMAGE_ROOTFS}/install/recommend
129 # Did we add more to the list?
130 grep -v -x -F -f ${IMAGE_ROOTFS}/install/recommend.list ${IMAGE_ROOTFS}/install/recommend > ${IMAGE_ROOTFS}/install/recommend.new || true
131 # We don't want to loop unless there is a change to the list!
132 loop=0
133 cat ${IMAGE_ROOTFS}/install/recommend.new | \
134 while read pkg ; do
135 # Ohh there was a new one, we'll need to loop again...
136 loop=1
137 echo "Processing $pkg..."
138 pkg_name=$(resolve_package $pkg)
139 if [ -z "$pkg_name" ]; then
140 echo "Unable to find package $pkg." >> "${WORKDIR}/temp/log.do_rootfs_recommend.${PID}"
141 continue
142 fi
143 echo "Attempting $pkg_name..." >> "${WORKDIR}/temp/log.do_rootfs_recommend.${PID}"
144 ${RPM} -D "_dbpath ${IMAGE_ROOTFS}/install" -D "`cat ${DEPLOY_DIR_RPM}/solvedb.macro`" \
145 -D "__dbi_txn create nofsync private" \
146 -U --justdb --noscripts --notriggers --noparentdirs --nolinktos --ignoresize \
147 $pkg_name >> "${WORKDIR}/temp/log.do_rootfs_recommend.${PID}" 2>&1 || true
148 done
149 cat ${IMAGE_ROOTFS}/install/recommend.list ${IMAGE_ROOTFS}/install/recommend.new | sort -u > ${IMAGE_ROOTFS}/install/recommend.new.list
150 mv ${IMAGE_ROOTFS}/install/recommend.new.list ${IMAGE_ROOTFS}/install/recommend.list
151 rm ${IMAGE_ROOTFS}/install/recommend ${IMAGE_ROOTFS}/install/recommend.new
152 done
153 fi
154
155 # Now that we have a solution, pull out a list of what to install...
156 echo "Manifest: ${IMAGE_ROOTFS}/install/install.manifest"
157 ${RPM} -D "_dbpath ${IMAGE_ROOTFS}/install" -qa --yaml \
158 -D "__dbi_txn create nofsync private" \
159 | grep -i 'Packageorigin' | cut -d : -f 2 > ${IMAGE_ROOTFS}/install/install_solution.manifest
160
161 # Attempt install
162 ${RPM} --root ${IMAGE_ROOTFS} -D "_dbpath ${rpmlibdir}" \
163 --noscripts --notriggers --noparentdirs --nolinktos \
164 -D "__dbi_txn create nofsync private" \
165 -Uhv ${IMAGE_ROOTFS}/install/install_solution.manifest
166 61
167 export D=${IMAGE_ROOTFS} 62 export D=${IMAGE_ROOTFS}
168 export OFFLINE_ROOT=${IMAGE_ROOTFS} 63 export OFFLINE_ROOT=${IMAGE_ROOTFS}
@@ -227,7 +122,7 @@ EOF
227 122
228 # Workaround so the parser knows we need the resolve_package function! 123 # Workaround so the parser knows we need the resolve_package function!
229 if false ; then 124 if false ; then
230 resolve_package foo || true 125 resolve_package_rpm foo ${RPMCONF_TARGET_BASE}.conf || true
231 fi 126 fi
232} 127}
233 128
@@ -236,18 +131,6 @@ remove_packaging_data_files() {
236 rm -rf ${IMAGE_ROOTFS}${opkglibdir} 131 rm -rf ${IMAGE_ROOTFS}${opkglibdir}
237} 132}
238 133
239# Resolve package names to filepaths
240resolve_package() {
241 pkg="$1"
242 pkg_name=""
243 for solve in `cat ${DEPLOY_DIR_RPM}/solvedb.conf`; do
244 pkg_name=$(${RPM} -D "_dbpath $solve" -D "__dbi_txn create nofsync" -q --yaml $pkg | grep -i 'Packageorigin' | cut -d : -f 2)
245 if [ -n "$pkg_name" ]; then
246 break;
247 fi
248 done
249 echo $pkg_name
250}
251 134
252install_all_locales() { 135install_all_locales() {
253 PACKAGES_TO_INSTALL="" 136 PACKAGES_TO_INSTALL=""
@@ -263,7 +146,7 @@ install_all_locales() {
263 # but this should be good enough for the few users of this function... 146 # but this should be good enough for the few users of this function...
264 for pkg in $INSTALLED_PACKAGES; do 147 for pkg in $INSTALLED_PACKAGES; do
265 for lang in ${IMAGE_LOCALES}; do 148 for lang in ${IMAGE_LOCALES}; do
266 pkg_name=$(resolve_package $pkg-locale-$lang) 149 pkg_name=$(resolve_package_rpm $pkg-locale-$lang ${RPMCONF_TARGET_BASE}.conf)
267 if [ -n "$pkg_name" ]; then 150 if [ -n "$pkg_name" ]; then
268 ${RPM} --root ${IMAGE_ROOTFS} -D "_dbpath ${rpmlibdir}" \ 151 ${RPM} --root ${IMAGE_ROOTFS} -D "_dbpath ${rpmlibdir}" \
269 -D "__dbi_txn create nofsync private" \ 152 -D "__dbi_txn create nofsync private" \