[Zope-Checkins] CVS: Zope/lib/python/BTrees - BucketTemplate.c:1.53

Tim Peters tim.one@comcast.net
Wed, 16 Apr 2003 12:01:10 -0400


Update of /cvs-repository/Zope/lib/python/BTrees
In directory cvs.zope.org:/tmp/cvs-serv20433/lib/python/BTrees

Modified Files:
	BucketTemplate.c 
Log Message:
bucket_set():  Backported Guido's fix to squash nuisance warnings from gcc.


=== Zope/lib/python/BTrees/BucketTemplate.c 1.52 => 1.53 ===
--- Zope/lib/python/BTrees/BucketTemplate.c:1.52	Fri Apr 11 15:38:18 2003
+++ Zope/lib/python/BTrees/BucketTemplate.c	Wed Apr 16 12:01:10 2003
@@ -299,7 +299,18 @@
 {
     int i, cmp;
     KEY_TYPE key;
-    VALUE_TYPE value;
+
+    /* Subtle:  there may or may not be a value.  If there is, we need to
+     * check its type early, so that in case of error we can get out before
+     * mutating the bucket.  But because value isn't used on all paths, if
+     * we don't initialize value then gcc gives a nuisance complaint that
+     * value may be used initialized (it can't be, but gcc doesn't know
+     * that).  So we initialize it.  However, VALUE_TYPE can be various types,
+     * including int, PyObject*, and char[6], so it's a puzzle to spell
+     * initialization.  It so happens that {0} is a valid initializer for all
+     * these types.
+     */
+    VALUE_TYPE value = {0};	/* squash nuisance warning */
     int result = -1;    /* until proven innocent */
     int copied = 1;