process_rfc822_addr(value, user, node, name);
syslog(LOG_DEBUG, "internet_addressing: converted to <%s@%s> (%s)", user, node, name);
snprintf(addr, sizeof(addr), "%s@%s", user, node);
- if (CM_IsEmpty(msg, eAuthor) && !IsEmptyStr(name))
- CM_SetField(msg, eAuthor, name, strlen(name));
- if (CM_IsEmpty(msg, erFc822Addr) && !IsEmptyStr(addr))
- CM_SetField(msg, erFc822Addr, addr, strlen(addr));
+ if (CM_IsEmpty(msg, eAuthor) && !IsEmptyStr(name)) {
+ CM_SetField(msg, eAuthor, name, -1);
+ }
+ if (CM_IsEmpty(msg, erFc822Addr) && !IsEmptyStr(addr)) {
+ CM_SetField(msg, erFc822Addr, addr, -1);
+ }
processed = 1;
}
CM_SetField(journal_msg, eJournal, HKEY("is journal"));
if (!IsEmptyStr(jmsg->from)) {
- CM_SetField(journal_msg, eAuthor, jmsg->from, strlen(jmsg->from));
+ CM_SetField(journal_msg, eAuthor, jmsg->from, -1);
}
if (!IsEmptyStr(jmsg->rfca)) {
- CM_SetField(journal_msg, erFc822Addr, jmsg->rfca, strlen(jmsg->rfca));
+ CM_SetField(journal_msg, erFc822Addr, jmsg->rfca, -1);
}
if (!IsEmptyStr(jmsg->subj)) {
- CM_SetField(journal_msg, eMsgSubject, jmsg->subj, strlen(jmsg->subj));
+ CM_SetField(journal_msg, eMsgSubject, jmsg->subj, -1);
}
mblen = snprintf(mime_boundary, sizeof(mime_boundary),
Msg->cm_fields[which] = *buf;
*buf = NULL;
if (length < 0) { // You can set the length to -1 to have CM_SetField measure it for you
- Msg->cm_lengths[which] = strlen(buf);
+ Msg->cm_lengths[which] = strlen(Msg->cm_fields[which]);
}
else {
Msg->cm_lengths[which] = length;
* If this message has no O (room) field, generate one.
*/
if (CM_IsEmpty(msg, eOriginalRoom) && !IsEmptyStr(CC->room.QRname)) {
- CM_SetField(msg, eOriginalRoom, CC->room.QRname, strlen(CC->room.QRname));
+ CM_SetField(msg, eOriginalRoom, CC->room.QRname, -1);
}
/* Perform "before save" hooks (aborting if any return nonzero) */
msg->cm_format_type = format_type;
if (!IsEmptyStr(from)) {
- CM_SetField(msg, eAuthor, from, strlen(from));
+ CM_SetField(msg, eAuthor, from, -1);
}
else if (!IsEmptyStr(fromaddr)) {
char *pAt;
- CM_SetField(msg, eAuthor, fromaddr, strlen(fromaddr));
+ CM_SetField(msg, eAuthor, fromaddr, -1);
pAt = strchr(msg->cm_fields[eAuthor], '@');
if (pAt != NULL) {
CM_CutFieldAt(msg, eAuthor, pAt - msg->cm_fields[eAuthor]);
msg->cm_fields[eAuthor] = strdup("Citadel");
}
- if (!IsEmptyStr(fromaddr)) CM_SetField(msg, erFc822Addr, fromaddr, strlen(fromaddr));
- if (!IsEmptyStr(room)) CM_SetField(msg, eOriginalRoom, room, strlen(room));
+ if (!IsEmptyStr(fromaddr)) CM_SetField(msg, erFc822Addr, fromaddr, -1);
+ if (!IsEmptyStr(room)) CM_SetField(msg, eOriginalRoom, room, -1);
if (!IsEmptyStr(to)) {
- CM_SetField(msg, eRecipient, to, strlen(to));
+ CM_SetField(msg, eRecipient, to, -1);
recp = validate_recipients(to, NULL, 0);
}
if (!IsEmptyStr(subject)) {
- CM_SetField(msg, eMsgSubject, subject, strlen(subject));
+ CM_SetField(msg, eMsgSubject, subject, -1);
}
if (!IsEmptyStr(text)) {
- CM_SetField(msg, eMesageText, text, strlen(text));
+ CM_SetField(msg, eMesageText, text, -1);
}
long msgnum = CtdlSubmitMsg(msg, recp, room, 0);
CM_SetField(msg, eMessagePath, my_email, myelen);
}
else if (!IsEmptyStr(author->fullname)) {
- CM_SetField(msg, eMessagePath, author->fullname, strlen(author->fullname));
+ CM_SetField(msg, eMessagePath, author->fullname, -1);
}
convert_spaces_to_underscores(msg->cm_fields[eMessagePath]);
if (!!IsEmptyStr(CC->room.QRname)) {
if (CC->room.QRflags & QR_MAILBOX) { /* room */
- CM_SetField(msg, eOriginalRoom, &CC->room.QRname[11], strlen(&CC->room.QRname[11]));
+ CM_SetField(msg, eOriginalRoom, &CC->room.QRname[11], -1);
}
else {
- CM_SetField(msg, eOriginalRoom, CC->room.QRname, strlen(CC->room.QRname));
+ CM_SetField(msg, eOriginalRoom, CC->room.QRname, -1);
}
}
CM_SetField(msg, erFc822Addr, my_email, myelen);
}
else if ( (author == &CC->user) && (!IsEmptyStr(CC->cs_inet_email)) ) {
- CM_SetField(msg, erFc822Addr, CC->cs_inet_email, strlen(CC->cs_inet_email));
+ CM_SetField(msg, erFc822Addr, CC->cs_inet_email, -1);
}
if (subject != NULL) {
msg->cm_magic = CTDLMESSAGE_MAGIC;
msg->cm_anon_type = MES_NORMAL;
msg->cm_format_type = 4;
- CM_SetField(msg, eAuthor, CC->user.fullname, strlen(CC->user.fullname));
- CM_SetField(msg, eOriginalRoom, req_room, strlen(req_room));
+ CM_SetField(msg, eAuthor, CC->user.fullname, -1);
+ CM_SetField(msg, eOriginalRoom, req_room, -1);
msg->cm_flags = flags;
CM_SetAsFieldSB(msg, eMesageText, &encoded_message);