[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r17688: {tor} One log.c XXX021 was a misunderstanding. Also, clip log mess (in tor/trunk: . src/common)
Author: nickm
Date: 2008-12-18 12:18:06 -0500 (Thu, 18 Dec 2008)
New Revision: 17688
Modified:
   tor/trunk/ChangeLog
   tor/trunk/src/common/log.c
Log:
One log.c XXX021 was a misunderstanding.  Also, clip log messages passed to syslog to their maximum length when there is a maximum.
Modified: tor/trunk/ChangeLog
===================================================================
--- tor/trunk/ChangeLog	2008-12-18 16:56:00 UTC (rev 17687)
+++ tor/trunk/ChangeLog	2008-12-18 17:18:06 UTC (rev 17688)
@@ -40,6 +40,9 @@
       pairs. Partial implementation of proposal 157.
     - Clients now never report any stream end reason except 'MISC'.
       Implements proposal 148.
+    - On platforms with a maximum syslog string length, truncate syslog
+      messages to that length ourselves, rather than relying on the
+      system to do it for us.
 
   o Minor features (controller):
     - New CONSENSUS_ARRIVED event to note when a new consensus has
Modified: tor/trunk/src/common/log.c
===================================================================
--- tor/trunk/src/common/log.c	2008-12-18 16:56:00 UTC (rev 17687)
+++ tor/trunk/src/common/log.c	2008-12-18 17:18:06 UTC (rev 17688)
@@ -299,10 +299,24 @@
     }
     if (lf->is_syslog) {
 #ifdef HAVE_SYSLOG_H
-      /* XXXX Some syslog implementations have scary limits on the length of
-       * what you can pass them.  Can/should we detect this? */
-      syslog(severity, "%s", end_of_prefix);
+      char *m = end_of_prefix;
+#ifdef MAXLINE
+      /* Some syslog implementations have limits on the length of what you can
+       * pass them, and some very old ones do not detect overflow so well.
+       * Regrettably, they call their maximum line length MAXLINE. */
+#if MAXLINE < 64
+#warn "MAXLINE is a very low number; it might not be from syslog.h after all"
 #endif
+      if (msg_len >= MAXLINE)
+        m = tor_strndup(end_of_prefix, MAXLINE-1);
+#endif
+      syslog(severity, "%s", m);
+#ifdef MAXLINE
+      if (m != end_of_prefix) {
+        tor_free(m);
+      }
+#endif
+#endif
       lf = lf->next;
       continue;
     } else if (lf->callback) {
@@ -739,9 +753,8 @@
   "OR", "EDGE", "ACCT", "HIST", NULL
 };
 
-/** Return the log domain for which <b>domain</b> is the name, or 0 if there
- * is no such name. */
-/*XXXX021 0 could mean "no such domain" or LD_GENERAL.  Fix that. */
+/** Return a bitmask for the log domain for which <b>domain</b> is the name,
+ * or 0 if there is no such name. */
 static log_domain_mask_t
 parse_log_domain(const char *domain)
 {