summaryrefslogtreecommitdiffstats
path: root/zarb-ml/mageia-dev/2012-August/017900.html
diff options
context:
space:
mode:
Diffstat (limited to 'zarb-ml/mageia-dev/2012-August/017900.html')
-rw-r--r--zarb-ml/mageia-dev/2012-August/017900.html140
1 files changed, 140 insertions, 0 deletions
diff --git a/zarb-ml/mageia-dev/2012-August/017900.html b/zarb-ml/mageia-dev/2012-August/017900.html
new file mode 100644
index 000000000..82e5ca204
--- /dev/null
+++ b/zarb-ml/mageia-dev/2012-August/017900.html
@@ -0,0 +1,140 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN">
+<HTML>
+ <HEAD>
+ <TITLE> [Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)
+ </TITLE>
+ <LINK REL="Index" HREF="index.html" >
+ <LINK REL="made" HREF="mailto:mageia-dev%40mageia.org?Subject=Re%3A%20%5BMageia-dev%5D%20Library%20policy%20query%3A%20What%20do%20we%20do%20when%20SONAME%0A%09includes%20both%20major%20and%20minor%3F%20%28Re%3A%20%5Bchangelog%5D%20%5BRPM%5D%0A%09cauldron%20core/release%20kdelibs4-4.9.0-2.mga3%29&In-Reply-To=%3C10614520.IBvc66st52%40localhost%3E">
+ <META NAME="robots" CONTENT="index,nofollow">
+ <META http-equiv="Content-Type" content="text/html; charset=us-ascii">
+ <LINK REL="Previous" HREF="017899.html">
+ <LINK REL="Next" HREF="017901.html">
+ </HEAD>
+ <BODY BGCOLOR="#ffffff">
+ <H1>[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)</H1>
+ <B>Nicolas L&#233;cureuil</B>
+ <A HREF="mailto:mageia-dev%40mageia.org?Subject=Re%3A%20%5BMageia-dev%5D%20Library%20policy%20query%3A%20What%20do%20we%20do%20when%20SONAME%0A%09includes%20both%20major%20and%20minor%3F%20%28Re%3A%20%5Bchangelog%5D%20%5BRPM%5D%0A%09cauldron%20core/release%20kdelibs4-4.9.0-2.mga3%29&In-Reply-To=%3C10614520.IBvc66st52%40localhost%3E"
+ TITLE="[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)">nicolas.lecureuil at free.fr
+ </A><BR>
+ <I>Thu Aug 2 11:35:55 CEST 2012</I>
+ <P><UL>
+ <LI>Previous message: <A HREF="017899.html">[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)
+</A></li>
+ <LI>Next message: <A HREF="017901.html">[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)
+</A></li>
+ <LI> <B>Messages sorted by:</B>
+ <a href="date.html#17900">[ date ]</a>
+ <a href="thread.html#17900">[ thread ]</a>
+ <a href="subject.html#17900">[ subject ]</a>
+ <a href="author.html#17900">[ author ]</a>
+ </LI>
+ </UL>
+ <HR>
+<!--beginarticle-->
+<PRE>Le jeudi 2 ao&#251;t 2012 10:31:04 Pascal Terjan a &#233;crit :
+&gt;<i> On Thu, Aug 2, 2012 at 10:17 AM, Colin Guthrie &lt;<A HREF="https://www.mageia.org/mailman/listinfo/mageia-dev">mageia at colin.guthr.ie</A>&gt;
+</I>wrote:
+&gt;<i> &gt; 'Twas brillig, and Balcaen John at 02/08/12 10:01 did gyre and gimble:
+</I>&gt;<i> &gt;&gt; Le jeudi 2 ao&#251;t 2012 09:28:28 Colin Guthrie a &#233;crit :
+</I>&gt;<i> &gt;&gt;&gt; 'Twas brillig, and Christiaan Welvaart at 01/08/12 23:09 did gyre and
+</I>&gt;<i> &gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt; gimble:
+</I>&gt;<i> &gt;&gt;&gt;&gt; On Wed, 1 Aug 2012, Colin Guthrie wrote:
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; I have to agree here that something is &quot;funny&quot; in the libattica
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; package
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; which ultimately helped to contribute to this issue.
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; e.g. on my system before update (tho' with similar results after):
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; [<A HREF="https://www.mageia.org/mailman/listinfo/mageia-dev">colin at jimmy</A> ~]$ rpm -q --provides lib64attica0
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; libattica.so.0.3()(64bit)
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; lib64attica0 = 0.3.0-1.mga2
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; lib64attica0(x86-64) = 0.3.0-1.mga2
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; [<A HREF="https://www.mageia.org/mailman/listinfo/mageia-dev">colin at jimmy</A> ~]$ rpm -ql lib64attica0
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; /usr/lib64/libattica.so.0.3
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; /usr/lib64/libattica.so.0.3.0
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; So I can see how this mistake was made and TBH I could have made the
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; same mistake myself (with the caveat that I likely would not have
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; bumped
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; the version of someone else's package with out confirming first and
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; that
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; it should have been obvious from testing and installing the build)
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; But either way this seems like an issue to fix properly (possibly with
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; an upstream fix or some modification to the library policy when the
+</I>&gt;<i> &gt;&gt;&gt;&gt;&gt; minor version is &quot;presented&quot; like this).
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; Good catch! Of course it's never the library policy that's wrong. The
+</I>&gt;<i> &gt;&gt;&gt;&gt; library major version is apparently 0.4 so the correct package name is
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; lib64attica0.3 for the previous one
+</I>&gt;<i> &gt;&gt;&gt;&gt; lib64attica0.4 for the current one
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; ... in the specfile: %define attica_major 0.4
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; Can the maintainer of this package please fix this?
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; To find the version to use, look up the 'soname' of the library. I use:
+</I>&gt;<i> &gt;&gt;&gt;&gt; readelf -a /usr/lib64/libattica.so.0.4|grep SONAME
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; =&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; ... Library soname: [libattica.so.0.4]
+</I>&gt;<i> &gt;&gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt;&gt; What follows &quot;.so.&quot; is the major version of the library.
+</I>&gt;<i> &gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt; Is that really the correct definition of what a &quot;major&quot; version is?
+</I>&gt;<i> &gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt; I always thought the major was just the first number.
+</I>&gt;<i> &gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt; The library policy certainly doesn't mention &quot;double digit majors&quot; or
+</I>&gt;<i> &gt;&gt;&gt; similar.
+</I>&gt;<i> &gt;&gt;&gt;
+</I>&gt;<i> &gt;&gt;&gt; Is this something upstream is doing deliberately or is it just an
+</I>&gt;<i> &gt;&gt;&gt; oversight?&gt;&gt;
+</I>&gt;<i> &gt;&gt; <A HREF="https://projects.kde.org/projects/kdesupport/attica/repository/revisions/">https://projects.kde.org/projects/kdesupport/attica/repository/revisions/</A>
+</I>&gt;<i> &gt;&gt; master/entry/CMakeLists.txt&gt;
+</I>&gt;<i> &gt; Actually it's this file/line:
+</I>&gt;<i> &gt;
+</I>&gt;<i> &gt; <A HREF="https://projects.kde.org/projects/kdesupport/attica/repository/revisions/m">https://projects.kde.org/projects/kdesupport/attica/repository/revisions/m</A>
+</I>&gt;<i> &gt; aster/entry/lib/CMakeLists.txt#L120
+</I>&gt;<i> &gt;
+</I>&gt;<i> &gt; So it's seems like this was done deliberately due to a ABI breakage a
+</I>&gt;<i> &gt; while ago:
+</I>&gt;<i> &gt;
+</I>&gt;<i> &gt; <A HREF="https://projects.kde.org/projects/kdesupport/attica/repository/revisions/a">https://projects.kde.org/projects/kdesupport/attica/repository/revisions/a</A>
+</I>&gt;<i> &gt; c2270b1f9c445fd39e48051b99d35d9b9693a34
+</I>&gt;<i> &gt;
+</I>&gt;<i> &gt; Now, this is an interesting point (regarding our lib policy) bumping the
+</I>&gt;<i> &gt; major for an API change and the minor for an ABI change seems kinda
+</I>&gt;<i> &gt; sensible to me. So how should we deal with that in our policy? Just use
+</I>&gt;<i> &gt; 0.4 as the &quot;major&quot; value here as Christiaan suggested?
+</I>&gt;<i>
+</I>&gt;<i> A minor change is supposed to only add interfaces and be backwards
+</I>&gt;<i> compatible, that's why it is not in the soname.
+</I>&gt;<i> If there has been an ABI breakage, the major should be incremented.
+</I>
+I think that we better should see with attica devs to ask a major increase.
+</PRE>
+
+
+<!--endarticle-->
+ <HR>
+ <P><UL>
+ <!--threads-->
+ <LI>Previous message: <A HREF="017899.html">[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)
+</A></li>
+ <LI>Next message: <A HREF="017901.html">[Mageia-dev] Library policy query: What do we do when SONAME includes both major and minor? (Re: [changelog] [RPM] cauldron core/release kdelibs4-4.9.0-2.mga3)
+</A></li>
+ <LI> <B>Messages sorted by:</B>
+ <a href="date.html#17900">[ date ]</a>
+ <a href="thread.html#17900">[ thread ]</a>
+ <a href="subject.html#17900">[ subject ]</a>
+ <a href="author.html#17900">[ author ]</a>
+ </LI>
+ </UL>
+
+<hr>
+<a href="https://www.mageia.org/mailman/listinfo/mageia-dev">More information about the Mageia-dev
+mailing list</a><br>
+</body></html>