/* -*- c++ -*- attachmentstrategy.cpp This file is part of KMail, the KDE mail client. Copyright (c) 2003 Marc Mutz KMail is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License, version 2, as published by the Free Software Foundation. KMail 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 General Public License for more details. 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 USA In addition, as a special exception, the copyright holders give permission to link the code of this program with any edition of the TQt library by Trolltech AS, Norway (or with modified versions of TQt that use the same license as TQt), and distribute linked combinations including the two. You must obey the GNU General Public License in all respects for all of the code used other than TQt. If you modify this file, you may extend this exception to your version of the file, but you are not obligated to do so. If you do not wish to do so, delete this exception statement from your version. */ #ifdef HAVE_CONFIG_H #include #endif #include "attachmentstrategy.h" #include "partNode.h" #include "kmmsgpart.h" #include #include namespace KMail { static AttachmentStrategy::Display smartDisplay( const partNode *node ) { if ( node->hasContentDispositionInline() ) // explict "inline" disposition: return AttachmentStrategy::Inline; if ( node->isAttachment() ) // explicit "attachment" disposition: return AttachmentStrategy::AsIcon; if ( node->type() == DwMime::kTypeText && node->msgPart().fileName().stripWhiteSpace().isEmpty() && node->msgPart().name().stripWhiteSpace().isEmpty() ) // text/* w/o filename parameter: return AttachmentStrategy::Inline; return AttachmentStrategy::AsIcon; } // // IconicAttachmentStrategy: // show everything but the first text/plain body as icons // class IconicAttachmentStrategy : public AttachmentStrategy { friend class ::KMail::AttachmentStrategy; protected: IconicAttachmentStrategy() : AttachmentStrategy() {} virtual ~IconicAttachmentStrategy() {} public: const char * name() const { return "iconic"; } const AttachmentStrategy * next() const { return smart(); } const AttachmentStrategy * prev() const { return headerOnly(); } bool inlineNestedMessages() const { return false; } Display defaultDisplay( const partNode * ) const { return AsIcon; } }; // // SmartAttachmentStrategy: // in addition to Iconic, show all body parts // with content-disposition == "inline" and // all text parts without a filename or name parameter inline // class SmartAttachmentStrategy : public AttachmentStrategy { friend class ::KMail::AttachmentStrategy; protected: SmartAttachmentStrategy() : AttachmentStrategy() {} virtual ~SmartAttachmentStrategy() {} public: const char * name() const { return "smart"; } const AttachmentStrategy * next() const { return inlined(); } const AttachmentStrategy * prev() const { return iconic(); } bool inlineNestedMessages() const { return true; } Display defaultDisplay( const partNode * node ) const { return smartDisplay( node ); } }; // // InlinedAttachmentStrategy: // show everything possible inline // class InlinedAttachmentStrategy : public AttachmentStrategy { friend class ::KMail::AttachmentStrategy; protected: InlinedAttachmentStrategy() : AttachmentStrategy() {} virtual ~InlinedAttachmentStrategy() {} public: const char * name() const { return "inlined"; } const AttachmentStrategy * next() const { return hidden(); } const AttachmentStrategy * prev() const { return smart(); } bool inlineNestedMessages() const { return true; } Display defaultDisplay( const partNode * ) const { return Inline; } }; // // HiddenAttachmentStrategy // show nothing except the first text/plain body part _at all_ // class HiddenAttachmentStrategy : public AttachmentStrategy { friend class ::KMail::AttachmentStrategy; protected: HiddenAttachmentStrategy() : AttachmentStrategy() {} virtual ~HiddenAttachmentStrategy() {} public: const char * name() const { return "hidden"; } const AttachmentStrategy * next() const { return headerOnly(); } const AttachmentStrategy * prev() const { return inlined(); } bool inlineNestedMessages() const { return false; } Display defaultDisplay( const partNode * ) const { return None; } }; class HeaderOnlyAttachmentStrategy : public AttachmentStrategy { friend class ::KMail::AttachmentStrategy; protected: HeaderOnlyAttachmentStrategy() : AttachmentStrategy() {} virtual ~HeaderOnlyAttachmentStrategy() {} public: const char * name() const { return "headerOnly"; } const AttachmentStrategy * next() const { return iconic(); } const AttachmentStrategy * prev() const { return hidden(); } bool inlineNestedMessages() const { return true; } Display defaultDisplay( const partNode *node ) const { if ( node->isInEncapsulatedMessage() ) { return smartDisplay( node ); } partNode::AttachmentDisplayInfo info = node->attachmentDisplayInfo(); if ( info.displayInHeader ) { // The entire point about this attachment strategy: Hide attachments in the body that are // already displayed in the attachment quick list return None; } else { return smartDisplay( node ); } } }; // // AttachmentStrategy abstract base: // AttachmentStrategy::AttachmentStrategy() { } AttachmentStrategy::~AttachmentStrategy() { } const AttachmentStrategy * AttachmentStrategy::create( Type type ) { switch ( type ) { case Iconic: return iconic(); case Smart: return smart(); case Inlined: return inlined(); case Hidden: return hidden(); case HeaderOnly: return headerOnly(); } kdFatal( 5006 ) << "AttachmentStrategy::create(): Unknown attachment startegy ( type == " << (int)type << " ) requested!" << endl; return 0; // make compiler happy } const AttachmentStrategy * AttachmentStrategy::create( const TQString & type ) { TQString lowerType = type.lower(); if ( lowerType == "iconic" ) return iconic(); //if ( lowerType == "smart" ) return smart(); // not needed, see below if ( lowerType == "inlined" ) return inlined(); if ( lowerType == "hidden" ) return hidden(); if ( lowerType == "headeronly" ) return headerOnly(); // don't kdFatal here, b/c the strings are user-provided // (KConfig), so fail gracefully to the default: return smart(); } static const AttachmentStrategy * iconicStrategy = 0; static const AttachmentStrategy * smartStrategy = 0; static const AttachmentStrategy * inlinedStrategy = 0; static const AttachmentStrategy * hiddenStrategy = 0; static const AttachmentStrategy * headerOnlyStrategy = 0; const AttachmentStrategy * AttachmentStrategy::iconic() { if ( !iconicStrategy ) iconicStrategy = new IconicAttachmentStrategy(); return iconicStrategy; } const AttachmentStrategy * AttachmentStrategy::smart() { if ( !smartStrategy ) smartStrategy = new SmartAttachmentStrategy(); return smartStrategy; } const AttachmentStrategy * AttachmentStrategy::inlined() { if ( !inlinedStrategy ) inlinedStrategy = new InlinedAttachmentStrategy(); return inlinedStrategy; } const AttachmentStrategy * AttachmentStrategy::hidden() { if ( !hiddenStrategy ) hiddenStrategy = new HiddenAttachmentStrategy(); return hiddenStrategy; } const AttachmentStrategy * AttachmentStrategy::headerOnly() { if ( !headerOnlyStrategy ) headerOnlyStrategy = new HeaderOnlyAttachmentStrategy(); return headerOnlyStrategy; } } // namespace KMail