summaryrefslogtreecommitdiffstats
path: root/examples
diff options
context:
space:
mode:
Diffstat (limited to 'examples')
-rw-r--r--examples/widgets/richtext/textedit/textedit.cpp18
1 files changed, 8 insertions, 10 deletions
diff --git a/examples/widgets/richtext/textedit/textedit.cpp b/examples/widgets/richtext/textedit/textedit.cpp
index 9b5425240d..945869c88c 100644
--- a/examples/widgets/richtext/textedit/textedit.cpp
+++ b/examples/widgets/richtext/textedit/textedit.cpp
@@ -60,7 +60,6 @@
#include <QFontDatabase>
#include <QMenu>
#include <QMenuBar>
-#include <QTextCodec>
#include <QTextEdit>
#include <QStatusBar>
#include <QToolBar>
@@ -417,20 +416,19 @@ bool TextEdit::load(const QString &f)
return false;
QByteArray data = file.readAll();
- QTextCodec *codec = Qt::codecForHtml(data);
- QString str = codec->toUnicode(data);
- if (Qt::mightBeRichText(str)) {
+ QMimeDatabase db;
+ if (db.mimeTypeForFileNameAndData(f, data).name() == QLatin1String("text/html")) {
+ auto encoding = QStringDecoder::encodingForHtml(data.constData(), data.size());
+ QString str = QStringDecoder(encoding ? *encoding : QStringDecoder::Utf8)(data);
QUrl baseUrl = (f.front() == QLatin1Char(':') ? QUrl(f) : QUrl::fromLocalFile(f)).adjusted(QUrl::RemoveFilename);
textEdit->document()->setBaseUrl(baseUrl);
textEdit->setHtml(str);
- } else {
#if QT_CONFIG(textmarkdownreader)
- QMimeDatabase db;
- if (db.mimeTypeForFileNameAndData(f, data).name() == QLatin1String("text/markdown"))
- textEdit->setMarkdown(QString::fromUtf8(data));
- else
+ } else if (db.mimeTypeForFileNameAndData(f, data).name() == QLatin1String("text/markdown")) {
+ textEdit->setMarkdown(QString::fromUtf8(data));
#endif
- textEdit->setPlainText(QString::fromUtf8(data));
+ } else {
+ textEdit->setPlainText(QString::fromUtf8(data));
}
setCurrentFileName(f);