aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/cmd/upas/marshal/marshal.c54
1 files changed, 53 insertions, 1 deletions
diff --git a/src/cmd/upas/marshal/marshal.c b/src/cmd/upas/marshal/marshal.c
index fbc06cf6..da54c760 100644
--- a/src/cmd/upas/marshal/marshal.c
+++ b/src/cmd/upas/marshal/marshal.c
@@ -134,6 +134,8 @@ void freealiases(Alias*);
int doublequote(Fmt*);
int mountmail(void);
int nprocexec;
+int rfc2047fmt(Fmt*);
+char* mksubject(char*);
int rflag, lbflag, xflag, holding, nflag, Fflag, eightflag, dflag;
int pgpflag = 0;
@@ -207,6 +209,7 @@ threadmain(int argc, char **argv)
quotefmtinstall();
fmtinstall('Z', doublequote);
+ fmtinstall('U', rfc2047fmt);
threadwaitchan();
ARGBEGIN{
@@ -487,7 +490,10 @@ readheaders(Biobuf *in, int *fp, String **sp, Addr **top, int strict)
break;
}
}
- if(top==nil || hdrtype!=Hbcc){
+ if(hdrtype == Hsubject){
+ s_append(s, mksubject(s_to_c(sline)));
+ s_append(s, "\n");
+ }else if(top==nil || hdrtype!=Hbcc){
s_append(s, s_to_c(sline));
s_append(s, "\n");
}
@@ -1865,3 +1871,49 @@ mountmail(void)
return -1;
return 0;
}
+
+int
+rfc2047fmt(Fmt *fmt)
+{
+ char *s, *p;
+
+ s = va_arg(fmt->args, char*);
+ if(s == nil)
+ return fmtstrcpy(fmt, "");
+ for(p=s; *p; p++)
+ if((uchar)*p >= 0x80)
+ goto hard;
+ return fmtstrcpy(fmt, s);
+
+hard:
+ fmtprint(fmt, "=?utf-8?q?");
+ for(p=s; *p; p++){
+ if(*p == ' ')
+ fmtrune(fmt, '_');
+ else if(*p == '_' || *p == '\t' || *p == '=' || *p == '?' || (uchar)*p >= 0x80)
+ fmtprint(fmt, "=%.2uX", (uchar)*p);
+ else
+ fmtrune(fmt, (uchar)*p);
+ }
+ fmtprint(fmt, "?=");
+ return 0;
+}
+
+char*
+mksubject(char *line)
+{
+ char *p, *q;
+ static char buf[1024];
+
+ p = strchr(line, ':')+1;
+ while(*p == ' ')
+ p++;
+ for(q=p; *q; q++)
+ if((uchar)*q >= 0x80)
+ goto hard;
+ return line;
+
+hard:
+ snprint(buf, sizeof buf, "Subject: %U", p);
+ return buf;
+}