You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
5.0 KiB
136 lines
5.0 KiB
/******************************************************************************* |
|
** |
|
** Filename : util |
|
** Created on : 03 April, 2005 |
|
** Copyright : (c) 2005 Till Adam |
|
** Email : <adam@kde.org> |
|
** |
|
*******************************************************************************/ |
|
|
|
/******************************************************************************* |
|
** |
|
** 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. |
|
** |
|
** It 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 Qt library by Trolltech AS, Norway (or with modified versions |
|
** of Qt that use the same license as Qt), 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 |
|
** Qt. 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. |
|
** |
|
*******************************************************************************/ |
|
#ifndef KMAILUTIL_H |
|
#define KMAILUTIL_H |
|
|
|
#include <stdlib.h> |
|
#include <QObject> |
|
#include <QByteArray> |
|
#include <QWidget> |
|
#include <kio/netaccess.h> |
|
#include <kmessagebox.h> |
|
#include <klocale.h> |
|
#include <akonadi/item.h> |
|
#include "kmkernel.h" |
|
#include <kmime/kmime_message.h> |
|
class KUrl; |
|
|
|
class OrgKdeAkonadiImapSettingsInterface; |
|
|
|
#define IMAP_RESOURCE_IDENTIFIER "akonadi_imap_resource" |
|
|
|
namespace KMail |
|
{ |
|
/** |
|
* The Util namespace contains a collection of helper functions use in |
|
* various places. |
|
*/ |
|
namespace Util { |
|
|
|
/** |
|
* First disconnect then reconnect a sender/signal-receiver/slot pair. |
|
* This improves readability of code a bit by reducing two (maybe long and complex) lines |
|
* to one and often helps in avoiding a pair of brackets. |
|
*/ |
|
void reconnectSignalSlotPair( QObject *src, const char *signal, QObject *dst, const char *slot ); |
|
|
|
// return true if we should proceed, false if we should abort |
|
bool checkOverwrite( const KUrl &url, QWidget *w ); |
|
|
|
/** Test if all required settings are set. |
|
Reports problems to user via dialogs and returns false. |
|
Returns true if everything is Ok. */ |
|
bool checkTransport( QWidget *w ); |
|
|
|
/** |
|
* Convert all sequences of "\r\n" (carriage return followed by a line |
|
* feed) to a single "\n" (line feed). The conversion happens in place. |
|
* Returns the length of the resulting string. |
|
* @param str The string to convert. |
|
* @param strLen The length of the string to convert. |
|
* @return The new length of the converted string. |
|
*/ |
|
size_t crlf2lf( char* str, const size_t strLen ); |
|
|
|
|
|
/** |
|
* Delegates opening a URL to the Max OSX mechanisms for that. |
|
* Returns false if it did nothing (such as on other platforms. |
|
*/ |
|
bool handleUrlOnMac( const KUrl& url ); |
|
|
|
/** |
|
* Convert "\n" line endings to "\r\n". |
|
* @param src The source string to convert. |
|
* @return The result string. |
|
*/ |
|
QByteArray lf2crlf( const QByteArray & src ); |
|
|
|
/** |
|
* Validates a list of email addresses. |
|
* @return true if all addresses are valid. |
|
* @return false if one or several addresses are invalid. |
|
*/ |
|
bool validateAddresses( QWidget *parent, const QString &addresses ); |
|
|
|
KMime::Message::Ptr message( const Akonadi::Item & item ); |
|
|
|
/** Convert all non-ascii characters to question marks |
|
* If ok is non-null, *ok will be set to true if all characters |
|
* where ascii, *ok will be set to false otherwise */ |
|
QByteArray toUsAscii(const QString& _str, bool *ok=0); |
|
|
|
|
|
/** Return a QTextCodec for the specified charset. |
|
* This function is a bit more tolerant, than QTextCodec::codecForName */ |
|
const QTextCodec* codecForName(const QByteArray& _str); |
|
|
|
|
|
/** |
|
* Find out preferred charset for 'text'. |
|
* First @p encoding is tried and if that one is not suitable, |
|
* the encodings in @p encodingList are tried. |
|
*/ |
|
QByteArray autoDetectCharset(const QByteArray &encoding, const QStringList &encodingList, const QString &text); |
|
|
|
KUrl findSieveUrlForAccount( OrgKdeAkonadiImapSettingsInterface *a, const QString &ident); |
|
OrgKdeAkonadiImapSettingsInterface *createImapSettingsInterface( const QString &ident ); |
|
} |
|
} |
|
|
|
#endif
|
|
|