[or-cvs] r17908: {tor} Backport 17891 and 17892 to fix openbsd build warnings. Also (in tor/branches/tor-0_2_0-patches: doc src/common src/or)
nickm at seul.org
nickm at seul.org
Mon Jan 5 08:12:33 UTC 2009
Author: nickm
Date: 2009-01-05 03:12:33 -0500 (Mon, 05 Jan 2009)
New Revision: 17908
Modified:
tor/branches/tor-0_2_0-patches/doc/TODO.020
tor/branches/tor-0_2_0-patches/src/common/torgzip.c
tor/branches/tor-0_2_0-patches/src/common/util.c
tor/branches/tor-0_2_0-patches/src/or/directory.c
Log:
Backport 17891 and 17892 to fix openbsd build warnings. Also backport snarky comments.
Modified: tor/branches/tor-0_2_0-patches/doc/TODO.020
===================================================================
--- tor/branches/tor-0_2_0-patches/doc/TODO.020 2009-01-05 08:07:33 UTC (rev 17907)
+++ tor/branches/tor-0_2_0-patches/doc/TODO.020 2009-01-05 08:12:33 UTC (rev 17908)
@@ -3,8 +3,8 @@
description of the patch.)
Backport for 0.2.0:
- - r17891: Fix a fun OpenBSD warning.
- - r17892: Fix another fun OpenBSD warning.
+ o r17891: Fix a fun OpenBSD warning.
+ o r17892: Fix another fun OpenBSD warning.
Backport for 0.2.0 once better tested:
Xo r16621: Make some DNS code more robust (partial; see also libevent
Modified: tor/branches/tor-0_2_0-patches/src/common/torgzip.c
===================================================================
--- tor/branches/tor-0_2_0-patches/src/common/torgzip.c 2009-01-05 08:07:33 UTC (rev 17907)
+++ tor/branches/tor-0_2_0-patches/src/common/torgzip.c 2009-01-05 08:12:33 UTC (rev 17908)
@@ -143,7 +143,16 @@
}
done:
*out_len = stream->total_out;
- if (stream->total_out > out_size + 4097) {
+#ifdef OPENBSD
+ /* "Hey Rocky! Watch me change an unsigned field to a signed field in a
+ * third-party API!"
+ * "Oh, that trick will just make people do unsafe casts to the unsigned
+ * type in their cross-platform code!"
+ * "Don't be foolish. I'm _sure_ they'll have the good sense to make sure
+ * the newly unsigned field isn't negative." */
+ tor_assert(stream->total_out >= 0);
+#endif
+ if (((size_t)stream->total_out) > out_size + 4097) {
/* If we're wasting more than 4k, don't. */
*out = tor_realloc(*out, stream->total_out + 1);
}
Modified: tor/branches/tor-0_2_0-patches/src/common/util.c
===================================================================
--- tor/branches/tor-0_2_0-patches/src/common/util.c 2009-01-05 08:07:33 UTC (rev 17907)
+++ tor/branches/tor-0_2_0-patches/src/common/util.c 2009-01-05 08:12:33 UTC (rev 17908)
@@ -73,8 +73,13 @@
#include <malloc/malloc.h>
#endif
#ifdef HAVE_MALLOC_H
+#ifndef OPENBSD
+/* OpenBSD has a malloc.h, but for our purposes, it only exists in order to
+ * scold us for being so stupid as to autodetect its presence. To be fair,
+ * they've done this since 1996, when autoconf was only 5 years old. */
#include <malloc.h>
#endif
+#endif
/* =====
* Memory management
Modified: tor/branches/tor-0_2_0-patches/src/or/directory.c
===================================================================
--- tor/branches/tor-0_2_0-patches/src/or/directory.c 2009-01-05 08:07:33 UTC (rev 17907)
+++ tor/branches/tor-0_2_0-patches/src/or/directory.c 2009-01-05 08:12:33 UTC (rev 17908)
@@ -8,8 +8,10 @@
#include "or.h"
#if defined(EXPORTMALLINFO) && defined(HAVE_MALLOC_H) && defined(HAVE_MALLINFO)
+#ifndef OPENBSD
#include <malloc.h>
#endif
+#endif
/**
* \file directory.c
More information about the tor-commits
mailing list