#include "php.h"
#include "php_mailparse.h"
+#define DEBUG_RFC2045_DECODE 0
+
static int op_func(int c, void *dat)
{
struct rfc2045 * p = (struct rfc2045*)dat;
+
rfc2045_add_workbufch(p, c);
/* drain buffer */
if (p->workbuflen >= 4096) {
+#if DEBUG_RFC2045_DECODE
+ zend_printf("op_func buffer is %d; lets drain it\n", p->workbuflen);
+#endif
(*p->udecode_func)(p->workbuf, p->workbuflen, p->misc_decode_ptr);
p->workbuflen = 0;
}
p->udecode_func=u;
p->workbuflen=0;
- if (from == mbfl_no_encoding_8bit)
+ if (from == mbfl_no_encoding_8bit || from == mbfl_no_encoding_7bit)
p->decode_filter = NULL;
else
p->decode_filter = mbfl_convert_filter_new(
mbfl_convert_filter_flush(p->decode_filter);
mbfl_convert_filter_delete(p->decode_filter);
p->decode_filter = NULL;
- if (p->workbuflen > 0)
+ if (p->workbuflen > 0) {
+#if DEBUG_RFC2045_DECODE
+ zend_printf("cdecode end: there are %d bytes remaining; drain it\n",
+ p->workbuflen);
+#endif
(*p->udecode_func)(p->workbuf, p->workbuflen, p->misc_decode_ptr);
+ }
}
return 0;
}
if (p->decode_filter)
{
+#if DEBUG_RFC2045_DECODE
+ zend_printf("cdecode: with filter %d bytes\n", l);
+#endif
for (i=0; i<l; i++)
{
- if (mbfl_convert_filter_feed(s[i], p->decode_filter) < 0)
+ if (mbfl_convert_filter_feed(s[i], p->decode_filter) < 0) {
+#if DEBUG_RFC2045_DECODE
+ int j;
+
+ zend_printf("returning -1 on %d byte == %d (%c)! context is\n",
+ i, (unsigned char)s[i], s[i]);
+
+ for (j = i - 10; j < i + 10; j++) {
+ zend_printf(" byte %d was %d '%c'\n",
+ j, (unsigned char)s[j], s[j]
+ );
+ }
+#else
+ TSRMLS_FETCH();
+ zend_error(E_WARNING, "%s() - filter conversion failed. Input message is probably incorrectly encoded\n",
+ get_active_function_name(TSRMLS_C)
+ );
+#endif
return -1;
+ }
}
}
- else
+ else {
+#if DEBUG_RFC2045_DECODE
+ zend_printf("cdecode: no filter %d bytes\n", l);
+#endif
return ((*p->udecode_func)(s,l,p->misc_decode_ptr));
+ }
}
return (0);