On 24-10-09 00:31, Stanislav Brabec wrote:
Holger Hans Peter Freyther wrote:
On Friday 23 October 2009 13:07:06 Stanislav Brabec wrote:

I think that the logic should be:

libfoo.a exists and libfoo.so exists =>  put .a to -static.

libfoo.a exists and libfoo.so does not exist =>  put .a to -dev.

This logic will work as most users expect and will need no exception for
glibc.

This will add even more python code to package.bbclass and can not be realized
with a FILES_* change. I would prefer a stupid QA check for that as I don't
expect this to happen on many packages.

That it will happen for all packages that don't provide shared library.
These packages may end by broken -dev package with just the
*.a =>  -static rule.

Actually it's /lib/*.a,/usr/lib/*.a -> static, which means...


I am not sure, how many such packages exist in the tree, but here is a
list of files in my work directory that would need special care:

... becomes a bit smaller:


alsa-oss-1.0.17-r0: /usr/lib/libossredir.a
binutils-2.18-r8.1: /usr/lib/libiberty.a
bison-2.3-r0: /usr/lib/liby.a
bridge-utils-1.4-r0: /usr/lib/libbridge.a

flex-2.5.31-r4: /usr/lib/libfl.a

gcc-4.3.3-r7.1: /usr/lib/libstdc++_pic.a
gcc-4.3.3-r7.1: /usr/lib/libssp_nonshared.a

gcc-4.3.3-r7.1: /usr/lib/libsupc++.a
gdb-7.0-r0: /usr/lib/libbfd.a
gdb-7.0-r0: /usr/lib/libopcodes.a
gdb-7.0-r0: /usr/lib/libiberty.a
glibc-2.9-r35.2: /usr/lib/libc_nonshared.a
glibc-2.9-r35.2: /usr/lib/libmcheck.a
glibc-2.9-r35.2: /usr/lib/libg.a
glibc-2.9-r35.2: /usr/lib/libbsd-compat.a
glibc-2.9-r35.2: /usr/lib/libieee.a
glibc-2.9-r35.2: /usr/lib/libpthread_nonshared.a
libassuan-0.6.9-r0: /usr/lib/libassuan.a
libatomics-ops-1.2-r2: /usr/lib/libatomic_ops_gpl.a
libatomics-ops-1.2-r2: /usr/lib/libatomic_ops.a
libsdl-x11-1.2.11-r8: /usr/lib/libSDLmain.a
mysql-4.1.22-r3: /usr/lib/libmysys.a
mysql-4.1.22-r3: /usr/lib/libdbug.a
mysql-4.1.22-r3: /usr/lib/libvio.a
mysql-4.1.22-r3: /usr/lib/libheap.a
mysql-4.1.22-r3: /usr/lib/libmerge.a
mysql-4.1.22-r3: /usr/lib/libnisam.a
mysql-4.1.22-r3: /usr/lib/libmysqld.a
mysql-4.1.22-r3: /usr/lib/libmyisam.a
mysql-4.1.22-r3: /usr/lib/libmyisammrg.a
mysql-4.1.22-r3: /usr/lib/libmystrings.a
orbit2-2.14.17-r0: /usr/lib/libname-server-2.a

tcl-8.4.19-r2: /usr/lib/libtclstub8.4.a
tk-8.4.19-r0: /usr/lib/libtkstub8.4.a

I would be happy to take special care of the above recipe in my fixup branch. Do we all agree that the above .a files need to go into -dev packages? If so I'll add something like FILES_${PN}-static = "" to the affected recipes


And these wouldn't need special handling:

> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libnss.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libnssutil.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libunicharutil_external_s.a > firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libembed_base_standalone.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libsoftokn.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libssl.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libembed_base_s.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libcrmf.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libsmime.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libxpcomglue_s.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libmozreg_s.a
> firefox-3.5.2-r2: /usr/lib/firefox-devel-3.5.2/sdk/lib/libxpcomglue.a
> gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/lib64/libiberty.a
> gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libgfortran.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libssp.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libiberty.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libstdc++_pic.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libssp_nonshared.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libsupc++.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/arm-angstrom-linux-gnueabi/lib/libstdc++.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcc.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcc_eh.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgfortranbegin.a > gcc-cross-4.3.3-r7.1: /OE/build/tmp/cross/armv5te/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcov.a
> perl-5.8.8-r28: /usr/lib/perl/5.8.8/auto/DynaLoader/DynaLoader.a
> python-2.6.1-ml8.0: /usr/lib/python2.6/config/libpython2.6.a
> tcl-native-8.4.19-r2: /OE/build/tmp/staging/x86_64-linux/usr/lib/libtclstub8.4.a > tk-native-8.4.19-r0: /OE/build/tmp/staging/x86_64-linux/usr/lib/libtkstub8.4.a
> gcc-4.3.3-r7.1: /usr/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcc.a
> gcc-4.3.3-r7.1: /usr/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcc_eh.a
> gcc-4.3.3-r7.1: /usr/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgfortranbegin.a
> gcc-4.3.3-r7.1: /usr/lib/gcc/arm-angstrom-linux-gnueabi/4.3.3/libgcov.a

regards,

Koen

Found by this bash command:
find */*/image -name '*.a' | fgrep -v .debug | while read ; do if ! test -f 
"${REPLY%.a}.so" ; then PKG=$REPLY ; PKG=${PKG#*/} ; PKG=${PKG%%/*} ; echo 
$PKG: ${REPLY#*/image} ; fi ; done


________________________________________________________________________
Stanislav Brabec
http://www.penguin.cz/~utx/zaurus


_______________________________________________
Openembedded-devel mailing list
[email protected]
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/openembedded-devel



_______________________________________________
Openembedded-devel mailing list
[email protected]
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/openembedded-devel

Reply via email to