X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Futil.cpp;h=a6acf5893c4913f4c4e45286510968695a75392c;hp=75f32f2ec60f528ca8b89b114b7b1a63da2bc7d3;hb=e50ae7a06fc4e5d3a911c361d30953410deab609;hpb=9fc57dc2c000e80fb8bd746a090e2e8210e1278e diff --git a/src/common/util.cpp b/src/common/util.cpp index 75f32f2e..a6acf589 100644 --- a/src/common/util.cpp +++ b/src/common/util.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 by the Quassel Project * + * Copyright (C) 2005-2015 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -29,6 +29,10 @@ class QMetaMethod; +// MIBenum values from http://www.iana.org/assignments/character-sets/character-sets.xml#table-character-sets-1 +static QList utf8DetectionBlacklist = QList() + << 39 /* ISO-2022-JP */; + QString nickFromMask(QString mask) { return mask.section('!', 0, 0); @@ -90,6 +94,9 @@ QString stripAcceleratorMarkers(const QString &label_) QString decodeString(const QByteArray &input, QTextCodec *codec) { + if (codec && utf8DetectionBlacklist.contains(codec->mibEnum())) + return codec->toUnicode(input); + // First, we check if it's utf8. It is very improbable to encounter a string that looks like // valid utf8, but in fact is not. This means that if the input string passes as valid utf8, it // is safe to assume that it is. @@ -114,8 +121,8 @@ QString decodeString(const QByteArray &input, QTextCodec *codec) //qDebug() << "Detected utf8:" << s; return s; } - //QTextCodec *codec = QTextCodec::codecForName(encoding.toAscii()); - if (!codec) return QString::fromAscii(input); + //QTextCodec *codec = QTextCodec::codecForName(encoding.toLatin1()); + if (!codec) return QString::fromLatin1(input); return codec->toUnicode(input); }