summaryrefslogtreecommitdiffstats
path: root/korn/mailsubject.h
diff options
context:
space:
mode:
Diffstat (limited to 'korn/mailsubject.h')
-rw-r--r--korn/mailsubject.h187
1 files changed, 187 insertions, 0 deletions
diff --git a/korn/mailsubject.h b/korn/mailsubject.h
new file mode 100644
index 000000000..f3e2e4577
--- /dev/null
+++ b/korn/mailsubject.h
@@ -0,0 +1,187 @@
+#ifndef MailSubject_h
+#define MailSubject_h
+
+class QTextCodec;
+
+class KMailDrop;
+
+#include "mailid.h"
+
+
+
+/**
+ * A KornMailSubject instance represents a single mail. It stores
+ * its id, sender, subject, header, size and date and possibly its
+ * mail body
+ */
+class KornMailSubject
+{
+ KornMailId * _id;
+ KMailDrop * _drop;
+ QString _subject;
+ QString _sender;
+ QString _header;
+ int _size;
+ int _date;
+ bool _fullMessage;
+public:
+ /**
+ * KornMailSubject default constructor
+ */
+ KornMailSubject();
+
+ /**
+ * KornMailSubject constructor
+ * @param id id of the mail. The KornMailId instance should
+ * not be touched or deleted afterwards. It is destroyed by
+ * KornMailSubject's destructor.
+ * @param drop The KMailDrop.
+ */
+ KornMailSubject(KornMailId * id, KMailDrop * drop);
+
+ /**
+ * KornMailSubject copy constructor. All data of the source
+ * KornMailSubject instance are cloned.
+ * @param src KornMailSubject to copy from
+ */
+ KornMailSubject(const KornMailSubject & src);
+
+ /**
+ * replaces the contents of this by the contents of another
+ * KornMailSubject instance. All data of the source
+ * KornMailSubject instance are cloned.
+ * @param src KornMailSubject to copy from
+ */
+ KornMailSubject & operator= (const KornMailSubject & src);
+
+ /**
+ * KornMailSubject destructor
+ */
+ virtual ~KornMailSubject();
+
+ /**
+ * Return the mail id.
+ * @return the mail id.
+ */
+ const KornMailId * getId() const {return _id;}
+
+ /**
+ * Set the mails subject.
+ * @param subject the mails subject.
+ */
+ void setSubject(const QString & subject) {_subject = subject;}
+
+ /**
+ * Return the subject.
+ * @return the subject.
+ */
+ const QString & getSubject() const {return _subject;}
+
+ /**
+ * Set the mails sender.
+ * @param sender the mails sender.
+ */
+ void setSender(const QString & sender) {_sender = sender;}
+
+ /**
+ * Return the sender.
+ * @return the sender.
+ */
+ const QString & getSender() const {return _sender;}
+
+ /**
+ * Set the mails header and (if possible) body.
+ * @param header the mails header with or without body (see fullMessage parameter).
+ * @param fullMessage true, if header contains the message body as well, false otherwise.
+ */
+ void setHeader(const QString & header, bool fullMessage) {_header = header; _fullMessage = fullMessage;}
+
+ /**
+ * Return the header or the full message (if isHeaderFullMessage() is true).
+ * @return the header or the full message.
+ */
+ const QString & getHeader() const {return _header;}
+
+ /**
+ * Return true, if the header contains the header and the full message.
+ * Return false if the header just contains the header.
+ * @return see above.
+ */
+ bool isHeaderFullMessage() const {return _fullMessage;}
+
+ /**
+ * Set the size of the full mail.
+ * @param the mails full size.
+ */
+ void setSize(int size) {_size = size;}
+
+ /**
+ * Return the size of the full mail.
+ * @return the size of the full mail.
+ */
+ int getSize() const {return _size;}
+
+ /**
+ * Set the mails date in seconds since 1970-01-01 00:00:00.
+ * @param date the mails date.
+ */
+ void setDate(int date) {_date = date;}
+
+ /**
+ * Return the mails date in seconds since 1970-01-01 00:00:00.
+ * @return the mails date.
+ */
+ int getDate() const {return _date;}
+
+ /**
+ * Return a string representation of this (for debugging purposes only)
+ * @return a string representation
+ */
+ QString toString() const;
+
+ /**
+ * Sets the KMailDrop field.
+ * @param drop The KMailDrop-object
+ */
+ void setMailDrop( KMailDrop* drop ) { _drop = drop; }
+
+ /**
+ * Returns the KMailDrop instance of the Maildrop which owns the subject
+ */
+ KMailDrop* getMailDrop() const { return _drop; }
+
+ /**
+ * decodes headers using decodeRFC2047String
+ */
+ void decodeHeaders();
+
+private:
+
+ /**
+ * Decode a string based on RFC2047
+ */
+ QString decodeRFC2047String(const QCString& aStr);
+
+ /**
+ * Unfolding a string (basically changing tabs to spaces
+ */
+ QCString unfold( const QCString & header );
+
+ /**
+ * Returns true if the parameter is a blank (or tab)
+ *
+ * Note from KMail's code, where this function is taken from:
+ * don't rely on isblank(), which is a GNU extension in
+ * <cctype>. But if someone wants to write a configure test for
+ * isblank(), we can then rename this function to isblank and #ifdef
+ * it's definition...
+ */
+ inline bool isBlank( char ch ) { return ch == ' ' || ch == '\t' ; }
+
+ /**
+ * ??
+ */
+ const QTextCodec* codecForName(const QCString& _str);
+};
+
+#endif