/* Set transport-info line. */
{
- char *transport_info_args = NULL;
+ char *version = NULL;
+ char *impl = NULL;
if (mp->version) {
- tor_asprintf(&transport_info_args, " version=%s", mp->version);
+ tor_asprintf(&version, " version=%s", mp->version);
}
if (mp->implementation) {
- tor_asprintf(&transport_info_args, " implementation=%s",
- mp->implementation);
- }
- if (transport_info_args) {
- smartlist_add_asprintf(string_chunks, "transport-info%s",
- transport_info_args ? transport_info_args : "");
- tor_free(transport_info_args);
+ tor_asprintf(&impl, " implementation=%s", mp->implementation);
}
+ /* Always put in the line even if empty. Else, we don't know to which
+ * transport this applies to. */
+ smartlist_add_asprintf(string_chunks, "transport-info%s%s",
+ version ? version: "", impl ? impl: "");
+ tor_free(version);
+ tor_free(impl);
}
} SMARTLIST_FOREACH_END(mp);
tt_assert(s);
tt_str_op(s, OP_EQ,
"transport hagbard 127.0.0.1:5555\n"
- "transport celine 127.0.0.1:1723 card=no-enemy\n");
+ "transport-info\n"
+ "transport celine 127.0.0.1:1723 card=no-enemy\n"
+ "transport-info\n");
done:
/* XXXX clean up better */