aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core
diff options
context:
space:
mode:
Diffstat (limited to 'src/core')
-rw-r--r--src/core/abstract/MCAbstractMessagePart.cc3
-rw-r--r--src/core/basetypes/MCHTMLCleaner.cc20
-rw-r--r--src/core/basetypes/MCString.cc49
-rw-r--r--src/core/renderer/MCHTMLRenderer.cpp5
-rw-r--r--src/core/renderer/MCRenderer.h2
-rw-r--r--src/core/rfc822/MCAttachment.cc1
-rw-r--r--src/core/rfc822/MCMessageParser.cc8
-rw-r--r--src/core/rfc822/MCMessageParser.h1
8 files changed, 55 insertions, 34 deletions
diff --git a/src/core/abstract/MCAbstractMessagePart.cc b/src/core/abstract/MCAbstractMessagePart.cc
index 8ecd05f7..649fcc32 100644
--- a/src/core/abstract/MCAbstractMessagePart.cc
+++ b/src/core/abstract/MCAbstractMessagePart.cc
@@ -8,6 +8,7 @@ void AbstractMessagePart::init()
{
mMainPart = NULL;
mHeader = NULL;
+ setPartType(PartTypeMessage);
}
AbstractMessagePart::AbstractMessagePart()
@@ -35,7 +36,7 @@ AbstractMessagePart::~AbstractMessagePart()
String * AbstractMessagePart::description()
{
String * result = String::string();
- result->appendUTF8Format("<%s:%p %s>", className(), this, mMainPart->description());
+ result->appendUTF8Format("<%s:%p %s>", className()->UTF8Characters(), this, mMainPart->description()->UTF8Characters());
return result;
}
diff --git a/src/core/basetypes/MCHTMLCleaner.cc b/src/core/basetypes/MCHTMLCleaner.cc
index d8c63613..12f1371e 100644
--- a/src/core/basetypes/MCHTMLCleaner.cc
+++ b/src/core/basetypes/MCHTMLCleaner.cc
@@ -37,29 +37,33 @@ String * HTMLCleaner::cleanHTML(String * input)
tidyOptSetBool(tdoc, TidyXhtmlOut, yes);
tidySetCharEncoding(tdoc, "utf8");
tidyOptSetBool(tdoc, TidyForceOutput, yes);
+ //tidyOptSetValue(tdoc, TidyErrFile, "/dev/null");
+ //tidyOptSetValue(tdoc, TidyOutFile, "/dev/null");
+ tidyOptSetBool(tdoc, TidyShowWarnings, no);
+ tidyOptSetInt(tdoc, TidyShowErrors, 0);
rc = tidySetErrorBuffer(tdoc, &errbuf);
if ((rc > 1) || (rc < 0)) {
- fprintf(stderr, "error tidySetErrorBuffer: %i\n", rc);
- fprintf(stderr, "1:%s", errbuf.bp);
+ //fprintf(stderr, "error tidySetErrorBuffer: %i\n", rc);
+ //fprintf(stderr, "1:%s", errbuf.bp);
//return NULL;
}
rc = tidyParseBuffer(tdoc, &docbuf);
//MCLog("%s", MCUTF8(input));
if ((rc > 1) || (rc < 0)) {
- fprintf(stderr, "error tidyParseBuffer: %i\n", rc);
- fprintf(stderr, "1:%s", errbuf.bp);
+ //fprintf(stderr, "error tidyParseBuffer: %i\n", rc);
+ //fprintf(stderr, "1:%s", errbuf.bp);
//return NULL;
}
rc = tidyCleanAndRepair(tdoc);
if ((rc > 1) || (rc < 0)) {
- fprintf(stderr, "error tidyCleanAndRepair: %i\n", rc);
- fprintf(stderr, "1:%s", errbuf.bp);
+ //fprintf(stderr, "error tidyCleanAndRepair: %i\n", rc);
+ //fprintf(stderr, "1:%s", errbuf.bp);
//return NULL;
}
rc = tidySaveBuffer(tdoc, &output);
if ((rc > 1) || (rc < 0)) {
- fprintf(stderr, "error tidySaveBuffer: %i\n", rc);
- fprintf(stderr, "1:%s", errbuf.bp);
+ //fprintf(stderr, "error tidySaveBuffer: %i\n", rc);
+ //fprintf(stderr, "1:%s", errbuf.bp);
}
String * result = String::stringWithUTF8Characters((const char *) output.bp);
diff --git a/src/core/basetypes/MCString.cc b/src/core/basetypes/MCString.cc
index 52fbbb1c..1ecceb39 100644
--- a/src/core/basetypes/MCString.cc
+++ b/src/core/basetypes/MCString.cc
@@ -1197,7 +1197,7 @@ unsigned int String::replaceOccurrencesOfString(String * occurrence, String * re
location = u_strstr(p, occurrence->unicodeCharacters());
if (location == NULL)
break;
- p = location + 1;
+ p = location + occurrence->length();
count ++;
}
@@ -1248,7 +1248,7 @@ void String::deleteCharactersInRange(Range range)
}
int32_t count = mLength - (int32_t) (range.location + range.length);
- u_memmove(&mUnicodeChars[range.location], &mUnicodeChars[range.location + range.length], count);
+ u_memmove(&mUnicodeChars[range.location], &mUnicodeChars[range.location + range.length], count + 1);
}
int String::locationOfString(String * occurrence)
@@ -1301,7 +1301,6 @@ static void charactersParsed(void * context,
}
String * modifiedString;
modifiedString = new String((const char *) ch, len);
- //modifiedString->replaceOccurrencesOfString(MCSTR("\r\n"), MCSTR(" "));
modifiedString->replaceOccurrencesOfString(MCSTR("\n"), MCSTR(" "));
modifiedString->replaceOccurrencesOfString(MCSTR("\r"), MCSTR(" "));
modifiedString->replaceOccurrencesOfString(MCSTR("\t"), MCSTR(" "));
@@ -1488,12 +1487,14 @@ static void elementStarted(void * ctx, const xmlChar * name, const xmlChar ** at
}
else if (strcasecmp((const char *) name, "a") == 0) {
AutoreleasePool * pool;
- String * link;
+ String * link = NULL;
HashMap * attributes;
pool = new AutoreleasePool();
attributes = dictionaryFromAttributes(atts);
- link = (String *) attributes->objectForKey(MCSTR("href"));
+ if (attributes != NULL) {
+ link = (String *) attributes->objectForKey(MCSTR("href"));
+ }
if (link == NULL)
link = MCSTR("");
@@ -1515,19 +1516,21 @@ static void elementStarted(void * ctx, const xmlChar * name, const xmlChar ** at
pool = new AutoreleasePool();
attributes = dictionaryFromAttributes(atts);
- style = (String *) attributes->objectForKey(MCSTR("style"));
- if (style != NULL) {
- if (style->locationOfString(MCSTR("margin: 0.0px 0.0px 0.0px 0.0px;")) != -1) {
- hasSpacing = false;
- }
- else if (style->locationOfString(MCSTR("margin: 0px 0px 0px 0px;")) != -1) {
- hasSpacing = false;
- }
- else if (style->locationOfString(MCSTR("margin: 0.0px;")) != -1) {
- hasSpacing = false;
- }
- else if (style->locationOfString(MCSTR("margin: 0px;")) != -1) {
- hasSpacing = false;
+ if (attributes != NULL) {
+ style = (String *) attributes->objectForKey(MCSTR("style"));
+ if (style != NULL) {
+ if (style->locationOfString(MCSTR("margin: 0.0px 0.0px 0.0px 0.0px;")) != -1) {
+ hasSpacing = false;
+ }
+ else if (style->locationOfString(MCSTR("margin: 0px 0px 0px 0px;")) != -1) {
+ hasSpacing = false;
+ }
+ else if (style->locationOfString(MCSTR("margin: 0.0px;")) != -1) {
+ hasSpacing = false;
+ }
+ else if (style->locationOfString(MCSTR("margin: 0px;")) != -1) {
+ hasSpacing = false;
+ }
}
}
pool->release();
@@ -1569,9 +1572,13 @@ static void elementStarted(void * ctx, const xmlChar * name, const xmlChar ** at
cite = false;
pool = new AutoreleasePool();
attributes = dictionaryFromAttributes(atts);
- type = (String *) attributes->objectForKey(MCSTR("type"));
- if (type->caseInsensitiveCompare(MCSTR("cite")) == 0) {
- cite = true;
+ if (attributes != NULL) {
+ type = (String *) attributes->objectForKey(MCSTR("type"));
+ if (type != NULL) {
+ if (type->caseInsensitiveCompare(MCSTR("cite")) == 0) {
+ cite = true;
+ }
+ }
}
pool->release();
diff --git a/src/core/renderer/MCHTMLRenderer.cpp b/src/core/renderer/MCHTMLRenderer.cpp
index d168cd8e..71454a0e 100644
--- a/src/core/renderer/MCHTMLRenderer.cpp
+++ b/src/core/renderer/MCHTMLRenderer.cpp
@@ -219,7 +219,10 @@ String * htmlForAbstractPart(AbstractPart * part, htmlRendererContext * context)
String * htmlForAbstractSinglePart(AbstractPart * part, htmlRendererContext * context)
{
- String * mimeType = part->mimeType()->lowercaseString();
+ String * mimeType = NULL;
+ if (part->mimeType() != NULL) {
+ mimeType = part->mimeType()->lowercaseString();
+ }
MCAssert(mimeType != NULL);
if (isTextPart(part, context)) {
diff --git a/src/core/renderer/MCRenderer.h b/src/core/renderer/MCRenderer.h
index a7b1993a..8495b329 100644
--- a/src/core/renderer/MCRenderer.h
+++ b/src/core/renderer/MCRenderer.h
@@ -11,5 +11,7 @@
#define __MAILCORE_MCRENDERER_H_
#include <MailCore/MCHTMLRendererCallback.h>
+#include <MailCore/MCDateFormatter.h>
+#include <MailCore/MCAddressDisplay.h>
#endif
diff --git a/src/core/rfc822/MCAttachment.cc b/src/core/rfc822/MCAttachment.cc
index 0874d300..c75e689a 100644
--- a/src/core/rfc822/MCAttachment.cc
+++ b/src/core/rfc822/MCAttachment.cc
@@ -482,7 +482,6 @@ Attachment * Attachment::attachmentWithSingleMIME(struct mailmime * mime)
content_id = single_fields.fld_id;
loc = single_fields.fld_location;
- MCLog("filename %s", filename);
if (filename != NULL) {
result->setFilename(String::stringByDecodingMIMEHeaderValue(filename));
}
diff --git a/src/core/rfc822/MCMessageParser.cc b/src/core/rfc822/MCMessageParser.cc
index 335ff43f..98982e93 100644
--- a/src/core/rfc822/MCMessageParser.cc
+++ b/src/core/rfc822/MCMessageParser.cc
@@ -14,6 +14,12 @@ MessageParser * MessageParser::messageParserWithData(Data * data)
return (MessageParser *) parser->autorelease();
}
+MessageParser * MessageParser::messageParserWithContentsOfFile(String * filename)
+{
+ Data * data = Data::dataWithContentsOfFile(filename);
+ return messageParserWithData(data);
+}
+
void MessageParser::init()
{
mData = NULL;
@@ -31,8 +37,6 @@ MessageParser::MessageParser(Data * data)
msg = data_message_init(data->bytes(), data->length());
mailmessage_get_bodystructure(msg, &mime);
mMainPart = (AbstractPart *) Attachment::attachmentsWithMIME(msg->msg_mime)->retain();
- MCLog("%s:%p ", MCUTF8(mMainPart->className()), mMainPart);
- MCLog("%s:%p ", MCUTF8(mMainPart->description()), mMainPart);
mMainPart->setMessage(this);
header()->importIMFFields(msg->msg_fields);
mailmessage_free(msg);
diff --git a/src/core/rfc822/MCMessageParser.h b/src/core/rfc822/MCMessageParser.h
index f5d043c5..4f13299d 100644
--- a/src/core/rfc822/MCMessageParser.h
+++ b/src/core/rfc822/MCMessageParser.h
@@ -15,6 +15,7 @@ namespace mailcore {
class MessageParser : public AbstractMessage {
public:
static MessageParser * messageParserWithData(Data * data);
+ static MessageParser * messageParserWithContentsOfFile(String * filename);
MessageParser(Data * data);
virtual ~MessageParser();