/* This file is part of libkcal. Copyright (c) 2002 Michael Brade <brade@kde.org> This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef KCAL_ATTACHMENT_H #define KCAL_ATTACHMENT_H #include "listbase.h" #include "libkcal_export.h" #include <tqstring.h> namespace KCal { /** This class represents information related to an attachment. */ class KDE_EXPORT Attachment { public: typedef ListBase<Attachment> List; /** Create a Reference to some URI by copying an existing Attachment. @param attachment the attachment to be duplicated */ Attachment( const Attachment &attachment ); /** Create a Reference to some URI. @param uri the uri this attachment refers to @param mime the mime type of the resource being linked to */ Attachment( const TQString &uri, const TQString &mime = TQString() ); /** Create a binary attachment. @param base64 the attachment in base64 format @param mime the mime type of the attachment */ Attachment( const char *base64, const TQString &mime = TQString() ); ~Attachment(); /* The VALUE parameter in iCal */ bool isUri() const; TQString uri() const; void setUri( const TQString &uri ); bool isBinary() const; char *data() const; void setData( const char *base64 ); void setDecodedData( const TQByteArray &data ); TQByteArray &decodedData(); uint size(); /* The optional FMTTYPE parameter in iCal */ TQString mimeType() const; void setMimeType( const TQString &mime ); /* The custom X-CONTENT-DISPOSITION parameter, used by OGo etc. */ bool showInline() const; void setShowInline( bool showinline ); /* The custom X-LABEL parameter to show a human-readable title */ TQString label() const; void setLabel( const TQString &label ); /** Sets the attachment "local" option, which is derived from the Calendar Incidence @b X-KONTACT-TYPE parameter. @param local is the flag to set (true) or unset (false) for the attachment "local" option. @see local() */ void setLocal( bool local ); /** Returns the attachment "local" flag. */ bool isLocal() const; private: TQByteArray mDataCache; uint mSize; TQString mMimeType; TQString mUri; char *mData; TQString mLabel; bool mBinary; bool mLocal; bool mShowInline; class Private; Private *d; }; } #endif