mirror of
https://bitbucket.org/smil3y/kdelibs.git
synced 2025-02-23 18:32:49 +00:00
169 lines
5.3 KiB
C++
169 lines
5.3 KiB
C++
/* This file is part of the KDE libraries
|
|
Copyright (C) 1999 Lars Knoll (knoll@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 KCHARSETS_H
|
|
#define KCHARSETS_H
|
|
|
|
#include <kdecore_export.h>
|
|
#include <QtCore/QList>
|
|
|
|
class KCharsets;
|
|
class KCharsetsPrivate;
|
|
|
|
class QChar;
|
|
class QString;
|
|
class QStringList;
|
|
class QTextCodec;
|
|
|
|
namespace KGlobal
|
|
{
|
|
KDECORE_EXPORT KCharsets *charsets();
|
|
}
|
|
|
|
/**
|
|
* Charset font and encoder/decoder handling.
|
|
*
|
|
* This is needed, because Qt's encoding name matching in
|
|
* QTextCodec::codecForName matches only closely-related encoded names
|
|
* but not alternate names, e.g. found in the reality of the Internet.
|
|
*/
|
|
class KDECORE_EXPORT KCharsets
|
|
{
|
|
friend KCharsets *KGlobal::charsets();
|
|
|
|
protected:
|
|
/** Protected constructor. If you need the kcharsets object, use
|
|
KGlobal::charsets() instead.
|
|
*/
|
|
KCharsets();
|
|
|
|
public:
|
|
|
|
/**
|
|
* Destructor.
|
|
*/
|
|
virtual ~KCharsets();
|
|
|
|
/**
|
|
* Provided for compatibility.
|
|
* @param name the name of the codec
|
|
* @return the QTextCodec. If the desired codec could not be found,
|
|
* it returns a default (ISO 8859-1) codec
|
|
*/
|
|
QTextCodec *codecForName(const QString &name) const;
|
|
|
|
/**
|
|
* Tries to find a QTextCodec to convert the given encoding from and to
|
|
* Unicode.
|
|
*
|
|
* If no codec could be found, the ISO 8859-1 codec will be returned an
|
|
* and @p ok will be set to false.
|
|
*
|
|
* @param n the name of the codec
|
|
* @param ok true if a matching codec has been found, false if not
|
|
* @return the QTextCodec. If the desired codec could not be found,
|
|
* it returns a default (ISO 8859-1) codec
|
|
*/
|
|
QTextCodec *codecForName(const QString &n, bool &ok) const;
|
|
|
|
/**
|
|
* @brief Converts an entity to a character.
|
|
*
|
|
* The string must contain only the
|
|
* entity without the trailing ';'.
|
|
* @param str the entity
|
|
* @return QChar::Null if the entity could not be decoded.
|
|
*/
|
|
static QChar fromEntity(const QString &str);
|
|
|
|
/**
|
|
* Overloaded member function. Tries to find an entity in the
|
|
* QString str.
|
|
* @param str the string containing entified
|
|
* @param len is a return value, that gives the length of the decoded
|
|
* entity.
|
|
* @return a decoded entity if one could be found, QChar::null
|
|
* otherwise
|
|
*/
|
|
static QChar fromEntity(const QString &str, int &len);
|
|
|
|
/**
|
|
* Converts a QChar to an entity. The returned string does already
|
|
* contain the leading '&' and the trailing ';'.
|
|
* @param ch the char to convert
|
|
* @return the entity
|
|
*/
|
|
static QString toEntity(const QChar &ch);
|
|
|
|
/**
|
|
* Scans the given string for entities (like &amp;) and resolves them
|
|
* using fromEntity.
|
|
* @param text the string containing the entities
|
|
* @return the clean string
|
|
*/
|
|
static QString resolveEntities( const QString &text );
|
|
|
|
/**
|
|
* Lists all available encodings as names.
|
|
* @return the list of all encodings
|
|
*/
|
|
QStringList availableEncodingNames() const;
|
|
|
|
/**
|
|
* Lists the available encoding names together with a more descriptive language.
|
|
* @return the list of descriptive encoding names
|
|
*/
|
|
QStringList descriptiveEncodingNames() const;
|
|
|
|
/**
|
|
* Lists the available encoding names grouped by script (or language that uses them).
|
|
* @returns the list of lists consisting of description followed by encoding names (i.e. encodingsByScript().at(i).at(0) is a description for encodingsByScript().at(i).at(k), k>0)
|
|
*/
|
|
QList<QStringList> encodingsByScript() const;
|
|
|
|
/**
|
|
* @brief Returns a long description for an encoding name.
|
|
* @param encoding the encoding for the language
|
|
* @return the long description for the encoding
|
|
*/
|
|
QString descriptionForEncoding( const QString& encoding ) const;
|
|
|
|
/**
|
|
* Returns the encoding for a string obtained with descriptiveEncodingNames().
|
|
* @param descriptiveName the descriptive name for the encoding
|
|
* @return the name of the encoding
|
|
*/
|
|
QString encodingForName( const QString &descriptiveName ) const;
|
|
|
|
private:
|
|
KCharsetsPrivate* const d;
|
|
|
|
/**
|
|
* @brief Get the QTextCodec for the name or return NULL
|
|
*
|
|
* This function is similar to KCharsets::codecForName except that it
|
|
* can return a NULL value when the name was not found.
|
|
*
|
|
* @param n name of the text codec
|
|
* @return pointer to the QTextCodec or NULL
|
|
* @todo Make this function public when it is clear what API is needed.
|
|
*/
|
|
QTextCodec *codecForNameOrNull( const QByteArray& n ) const;
|
|
};
|
|
|
|
#endif
|