aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog1
-rw-r--r--src/or/control.c11
2 files changed, 5 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index 6e9aeb83a..520695184 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -81,6 +81,7 @@ Changes in version 0.2.0.3-alpha - 2007-??-??
- Provide DNS expiry times in GMT, not in local time. For backward
compatibility, ADDRMAP events only provide GMT expiry in an extended
field. "GETINFO address-mappings" always does the right thing.
+ - Use CRLF line endings properly in NS events.
Changes in version 0.1.2.15 - 2007-07-17
diff --git a/src/or/control.c b/src/or/control.c
index d99fb4b8c..45ef63be7 100644
--- a/src/or/control.c
+++ b/src/or/control.c
@@ -3159,7 +3159,7 @@ int
control_event_networkstatus_changed(smartlist_t *statuses)
{
smartlist_t *strs;
- char *s;
+ char *s, *esc = NULL;
if (!EVENT_IS_INTERESTING(EVENT_NS) || !smartlist_len(statuses))
return 0;
@@ -3171,17 +3171,14 @@ control_event_networkstatus_changed(smartlist_t *statuses)
if (!s) continue;
smartlist_add(strs, s);
});
- smartlist_add(strs, tor_strdup("\r\n.\r\n"));
- /* XXX020 the above strdup has an extra \r\n in it, resulting in
- * a blank line in the NS output. Can we remove it, or is that
- * bad since the output of networkstatus_getinfo_helper_single()
- * only adds \n, not \r\n? */
s = smartlist_join_strings(strs, "", 0, NULL);
+ write_escaped_data(s, strlen(s), 1, &esc);
SMARTLIST_FOREACH(strs, char *, cp, tor_free(cp));
smartlist_free(strs);
- send_control_event_string(EVENT_NS, ALL_NAMES|ALL_FORMATS, s);
tor_free(s);
+ send_control_event_string(EVENT_NS, ALL_NAMES|ALL_FORMATS, esc);
+ tor_free(esc);
return 0;
}