From 01719d684979111e279ed71ea9f910dee6af2d22 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pertti=20Kellom=C3=A4ki?= Date: Mon, 16 May 2011 14:48:07 +0300 Subject: [PATCH] Fixes: NB#231286 - Launcher daemon doesn't link the libraries so that they could be prelinked RevBy: TrustMe --- debian/changelog | 1 + debian/control | 4 +- scripts/library-helper.py | 299 ++++++++++++++++++++------------------ 3 files changed, 158 insertions(+), 146 deletions(-) diff --git a/debian/changelog b/debian/changelog index 20ae703..0f4819f 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,5 +1,6 @@ applauncherd (0.29.8) unstable; urgency=low + * Fixes: NB#231286 - Launcher daemon doesn't link the libraries so that they could be prelinked * Changes: Highlighted applauncherd dependency with debian packages in documentation. -- Olli Leppanen Thu, 19 May 2011 15:42:28 +0300 diff --git a/debian/control b/debian/control index 5dfdf32..e215ae0 100644 --- a/debian/control +++ b/debian/control @@ -2,7 +2,7 @@ Source: applauncherd Section: admin Priority: important Maintainer: Jussi Lind -Build-Depends: cmake (>= 2.6.0), debhelper (>= 7), libqt4-dev (>= 4.5.0), libmeegotouch-dev, libcreds2-dev [arm armel], aegis-builder (>= 1.4) [arm armel], libxtst-dev, libxext-dev, libxi-dev, doxygen, python +Build-Depends: cmake (>= 2.6.0), debhelper (>= 7), libqt4-dev (>= 4.5.0), libmeegotouch-dev, libcreds2-dev [arm armel], aegis-builder (>= 1.4) [arm armel], libxtst-dev, libxext-dev, libxi-dev, doxygen, python, libsaveas, libmeegocontrol0, libduicontrolpanel, libxcomposite-dev, libresource0, libqt4-dev, liblocationextras, libmessagingif0, libsignon-qt0, libcontactswidgets-dev, sensord, libc6, libiphb0, libsignon-ui0, libdatepicker2, libxrandr-dev, liblocationpicker Standards-Version: 3.8.0 Package: applauncherd @@ -35,7 +35,7 @@ Description: Invoker debug package Package: applauncherd-launcher Architecture: any -Depends: ${shlibs:Depends}, ${misc:Depends}, libcreds2 [arm armel], applauncherd-single-instance +Depends: ${shlibs:Depends}, ${misc:Depends}, libcreds2 [arm armel], applauncherd-single-instance, libcontactswidgets0, libiphb0, libsignon-qt0, libxrandr2, libresource0, libsaveas, sensord, libxcomposite1, libqt4-declarative, libmeegocontrol0, libdatepicker2, libc6, libduicontrolpanel, libsignon-ui0, liblocationextras, libmessagingif0, liblocationpicker Description: Launcher part of applauncherd Launcher part of applauncherd. diff --git a/scripts/library-helper.py b/scripts/library-helper.py index a0e2110..466e87f 100755 --- a/scripts/library-helper.py +++ b/scripts/library-helper.py @@ -29,158 +29,158 @@ L = 1 # link libraries = [ # Library Linker flags, Binary package, Dev package - (D, "/usr/lib/libcontactsvoicemail.so.0", "-lcontactsvoicemail", "libcontactsvoicemail0", "libcontactswidgets-dev"), - (D, "/usr/lib/libmaemomeegotouchcalendarinterface.so.1", "-lmaemomeegotouchcalendarinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), - (D, "/usr/lib/libqtcontacts_extensions_tracker.so.4", "-lqtcontacts_extensions_tracker", "libqtcontacts-extensions-tracker0", "libqtcontacts-extensions-tracker-dev"), - (D, "/usr/lib/libcontactsutils.so.0", "-lcontactsutils", "libcontactswidgets0", "libcontactswidgets-dev"), - (D, "/usr/lib/libcontactswidgets.so.0", "-lcontactswidgets", "libcontactswidgets0", "libcontactswidgets-dev"), + #(L, "/usr/lib/libcontactsvoicemail.so.0", "-lcontactsvoicemail", "libcontactsvoicemail0", "libcontactswidgets-dev"), + #(L, "/usr/lib/libmaemomeegotouchcalendarinterface.so.1", "-lmaemomeegotouchcalendarinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), + #(L, "/usr/lib/libqtcontacts_extensions_tracker.so.4", "-lqtcontacts_extensions_tracker", "libqtcontacts-extensions-tracker0", "libqtcontacts-extensions-tracker-dev"), + #(L, "/usr/lib/libcontactsutils.so.0", "-lcontactsutils", "libcontactswidgets0", "libcontactswidgets-dev"), + (L, "/usr/lib/libcontactswidgets.so.0", "-lcontactswidgets", "libcontactswidgets0", "libcontactswidgets-dev"), (D, "/usr/lib/libpvr2d_r125.so", "-lpvr2d_r125", "opengles-sgx-img-common", "opengles-sgx-img-common-dev"), (D, "/usr/lib/libpvrPVR2D_DRI2WSEGL_r125.so", "-lpvrPVR2D_DRI2WSEGL_r125", "opengles-sgx-img-common", "opengles-sgx-img-common-dev"), - (D, "/usr/lib/libdatepicker2.so", "-ldatepicker2", "libdatepicker2", "libdatepicker2"), - (D, "/usr/lib/libvideo-widget-meegotouch.so.1", "-lvideo-widget-meegotouch", "libvideo-widget-meegotouch", "libvideo-widget-meegotouch-dev"), - (D, "/usr/lib/libvideo-renderer-gst-playbin2.so.1", "-lvideo-renderer-gst-playbin2", "libvideo-renderer-gst-playbin2", "libvideo-renderer-gst-playbin2-dev"), - (D, "/usr/lib/libAccountPlugin.so.1", "-lAccountPlugin", "libaccountplugin0", "libaccountplugin-dev"), - (D, "/usr/lib/libmaemomeegotouchcontactsinterface.so.1", "-lmaemomeegotouchcontactsinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), - (D, "/usr/lib/libgeoengine-mapwidget.so.1", "-lgeoengine-mapwidget", "geoengine-mapwidget", "geoengine-mapwidget-dev"), - (D, "/usr/lib/libmcontentwidgets.so.0", "-lmcontentwidgets", "libmcontentwidgets0", "libmcontentwidgets-dev"), - (D, "/usr/lib/libQtVersit.so.1", "-lQtVersit", "libqtm-versit", "libqtm-versit-dev"), - (D, "/usr/lib/libMOS.so.1", "-lMOS", "libmos", "libmos-dev"), - (D, "/usr/lib/libgallerycore.so.1", "-lgallerycore", "libgallerycore", "libgallerycore-dev"), - (D, "/usr/lib/liblocationpicker.so", "-llocationpicker", "liblocationpicker", "liblocationpicker"), - (D, "/usr/lib/libAccountSetup.so.1", "-lAccountSetup", "libaccountsetup0", "libaccountsetup-dev"), - (D, "/usr/lib/liblocationextras.so", "-llocationextras", "liblocationextras", "liblocationextras"), - (D, "/usr/lib/libNAccountsUI.so.1", "-lNAccountsUI", "libnaccounts-ui0", "libnaccounts-ui-dev"), - (D, "/usr/lib/libmdatauri.so.0", "-lmdatauri", "libmdatauri0", "libmdatauri-dev"), - (D, "/usr/lib/libgeoengine.so.1", "-lgeoengine", "geoengine", "geoengine-dev"), - (D, "/usr/lib/libSignOnUI.so", "-lSignOnUI", "libsignon-ui0", "libsignon-ui0"), - (D, "/usr/lib/libgq-gconf.so.0", "-lgq-gconf", "libgq-gconf0", "libgq-gconf-dev"), + (L, "/usr/lib/libdatepicker2.so", "-ldatepicker2", "libdatepicker2", "libdatepicker2"), + #(L, "/usr/lib/libvideo-widget-meegotouch.so.1", "-lvideo-widget-meegotouch", "libvideo-widget-meegotouch", "libvideo-widget-meegotouch-dev"), + #(L, "/usr/lib/libvideo-renderer-gst-playbin2.so.1", "-lvideo-renderer-gst-playbin2", "libvideo-renderer-gst-playbin2", "libvideo-renderer-gst-playbin2-dev"), + #(L, "/usr/lib/libAccountPlugin.so.1", "-lAccountPlugin", "libaccountplugin0", "libaccountplugin-dev"), + #(L, "/usr/lib/libmaemomeegotouchcontactsinterface.so.1", "-lmaemomeegotouchcontactsinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), + #(L, "/usr/lib/libgeoengine-mapwidget.so.1", "-lgeoengine-mapwidget", "geoengine-mapwidget", "geoengine-mapwidget-dev"), + #(L, "/usr/lib/libmcontentwidgets.so.0", "-lmcontentwidgets", "libmcontentwidgets0", "libmcontentwidgets-dev"), + #(L, "/usr/lib/libQtVersit.so.1", "-lQtVersit", "libqtm-versit", "libqtm-versit-dev"), + #(L, "/usr/lib/libMOS.so.1", "-lMOS", "libmos", "libmos-dev"), + #(L, "/usr/lib/libgallerycore.so.1", "-lgallerycore", "libgallerycore", "libgallerycore-dev"), + (L, "/usr/lib/liblocationpicker.so", "-llocationpicker", "liblocationpicker", "liblocationpicker"), + #(L, "/usr/lib/libAccountSetup.so.1", "-lAccountSetup", "libaccountsetup0", "libaccountsetup-dev"), + (L, "/usr/lib/liblocationextras.so", "-llocationextras", "liblocationextras", "liblocationextras"), + #(L, "/usr/lib/libNAccountsUI.so.1", "-lNAccountsUI", "libnaccounts-ui0", "libnaccounts-ui-dev"), + #(L, "/usr/lib/libmdatauri.so.0", "-lmdatauri", "libmdatauri0", "libmdatauri-dev"), + #(L, "/usr/lib/libgeoengine.so.1", "-lgeoengine", "geoengine", "geoengine-dev"), + (L, "/usr/lib/libSignOnUI.so", "-lSignOnUI", "libsignon-ui0", "libsignon-ui0"), + #(L, "/usr/lib/libgq-gconf.so.0", "-lgq-gconf", "libgq-gconf0", "libgq-gconf-dev"), (D, "/usr/lib/qt4/plugins/imageformats/libqsvg.so", "/usr/lib/qt4/plugins/imageformats/libqsvg.so", "libqt4-svg", "libqt4-svg"), - (D, "/usr/lib/libgstinterfaces-0.10.so.0", "-lgstinterfaces-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), - (D, "/usr/lib/libgstbase-0.10.so.0", "-lgstbase-0.10", "libgstreamer0.10-0", "libgstreamer0.10-dev"), + #(L, "/usr/lib/libgstinterfaces-0.10.so.0", "-lgstinterfaces-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), + #(L, "/usr/lib/libgstbase-0.10.so.0", "-lgstbase-0.10", "libgstreamer0.10-0", "libgstreamer0.10-dev"), (D, "/usr/lib/qt4/plugins/imageformats/libqico.so", "/usr/lib/qt4/plugins/imageformats/libqico.so", "libqtgui4", "libqtgui4"), - (D, "/usr/lib/libquill.so.1", "-lquill", "libquill1", "libquill-dev"), - (D, "/usr/lib/libidn.so.11", "-lidn", "libidn11", "libidn11-dev"), - (D, "/usr/lib/libmeegocontrol.so", "-lmeegocontrol", "libmeegocontrol0", "libmeegocontrol0"), - (D, "/usr/lib/libcares.so.2", "-lcares", "libc-ares2", "libc-ares-dev"), + #(L, "/usr/lib/libquill.so.1", "-lquill", "libquill1", "libquill-dev"), + #(L, "/usr/lib/libidn.so.11", "-lidn", "libidn11", "libidn11-dev"), + (L, "/usr/lib/libmeegocontrol.so", "-lmeegocontrol", "libmeegocontrol0", "libmeegocontrol0"), + #(L, "/usr/lib/libcares.so.2", "-lcares", "libc-ares2", "libc-ares-dev"), (D, "/usr/lib/qt4/plugins/imageformats/libqtiff.so", "/usr/lib/qt4/plugins/imageformats/libqtiff.so", "libqtgui4", "libqtgui4-dev"), - (D, "/usr/lib/libgstpbutils-0.10.so.0", "-lgstpbutils-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), + #(L, "/usr/lib/libgstpbutils-0.10.so.0", "-lgstpbutils-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), (D, "/usr/lib/libambase.so", "-lambase", "libamjpeg1", "libamjpeg1"), - (D, "/usr/lib/libcellular-qt.so.1", "-lcellular-qt", "libcellular-qt1", "libcellular-qt-dev"), - (D, "/usr/lib/libmoi.so.0", "-lmoi", "libmoi0", "libmoi-dev"), - (D, "/usr/lib/libcurl.so.4", "-lcurl", "libcurl3", "libcurl4-openssl-dev"), - (D, "/usr/lib/libcommhistory.so.0", "-lcommhistory", "libcommhistory0", "libcommhistory-dev"), - (D, "/usr/lib/libmessagingif0.so", "-lmessagingif0", "libmessagingif0", "libmessagingif0"), - (D, "/usr/lib/libgstvideo-0.10.so.0", "-lgstvideo-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), + #(L, "/usr/lib/libcellular-qt.so.1", "-lcellular-qt", "libcellular-qt1", "libcellular-qt-dev"), + #(L, "/usr/lib/libmoi.so.0", "-lmoi", "libmoi0", "libmoi-dev"), + #(L, "/usr/lib/libcurl.so.4", "-lcurl", "libcurl3", "libcurl4-openssl-dev"), + #(L, "/usr/lib/libcommhistory.so.0", "-lcommhistory", "libcommhistory0", "libcommhistory-dev"), + (L, "/usr/lib/libmessagingif0.so", "-lmessagingif0", "libmessagingif0", "libmessagingif0"), + #(L, "/usr/lib/libgstvideo-0.10.so.0", "-lgstvideo-0.10", "libgstreamer-plugins-base0.10-0", "libgstreamer-plugins-base0.10-dev"), (D, "/usr/lib/qt4/plugins/imageformats/libqgif.so", "/usr/lib/qt4/plugins/imageformats/libqgif.so", "libqtgui4", "libqtgui4"), - (D, "/usr/lib/libtiff.so.4", "-ltiff", "libtiff4", "libtiff4-dev"), - (D, "/usr/lib/libresource.so", "-lresource", "libresource0", "libresource0"), - (D, "/usr/lib/libgstreamer-0.10.so.0", "-lgstreamer-0.10", "libgstreamer0.10-0", "libgstreamer0.10-dev"), - (D, "/usr/lib/libQtLocation.so.1", "-lQtLocation", "libqtm-location", "libqtm-location-dev"), - (D, "/usr/lib/libexempi.so.3", "-lexempi", "libexempi3", "libexempi-dev"), - (D, "/usr/lib/libquillimagefilter.so.1", "-lquillimagefilter", "libquillimagefilter1", "libquillimagefilter-dev"), - (D, "/usr/lib/libexif.so.12", "-lexif", "libexif12", "libexif-dev"), - (D, "/usr/lib/libresourceqt.so.1", "-lresourceqt", "libresourceqt1", "libresourceqt-dev"), - (D, "/usr/lib/libquillmetadata.so.1", "-lquillmetadata", "libquillmetadata1", "libquillmetadata-dev"), - (D, "/usr/lib/libprofile.so.0", "-lprofile", "libprofile0", "libprofile-dev"), - (D, "/usr/lib/libsaveas.so", "-lsaveas", "libsaveas", "libsaveas"), - (D, "/usr/lib/libsignoncrypto-qt.so.1", "-lsignoncrypto-qt", "libsignoncrypto-qt", "libsignoncrypto-qt-dev"), - (D, "/usr/lib/libsignon-qt.so", "-lsignon-qt", "libsignon-qt0", "libsignon-qt0"), - (D, "/usr/lib/libmaemomeegotouchshareuiinterface.so.1", "-lmaemomeegotouchshareuiinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), - (D, "/usr/lib/libQtContacts.so.1", "-lQtContacts", "libqtm-contacts", "libqtm-contacts-dev"), - (D, "/usr/lib/libduicontrolpanel.so", "-lduicontrolpanel", "libduicontrolpanel", "libduicontrolpanel"), - (D, "/usr/lib/libaccounts-qt.so.1", "-laccounts-qt", "libaccounts-qt1", "libaccounts-qt-dev"), - (D, "/usr/lib/libdbus-qeventloop.so.1", "-ldbus-qeventloop", "libdbus-qeventloop1", "libdbus-qeventloop-dev"), - (D, "/usr/lib/libaccounts-glib.so.0", "-laccounts-glib", "libaccounts-glib0", "libaccounts-glib-dev"), - (D, "/usr/lib/libsmartsearch.so", "-lsmartsearch", "libsmartsearch0", "libsmartsearch0"), - (D, "/usr/lib/libhal.so.1", "-lhal", "libhal1", "libhal-dev"), - (D, "/usr/lib/libcontentmanager.so.0", "-lcontentmanager", "libcontentmanager0", "libcontentmanager-dev"), - (D, "/usr/lib/librelevance.so.0", "-lrelevance", "librelevance0", "librelevance-dev"), - (D, "/usr/lib/libdsme.so.0.2.0", "-ldsme", "libdsme0.2.0", "libdsme0.2.0-dev"), - (D, "/usr/lib/libtimed.so.0", "-ltimed", "libtimed0", "libtimed-dev"), - (D, "/usr/lib/libqmsystem2.so.1", "-lqmsystem2", "libqmsystem2", "libqmsystem2-dev"), - (D, "/lib/libnss_files-2.10.1.so", "-lnss_files-2.10.1", "libc6", "libc6"), - (D, "/usr/lib/libsensordatatypes.so", "-lsensordatatypes", "sensord", "sensord"), - (D, "/usr/lib/libsensorclient.so", "-lsensorclient", "sensord", "sensord"), - (D, "/usr/lib/libdsme_dbus_if.so.0.2.0", "-ldsme_dbus_if", "libdsme0.2.0", "libdsme0.2.0-dev"), - (D, "/usr/lib/libqmlog.so.0", "-lqmlog", "libqmlog0", "libqmlog-dev"), - (D, "/lib/libuuid.so.1", "-luuid", "libuuid1", "uuid-dev"), - (D, "/usr/lib/libiphb.so", "-liphb", "libiphb0", "libiphb0"), - (D, "/usr/lib/libthumbnailer.so.0", "-lthumbnailer", "libthumbnailer0", "libthumbnailer-dev"), - (D, "/usr/lib/libsysinfo.so.0", "-lsysinfo", "libsysinfo0", "libsysinfo-dev"), - (D, "/usr/lib/libbmeipc.so.0", "-lbmeipc", "libbmeipc0", "libbmeipc-dev"), - (D, "/usr/lib/libjpeg.so.62", "-ljpeg", "libjpeg62", "libjpeg62-dev"), - (D, "/usr/lib/libQtXmlPatterns.so.4", "-lQtXmlPatterns", "libqt4-xmlpatterns", "libqt4-dev"), - (D, "/usr/lib/libQtScript.so.4", "-lQtScript", "libqt4-script", "libqt4-dev"), - (D, "/usr/lib/libssl.so.0.9.8", "-lssl", "libssl0.9.8", "libssl-dev"), - (D, "/usr/lib/libaegis_crypto.so.1", "-laegis_crypto", "libaegis-crypto1", "libaegis-crypto-dev"), - (D, "/usr/lib/libQtDeclarative.so.4", "-lQtDeclarative", "libqt4-declarative", "libqt4-dev"), - (D, "/usr/lib/libxml2.so.2", "-lxml2", "libxml2", "libxml2-dev"), - (D, "/lib/libcal.so.1", "-lcal", "libcal1", "libcal-dev"), - (D, "/usr/lib/libcontentaction.so.0", "-lcontentaction", "libcontentaction0", "libcontentaction-dev"), - (D, "/usr/lib/libcrypto.so.0.9.8", "-lcrypto", "libssl0.9.8", "libssl-dev"), - (D, "/usr/lib/libbb5.so.0", "-lbb5", "libbb5-0", "libbb5-dev"), - (D, "/lib/libresolv-2.10.1.so", "-lresolv-2.10.1", "libc6", "libc6"), - (D, "/usr/lib/libgio-2.0.so.0", "-lgio-2.0", "libglib2.0-0", "libglib2.0-dev"), - (D, "/usr/lib/libQtSparql.so.0", "-lQtSparql", "libqtsparql0", "libqtsparql-dev"), - (D, "/usr/lib/libsqlite3.so.0", "-lsqlite3", "libsqlite3-0", "libsqlite3-dev"), - (D, "/usr/lib/libQtSql.so.4", "-lQtSql", "libqt4-sql", "libqt4-dev"), - (D, "/usr/lib/libmeegotouchsettings.so.0", "-lmeegotouchsettings", "libmeegotouchsettings0", "libmeegotouch-dev"), - (D, "/usr/lib/libmeegotouchextensions.so.0", "-lmeegotouchextensions", "libmeegotouchextensions0", "libmeegotouch-dev"), + #(L, "/usr/lib/libtiff.so.4", "-ltiff", "libtiff4", "libtiff4-dev"), + (L, "/usr/lib/libresource.so", "-lresource", "libresource0", "libresource0"), + #(L, "/usr/lib/libgstreamer-0.10.so.0", "-lgstreamer-0.10", "libgstreamer0.10-0", "libgstreamer0.10-dev"), + #(L, "/usr/lib/libQtLocation.so.1", "-lQtLocation", "libqtm-location", "libqtm-location-dev"), + #(L, "/usr/lib/libexempi.so.3", "-lexempi", "libexempi3", "libexempi-dev"), + #(L, "/usr/lib/libquillimagefilter.so.1", "-lquillimagefilter", "libquillimagefilter1", "libquillimagefilter-dev"), + #(L, "/usr/lib/libexif.so.12", "-lexif", "libexif12", "libexif-dev"), + #(L, "/usr/lib/libresourceqt.so.1", "-lresourceqt", "libresourceqt1", "libresourceqt-dev"), + #(L, "/usr/lib/libquillmetadata.so.1", "-lquillmetadata", "libquillmetadata1", "libquillmetadata-dev"), + #(L, "/usr/lib/libprofile.so.0", "-lprofile", "libprofile0", "libprofile-dev"), + (L, "/usr/lib/libsaveas.so", "-lsaveas", "libsaveas", "libsaveas"), + #(L, "/usr/lib/libsignoncrypto-qt.so.1", "-lsignoncrypto-qt", "libsignoncrypto-qt", "libsignoncrypto-qt-dev"), + (L, "/usr/lib/libsignon-qt.so", "-lsignon-qt", "libsignon-qt0", "libsignon-qt0"), + #(L, "/usr/lib/libmaemomeegotouchshareuiinterface.so.1", "-lmaemomeegotouchshareuiinterface", "maemo-meegotouch-interfaces", "maemo-meegotouch-interfaces-dev"), + #(L, "/usr/lib/libQtContacts.so.1", "-lQtContacts", "libqtm-contacts", "libqtm-contacts-dev"), + (L, "/usr/lib/libduicontrolpanel.so", "-lduicontrolpanel", "libduicontrolpanel", "libduicontrolpanel"), + #(L, "/usr/lib/libaccounts-qt.so.1", "-laccounts-qt", "libaccounts-qt1", "libaccounts-qt-dev"), + #(L, "/usr/lib/libdbus-qeventloop.so.1", "-ldbus-qeventloop", "libdbus-qeventloop1", "libdbus-qeventloop-dev"), + #(L, "/usr/lib/libaccounts-glib.so.0", "-laccounts-glib", "libaccounts-glib0", "libaccounts-glib-dev"), + #(L, "/usr/lib/libsmartsearch.so", "-lsmartsearch", "libsmartsearch0", "libsmartsearch0"), + #(L, "/usr/lib/libhal.so.1", "-lhal", "libhal1", "libhal-dev"), + #(L, "/usr/lib/libcontentmanager.so.0", "-lcontentmanager", "libcontentmanager0", "libcontentmanager-dev"), + #(L, "/usr/lib/librelevance.so.0", "-lrelevance", "librelevance0", "librelevance-dev"), + #(L, "/usr/lib/libdsme.so.0.2.0", "-ldsme", "libdsme0.2.0", "libdsme0.2.0-dev"), + #(L, "/usr/lib/libtimed.so.0", "-ltimed", "libtimed0", "libtimed-dev"), + #(L, "/usr/lib/libqmsystem2.so.1", "-lqmsystem2", "libqmsystem2", "libqmsystem2-dev"), + (L, "/lib/libnss_files-2.10.1.so", "-lnss_files-2.10.1", "libc6", "libc6"), + (L, "/usr/lib/libsensordatatypes.so", "-lsensordatatypes", "sensord", "sensord"), + (L, "/usr/lib/libsensorclient.so", "-lsensorclient", "sensord", "sensord"), + #(L, "/usr/lib/libdsme_dbus_if.so.0.2.0", "-ldsme_dbus_if", "libdsme0.2.0", "libdsme0.2.0-dev"), + #(L, "/usr/lib/libqmlog.so.0", "-lqmlog", "libqmlog0", "libqmlog-dev"), + #(L, "/lib/libuuid.so.1", "-luuid", "libuuid1", "uuid-dev"), + (L, "/usr/lib/libiphb.so", "-liphb", "libiphb0", "libiphb0"), + #(L, "/usr/lib/libthumbnailer.so.0", "-lthumbnailer", "libthumbnailer0", "libthumbnailer-dev"), + #(L, "/usr/lib/libsysinfo.so.0", "-lsysinfo", "libsysinfo0", "libsysinfo-dev"), + #(L, "/usr/lib/libbmeipc.so.0", "-lbmeipc", "libbmeipc0", "libbmeipc-dev"), + #(L, "/usr/lib/libjpeg.so.62", "-ljpeg", "libjpeg62", "libjpeg62-dev"), + #(L, "/usr/lib/libQtXmlPatterns.so.4", "-lQtXmlPatterns", "libqt4-xmlpatterns", "libqt4-dev"), + #(L, "/usr/lib/libQtScript.so.4", "-lQtScript", "libqt4-script", "libqt4-dev"), + #(L, "/usr/lib/libssl.so.0.9.8", "-lssl", "libssl0.9.8", "libssl-dev"), + #(L, "/usr/lib/libaegis_crypto.so.1", "-laegis_crypto", "libaegis-crypto1", "libaegis-crypto-dev"), + (L, "/usr/lib/libQtDeclarative.so.4", "-lQtDeclarative", "libqt4-declarative", "libqt4-dev"), + #(L, "/usr/lib/libxml2.so.2", "-lxml2", "libxml2", "libxml2-dev"), + #(L, "/lib/libcal.so.1", "-lcal", "libcal1", "libcal-dev"), + #(L, "/usr/lib/libcontentaction.so.0", "-lcontentaction", "libcontentaction0", "libcontentaction-dev"), + #(L, "/usr/lib/libcrypto.so.0.9.8", "-lcrypto", "libssl0.9.8", "libssl-dev"), + #(L, "/usr/lib/libbb5.so.0", "-lbb5", "libbb5-0", "libbb5-dev"), + (L, "/lib/libresolv-2.10.1.so", "-lresolv-2.10.1", "libc6", "libc6"), + #(L, "/usr/lib/libgio-2.0.so.0", "-lgio-2.0", "libglib2.0-0", "libglib2.0-dev"), + #(L, "/usr/lib/libQtSparql.so.0", "-lQtSparql", "libqtsparql0", "libqtsparql-dev"), + #(L, "/usr/lib/libsqlite3.so.0", "-lsqlite3", "libsqlite3-0", "libsqlite3-dev"), + #(L, "/usr/lib/libQtSql.so.4", "-lQtSql", "libqt4-sql", "libqt4-dev"), + #(L, "/usr/lib/libmeegotouchsettings.so.0", "-lmeegotouchsettings", "libmeegotouchsettings0", "libmeegotouch-dev"), + #(L, "/usr/lib/libmeegotouchextensions.so.0", "-lmeegotouchextensions", "libmeegotouchextensions0", "libmeegotouch-dev"), (D, "/usr/lib/qt4/plugins/inputmethods/libminputcontext.so", "-lminputcontext", "meego-im-context", "meego-im-context"), (D, "/usr/lib/qt4/plugins/inputmethods/libqimsw-multi.so", "-lqimsw-multi", "libqtgui4", "libqtgui4"), - (D, "/lib/libudev.so.0", "-ludev", "libudev0", "libudev-dev"), - (D, "/usr/lib/libmeegotouchviews.so.0", "-lmeegotouchviews", "libmeegotouchviews0", "libmeegotouch-dev"), + #(L, "/lib/libudev.so.0", "-ludev", "libudev0", "libudev-dev"), + #(L, "/usr/lib/libmeegotouchviews.so.0", "-lmeegotouchviews", "libmeegotouchviews0", "libmeegotouch-dev"), (D, "/usr/lib/qt4/plugins/graphicssystems/libqmeegographicssystem.so", "/usr/lib/qt4/plugins/graphicssystems/libqmeegographicssystem.so", "libqt4-meegographicssystem", "libqt4-meegographicssystem"), - (D, "/usr/lib/libXrandr.so.2", "-lXrandr", "libxrandr2", "libxrandr-dev"), + (L, "/usr/lib/libXrandr.so.2", "-lXrandr", "libxrandr2", "libxrandr-dev"), (D, "/usr/lib/contextkit/subscriber-plugins/kbslider-1.so", "/usr/lib/contextkit/subscriber-plugins/kbslider-1.so", "context-keyboard", "context-keyboard"), - (D, "/usr/lib/libXcomposite.so.1", "-lXcomposite", "libxcomposite1", "libxcomposite-dev"), + (L, "/usr/lib/libXcomposite.so.1", "-lXcomposite", "libxcomposite1", "libxcomposite-dev"), (D, "/usr/lib/libGLESv2_r125.so", "-lGLESv2_r125", "libgles2-sgx-img", "libgles2-sgx-img"), - (D, "/usr/lib/libgconf-2.so.4", "-lgconf-2", "libgconf2-6", "libgconf2-dev"), - (D, "/usr/lib/libQtCore.so.4", "-lQtCore", "libqtcore4", "libqt4-dev"), - (D, "/usr/lib/libdbus-glib-1.so.2", "-ldbus-glib-1", "libdbus-glib-1-2", "libdbus-glib-1-dev"), - (D, "/usr/lib/libstdc++.so.6", "-lstdc++", "libstdc++6", "libstdc++6-4.4-dev"), - (D, "/usr/lib/libXi.so.6", "-lXi", "libxi6", "libxi-dev"), - (D, "/lib/libpcre.so.3", "-lpcre", "libpcre3", "libpcre3-dev"), - (D, "/usr/lib/libQtSvg.so.4", "-lQtSvg", "libqt4-svg", "libqt4-dev"), - (D, "/usr/lib/libicui18n.so.44", "-licui18n", "libicu44", "libicu-dev"), + #(L, "/usr/lib/libgconf-2.so.4", "-lgconf-2", "libgconf2-6", "libgconf2-dev"), + #(L, "/usr/lib/libQtCore.so.4", "-lQtCore", "libqtcore4", "libqt4-dev"), + #(L, "/usr/lib/libdbus-glib-1.so.2", "-ldbus-glib-1", "libdbus-glib-1-2", "libdbus-glib-1-dev"), + #(L, "/usr/lib/libstdc++.so.6", "-lstdc++", "libstdc++6", "libstdc++6-4.4-dev"), + #(L, "/usr/lib/libXi.so.6", "-lXi", "libxi6", "libxi-dev"), + #(L, "/lib/libpcre.so.3", "-lpcre", "libpcre3", "libpcre3-dev"), + #(L, "/usr/lib/libQtSvg.so.4", "-lQtSvg", "libqt4-svg", "libqt4-dev"), + #(L, "/usr/lib/libicui18n.so.44", "-licui18n", "libicu44", "libicu-dev"), (D, "/usr/lib/libIMGegl_r125.so", "-lIMGegl_r125", "opengles-sgx-img-common", "opengles-sgx-img-common"), - (D, "/usr/lib/libdbus-1.so.3", "-ldbus-1", "libdbus-1-3", "libdbus-1-dev"), - (D, "/usr/lib/libmeegotouchcore.so.0", "-lmeegotouchcore", "libmeegotouchcore0", "libmeegotouch-dev"), - (D, "/usr/lib/libX11.so.6", "-lX11", "libx11-6", "libx11-dev"), - (D, "/usr/lib/libexpat.so.1", "-lexpat", "libexpat1", "libexpat1-dev"), - (D, "/usr/lib/libfontconfig.so.1", "-lfontconfig", "libfontconfig1", "libfontconfig1-dev"), - (D, "/usr/lib/libSM.so.6", "-lSM", "libsm6", "libsm-dev"), - (D, "/usr/lib/libICE.so.6", "-lICE", "libice6", "libice-dev"), + #(L, "/usr/lib/libdbus-1.so.3", "-ldbus-1", "libdbus-1-3", "libdbus-1-dev"), + #(L, "/usr/lib/libmeegotouchcore.so.0", "-lmeegotouchcore", "libmeegotouchcore0", "libmeegotouch-dev"), + #(L, "/usr/lib/libX11.so.6", "-lX11", "libx11-6", "libx11-dev"), + #(L, "/usr/lib/libexpat.so.1", "-lexpat", "libexpat1", "libexpat1-dev"), + #(L, "/usr/lib/libfontconfig.so.1", "-lfontconfig", "libfontconfig1", "libfontconfig1-dev"), + #(L, "/usr/lib/libSM.so.6", "-lSM", "libsm6", "libsm-dev"), + #(L, "/usr/lib/libICE.so.6", "-lICE", "libice6", "libice-dev"), (D, "/usr/lib/libEGL_r125.so", "-lEGL_r125", "opengles-sgx-img-common", "opengles-sgx-img-common"), - (D, "/usr/lib/libXdamage.so.1", "-lXdamage", "libxdamage1", "libxdamage-dev"), - (D, "/usr/lib/libcontextsubscriber.so.0", "-lcontextsubscriber", "libcontextsubscriber0", "libcontextsubscriber-dev"), - (D, "/lib/libdl-2.10.1.so", "-ldl-2.10.1", "libc6", "libc6"), - (D, "/usr/lib/libXext.so.6", "-lXext", "libxext6", "libxext-dev"), - (D, "/lib/libpthread-2.10.1.so", "-lpthread-2.10.1", "libc6", "libc6"), - (D, "/usr/lib/libXau.so.6", "-lXau", "libxau6", "libxau-dev"), - (D, "/usr/lib/libgobject-2.0.so.0", "-lgobject-2.0", "libglib2.0-0", "libglib2.0-dev"), - (D, "/usr/lib/libcdb.so.1", "-lcdb", "libcdb1", "libcdb-dev"), - (D, "/usr/lib/libQtNetwork.so.4", "-lQtNetwork", "libqt4-network", "libqt4-dev"), + #(L, "/usr/lib/libXdamage.so.1", "-lXdamage", "libxdamage1", "libxdamage-dev"), + #(L, "/usr/lib/libcontextsubscriber.so.0", "-lcontextsubscriber", "libcontextsubscriber0", "libcontextsubscriber-dev"), + (L, "/lib/libdl-2.10.1.so", "-ldl-2.10.1", "libc6", "libc6"), + #(L, "/usr/lib/libXext.so.6", "-lXext", "libxext6", "libxext-dev"), + (L, "/lib/libpthread-2.10.1.so", "-lpthread-2.10.1", "libc6", "libc6"), + #(L, "/usr/lib/libXau.so.6", "-lXau", "libxau6", "libxau-dev"), + #(L, "/usr/lib/libgobject-2.0.so.0", "-lgobject-2.0", "libglib2.0-0", "libglib2.0-dev"), + #(L, "/usr/lib/libcdb.so.1", "-lcdb", "libcdb1", "libcdb-dev"), + #(L, "/usr/lib/libQtNetwork.so.4", "-lQtNetwork", "libqt4-network", "libqt4-dev"), (D, "/usr/lib/gconv/UTF-16.so", "/usr/lib/gconv/UTF-16.so", "libc6", "libc6"), - (D, "/usr/lib/libicudata.so.44", "-licudata", "libicu44", "libicu-dev"), - (D, "/usr/lib/libQtMeeGoGraphicsSystemHelper.so.4", "-lQtMeeGoGraphicsSystemHelper", "libqt4-meegographicssystemhelper", "libqt4-meegographicssystemhelper-dev"), - (D, "/usr/lib/libQtGui.so.4", "-lQtGui", "libqtgui4", "libqt4-dev"), - (D, "/usr/lib/libQtOpenGL.so.4", "-lQtOpenGL", "libqt4-opengl", "libqt4-dev"), - (D, "/usr/lib/libQtXml.so.4", "-lQtXml", "libqt4-xml", "libqt4-dev"), - (D, "/usr/lib/libQtDBus.so.4", "-lQtDBus", "libqt4-dbus", "libqt4-dev"), - (D, "/usr/lib/libXfixes.so.3", "-lXfixes", "libxfixes3", "libxfixes-dev"), - (D, "/usr/lib/libz.so.1", "-lz", "zlib1g", "zlib1g-dev"), - (D, "/usr/lib/libxcb.so.1", "-lxcb", "libxcb1", "libxcb1-dev"), - (D, "/lib/libm-2.10.1.so", "-lm-2.10.1", "libc6", "libc6"), - (D, "/usr/lib/libgmodule-2.0.so.0", "-lgmodule-2.0", "libglib2.0-0", "libglib2.0-dev"), + #(L, "/usr/lib/libicudata.so.44", "-licudata", "libicu44", "libicu-dev"), + #(L, "/usr/lib/libQtMeeGoGraphicsSystemHelper.so.4", "-lQtMeeGoGraphicsSystemHelper", "libqt4-meegographicssystemhelper", "libqt4-meegographicssystemhelper-dev"), + #(L, "/usr/lib/libQtGui.so.4", "-lQtGui", "libqtgui4", "libqt4-dev"), + #(L, "/usr/lib/libQtOpenGL.so.4", "-lQtOpenGL", "libqt4-opengl", "libqt4-dev"), + #(L, "/usr/lib/libQtXml.so.4", "-lQtXml", "libqt4-xml", "libqt4-dev"), + #(L, "/usr/lib/libQtDBus.so.4", "-lQtDBus", "libqt4-dbus", "libqt4-dev"), + #(L, "/usr/lib/libXfixes.so.3", "-lXfixes", "libxfixes3", "libxfixes-dev"), + #(L, "/usr/lib/libz.so.1", "-lz", "zlib1g", "zlib1g-dev"), + #(L, "/usr/lib/libxcb.so.1", "-lxcb", "libxcb1", "libxcb1-dev"), + (L, "/lib/libm-2.10.1.so", "-lm-2.10.1", "libc6", "libc6"), + #(L, "/usr/lib/libgmodule-2.0.so.0", "-lgmodule-2.0", "libglib2.0-0", "libglib2.0-dev"), (D, "/usr/lib/libsrv_um_r125.so", "-lsrv_um_r125", "opengles-sgx-img-common", "opengles-sgx-img-common"), - (D, "/usr/lib/libpng12.so.0", "-lpng12", "libpng12-0", "libpng12-dev"), - (D, "/usr/lib/libfreetype.so.6", "-lfreetype", "libfreetype6", "libfreetype6-dev"), - (D, "/usr/lib/libgthread-2.0.so.0", "-lgthread-2.0", "libglib2.0-0", "libglib2.0-dev"), - (D, "/lib/libglib-2.0.so.0", "-lglib-2.0", "libglib2.0-0", "libglib2.0-dev"), - (D, "/usr/lib/libXrender.so.1", "-lXrender", "libxrender1", "libxrender-dev"), - (D, "/usr/lib/libicuuc.so.44", "-licuuc", "libicu44", "libicu-dev"), - (D, "/lib/librt-2.10.1.so", "-lrt-2.10.1", "libc6", "libc6"), + #(L, "/usr/lib/libpng12.so.0", "-lpng12", "libpng12-0", "libpng12-dev"), + #(L, "/usr/lib/libfreetype.so.6", "-lfreetype", "libfreetype6", "libfreetype6-dev"), + #(L, "/usr/lib/libgthread-2.0.so.0", "-lgthread-2.0", "libglib2.0-0", "libglib2.0-dev"), + #(L, "/lib/libglib-2.0.so.0", "-lglib-2.0", "libglib2.0-0", "libglib2.0-dev"), + #(L, "/usr/lib/libXrender.so.1", "-lXrender", "libxrender1", "libxrender-dev"), + #(L, "/usr/lib/libicuuc.so.44", "-licuuc", "libicu44", "libicu-dev"), + (L, "/lib/librt-2.10.1.so", "-lrt-2.10.1", "libc6", "libc6"), ] import sys @@ -190,8 +190,10 @@ import string import subprocess from collections import defaultdict +pulled_in_by = defaultdict(list) + def find_roots(initial_libs): - pulled_in_by = defaultdict(list) + global pulled_in_by dep_reg = re.compile(r"^.*=>\s*(\S*)\s.*$") for lib in initial_libs: if pulled_in_by[lib] == []: @@ -257,24 +259,32 @@ if __name__ == "__main__": bin_package[lib] = bp dev_package[lib] = dp - # roots of the library dependency tree - roots = find_roots(initial_libs) - if len(sys.argv) == 2 and sys.argv[1] == "--preload-h-libraries": f = open("preload-h-libraries.h", "w") f.write("// List of libraries produced by library-helper.py. DO NOT EDIT\n") - for lib in roots: + for lib in initial_libs: if status[lib] == D: f.write('"%s",\n' % lib) f.close() elif len(sys.argv) == 2 and sys.argv[1] == "--linker-flags": # produce minimized linker line f = open("additional-linked-libraries.ld", "w") - for lib in roots: + for lib in initial_libs: if status[lib] == L: f.write('%s ' % linker_flags[lib]) f.close() - elif len(sys.argv) == 3 and sys.argv[1] == "--check-dependencies": + elif len(sys.argv) == 3 and sys.argv[1] == "--sanity-check": + # roots of the library dependency tree + roots = find_roots(initial_libs) + + for lib in initial_libs: + if status[lib] == D and lib not in roots: + print "Redundant library in dlopen list: %s" % lib + print " already pulled in as dependency of %s" % string.join(pulled_in_by[lib], ", ") + elif status[lib] == L and lib not in roots: + print "Redundant library in linked libraries: %s" % lib + print " already pulled in as dependency of %s" % string.join(pulled_in_by[lib], ", ") + all_dev_packages = set() runtime_packages = set() linker_lib_packages = set() @@ -307,9 +317,10 @@ if __name__ == "__main__": Produce a list of libraries in preload-h-libraries.h --linker-flags Produdce a linker line fragment in additional-linked-libraries.ld - --check-dependencies control-file + --sanity-check control-file Given the debian control file, check if there are missing packages or redundant packages in Build-Depends or applauncherd-launcher Depends. + Also check the linked libraries and dlopened libraries for redundancies. """ sys.exit(1)