[Evolution-hackers] Unauthorised licence change to e-spinner.[ch]
- From: Christian Persch <chpe gnome org>
- To: evolution-hackers gnome org
- Subject: [Evolution-hackers] Unauthorised licence change to e-spinner.[ch]
- Date: Fri, 05 Sep 2008 15:16:41 +0200
Hi;
The commit
[http://svn.gnome.org/viewvc/evolution?limit_changes=0&view=revision&revision=36116] introduced a new copyright header for evolution/widgets/misc/e-spinner.[ch] [http://svn.gnome.org/viewvc/evolution/trunk/widgets/misc/e-spinner.c?limit_changes=0&r1=36116&r2=36115&pathrev=36116] above the old copyright header, in which it claims the code is
a) now licensed under LGPL 2 and LGPL 3, and
b) now "Copyright (C) 1999-2008 Novell, Inc. (www.novell.com)".
Both of these claims are false.
e-spinner.[ch] is derived from ephy-spinner.[ch] from Epiphany, and I
hold the copyright on much of the code in it. It is licensed under the
terms of the GPL 2+. As you can see from e-spinner.c's svn history
[http://svn.gnome.org/viewvc/evolution/trunk/widgets/misc/e-spinner.c?view=log], this file was first checked into evolution in 2007, at which time it was almost identical to ephy-spinner except for the rename of the namespace from "ephy" to "e". See the attached diff from ephy-spinner to today's e-spinner after reversal of that rename to observe that the cumulative changes are trivial (not to mention partially bogus), and even if they might justify a "2007-2008" novell copyright they certainly do not justify putting the novell copyright notice above all other copyright holders and to even put a claim to be an "Author" of it!
Most importantly, I was not asked for permission to re-license this code
to the LGPL 2 + LGPL 3; nor have I given such permission.
Please revert this unauthorised license change immediately.
	Christian
--- /home/chpe/source/gnome-2/trunk/epiphany/lib//widgets/ephy-spinner.c	2008-02-17 19:43:11.000000000 +0100
+++ e	2008-09-05 15:06:38.000000000 +0200
@@ -1,4 +1,25 @@
 /* 
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>  
+ *
+ *
+ * Authors:
+ *
+ * Copyright (C) 1999-2008 Novell, Inc. (www.novell.com)
+ *
+ */
+/*
  * Copyright © 2000 Eazel, Inc.
  * Copyright © 2002-2004 Marco Pesenti Gritti
  * Copyright © 2004, 2006 Christian Persch
@@ -21,20 +42,22 @@
  *
  * Ephy port by Marco Pesenti Gritti <marco it gnome org>
  * 
- * $Id: ephy-spinner.c 6952 2007-03-11 19:42:02Z chpe $
+ * $Id: e-spinner.c 12639 2006-12-12 17:06:55Z chpe $
+ */
+
+/*
+ * From Nautilus ephy-spinner.c
  */
 
-#ifndef COMPILING_TESTSPINNER
 #include "config.h"
-#include "ephy-debug.h"
-#endif
 
-#include "ephy-spinner.h"
+#include "e-spinner.h"
 
-#include <gdk-pixbuf/gdk-pixbuf.h>
-#include <gtk/gtkicontheme.h>
-#include <gtk/gtkiconfactory.h>
-#include <gtk/gtksettings.h>
+#define LOG(msg, args...)
+#define START_PROFILER(name)
+#define STOP_PROFILER(name)
+
+#include "e-util/e-icon-factory.h"
 
 /* Spinner cache implementation */
 
@@ -96,6 +119,7 @@
 static void ephy_spinner_cache_init	  (EphySpinnerCache *cache);
 
 static GObjectClass *ephy_spinner_cache_parent_class;
+static gpointer spinner_cache = NULL;
 
 static GType
 ephy_spinner_cache_get_type (void)
@@ -216,8 +240,7 @@
 
 	if (pw != dw || ph != dh)
 	{
-		result = gdk_pixbuf_scale_simple (pixbuf, dw, dh,
-						  GDK_INTERP_BILINEAR);
+		result = e_icon_factory_pixbuf_scale (pixbuf, dw, dh);
 		g_object_unref (pixbuf);
 		return result;
 	}
@@ -264,7 +287,10 @@
 			goto loser;
 		}
 	}
-	g_assert (icon_info != NULL);
+	if (icon_info == NULL) {
+		g_warning ("icon_info is NULL");
+		goto loser;
+	}
 
 	size = gtk_icon_info_get_base_size (icon_info);
 	icon = gtk_icon_info_get_filename (icon_info);
@@ -304,8 +330,7 @@
 
 	g_object_unref (icon_pixbuf);
 
-	if (list == NULL) goto loser;
-	g_assert (n > 0);
+	if (list == NULL || n <= 0) goto loser;
 
 	if (size > requested_size)
 	{
@@ -327,10 +352,12 @@
 
 	for (l = list; l != NULL; l = l->next)
 	{
-		g_assert (l->data != NULL);
+		if (l->data)
 		images->animation_pixbufs[--n] = l->data;
 	}
-	g_assert (n == 0);
+	if (n != 0) {
+		g_warning ("n != 0 \n");
+	}
 
 	g_slist_free (list);
 
@@ -475,24 +502,17 @@
 	g_type_class_add_private (object_class, sizeof (EphySpinnerCachePrivate));
 }
 
-static EphySpinnerCache *spinner_cache = NULL;
-
 static EphySpinnerCache *
 ephy_spinner_cache_ref (void)
 {
-	if (spinner_cache == NULL)
+	if (G_UNLIKELY (spinner_cache == NULL))
 	{
-		EphySpinnerCache **cache_ptr;
-
 		spinner_cache = g_object_new (EPHY_TYPE_SPINNER_CACHE, NULL);
-		cache_ptr = &spinner_cache;
-		g_object_add_weak_pointer (G_OBJECT (spinner_cache),
-					   (gpointer *) cache_ptr);
-
-		return spinner_cache;
+		g_object_add_weak_pointer (
+                        G_OBJECT (spinner_cache), &spinner_cache);
 	}
 		
-	return g_object_ref (spinner_cache);
+	return g_object_ref_sink (spinner_cache);
 }
 
 /* Spinner implementation */
@@ -640,14 +660,14 @@
 	}
 
 	/* Otherwise |images| will be NULL anyway */
-	g_assert (images->n_animation_pixbufs > 0);
+	g_return_val_if_fail (images->n_animation_pixbufs > 0, FALSE);
 		
-	g_assert (details->current_image >= 0 &&
-		  details->current_image < images->n_animation_pixbufs);
+	g_return_val_if_fail (details->current_image >= 0 &&
+		  details->current_image < images->n_animation_pixbufs, FALSE);
 
 	pixbuf = images->animation_pixbufs[details->current_image];
 
-	g_assert (pixbuf != NULL);
+	g_return_val_if_fail (pixbuf != NULL, FALSE);
 
 	width = gdk_pixbuf_get_width (pixbuf);
 	height = gdk_pixbuf_get_height (pixbuf);
[
Date Prev][
Date Next]   [
Thread Prev][
Thread Next]   
[
Thread Index]
[
Date Index]
[
Author Index]