1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
|
/*
kmime_content.h
KMime, the KDE internet mail/usenet news message library.
Copyright (c) 2001 the KMime authors.
See file AUTHORS for details
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, US
*/
#ifndef __KMIME_CONTENT_H__
#define __KMIME_CONTENT_H__
//forward declarations
#if 0
class KMime::Headers::Base;
class KMime::Headers::Generic;
class KMime::Headers::ContentType;
class KMime::Headers::CTEncoding;
class KMime::Headers::CDisposition;
class KMime::Headers::List;
#endif
#include "kmime_util.h"
#include "kmime_headers.h"
#include <qtextstream.h>
namespace KMime {
/** Base class for messages in mime format
It contains all the enums, static functions
and parser-classes, that are needed for
mime handling */
class Base {
public:
//enums
enum articleType { ATmimeContent,
ATremote,
ATlocal };
};
/** This class encapsulates a mime-encoded content.
It parses the given data and creates a tree-like
structure, that represents the structure of the
message */
class KDE_EXPORT Content : public Base {
public:
typedef QPtrList<KMime::Content> List;
Content();
Content(const QCString &h, const QCString &b);
virtual ~Content();
//type
virtual articleType type() { return ATmimeContent; }
//content handling
bool hasContent() { return ( !h_ead.isEmpty() && (!b_ody.isEmpty() || (c_ontents && !c_ontents->isEmpty())) ); }
void setContent(QStrList *l);
void setContent(const QCString &s);
virtual void parse();
virtual void assemble();
virtual void clear();
//header access
QCString head() { return h_ead; }
// extracts and removes the next header from head. The caller has to delete the returned header;
Headers::Generic* getNextHeader(QCString &head);
virtual Headers::Base* getHeaderByType(const char *type);
virtual void setHeader(Headers::Base *h);
virtual bool removeHeader(const char *type);
bool hasHeader(const char *type) { return (getHeaderByType(type)!=0); }
Headers::ContentType* contentType(bool create=true) { Headers::ContentType *p=0; return getHeaderInstance(p, create); }
Headers::CTEncoding* contentTransferEncoding(bool create=true) { Headers::CTEncoding *p=0; return getHeaderInstance(p, create); }
Headers::CDisposition* contentDisposition(bool create=true) { Headers::CDisposition *p=0; return getHeaderInstance(p, create); }
Headers::CDescription* contentDescription(bool create=true) { Headers::CDescription *p=0; return getHeaderInstance(p, create); }
//content access
int size();
int storageSize();
int lineCount();
QCString body() { return b_ody; }
void setBody( const QCString & str ) { b_ody = str; }
QCString encodedContent(bool useCrLf=false);
QByteArray decodedContent();
void decodedText(QString &s, bool trimText=false,
bool removeTrailingNewlines=false);
void decodedText(QStringList &s, bool trimText=false,
bool removeTrailingNewlines=false);
void fromUnicodeString(const QString &s);
Content* textContent();
void attachments(List *dst, bool incAlternatives=false);
void addContent(Content *c, bool prepend=false);
void removeContent(Content *c, bool del=false);
void changeEncoding(Headers::contentEncoding e);
//saves the encoded content to the given textstream
// scrambleFromLines: replace "\nFrom " with "\n>From ", this is
// needed to avoid problem with mbox-files
void toStream(QTextStream &ts, bool scrambleFromLines=false);
// this charset is used for all headers and the body
// if the charset is not declared explictly
QCString defaultCharset() { return QCString(d_efaultCS); }
void setDefaultCharset(const QCString &cs);
// use the default charset even if a different charset is
// declared in the article
bool forceDefaultCS() { return f_orceDefaultCS; }
// enables/disables the force mode, housekeeping.
// works correctly only when the article is completely empty or
// completely loaded
virtual void setForceDefaultCS(bool b);
protected:
QCString rawHeader(const char *name);
bool decodeText();
template <class T> T* getHeaderInstance(T *ptr, bool create);
QCString h_ead,
b_ody;
List *c_ontents;
Headers::Base::List *h_eaders;
const char *d_efaultCS;
bool f_orceDefaultCS;
};
// some compilers (for instance Compaq C++) need template inline functions
// here rather than in the *.cpp file
template <class T> T* Content::getHeaderInstance(T *ptr, bool create)
{
T dummy; //needed to access virtual member T::type()
ptr=static_cast <T*> (getHeaderByType(dummy.type()));
if(!ptr && create) { //no such header found, but we need one => create it
ptr=new T(this);
if(!(h_eaders)) {
h_eaders=new Headers::Base::List();
h_eaders->setAutoDelete(true);
}
h_eaders->append(ptr);
}
return ptr;
}
} // namespace KMime
#endif // __KMIME_CONTENT_H__
|