summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThiago Marcos P. Santos <thiago@mapbox.com>2017-01-20 15:51:16 +0100
committerThiago Marcos P. Santos <tmpsantos@gmail.com>2017-01-20 18:50:45 +0100
commit89dc01283f09a51ea6f7daa1eb38f75943c94594 (patch)
treed9ca58e3c20dc8dc3d74cf173d90a7534ec6dda6
parentfd9598779cf156c72bf43a0a73c4a7f0b0360176 (diff)
downloadqtlocation-mapboxgl-89dc01283f09a51ea6f7daa1eb38f75943c94594.tar.gz
[Qt] Fix build with WITH_QT_I18N=1
-rw-r--r--platform/qt/src/bidi.cpp12
1 files changed, 6 insertions, 6 deletions
diff --git a/platform/qt/src/bidi.cpp b/platform/qt/src/bidi.cpp
index 0eaeb3f2f4..b75d038d6b 100644
--- a/platform/qt/src/bidi.cpp
+++ b/platform/qt/src/bidi.cpp
@@ -12,12 +12,11 @@ public:
};
std::u16string applyArabicShaping(const std::u16string& input) {
- QString utf16string = QString::fromStdU16String(input);
- return utf16string.toStdU16String();
+ return input;
}
void BiDi::mergeParagraphLineBreaks(std::set<std::size_t>& lineBreakPoints) {
- lineBreakPoints.insert(static_cast<std::size_t>(bidi.impl->string.length()));
+ lineBreakPoints.insert(static_cast<std::size_t>(impl->string.length()));
}
std::vector<std::u16string>
@@ -27,7 +26,7 @@ BiDi::applyLineBreaking(std::set<std::size_t> lineBreakPoints) {
std::vector<std::u16string> transformedLines;
std::size_t start = 0;
for (std::size_t lineBreakPoint : lineBreakPoints) {
- transformedLines.push_back(bidi.getLine(start, lineBreakPoint));
+ transformedLines.push_back(getLine(start, lineBreakPoint));
start = lineBreakPoint;
}
@@ -41,12 +40,13 @@ BiDi::BiDi() : impl(std::make_unique<BiDiImpl>())
BiDi::~BiDi() = default;
std::vector<std::u16string> BiDi::processText(const std::u16string& input, std::set<std::size_t> lineBreakPoints) {
- impl->string = QString::fromStdU16String(input);
+ impl->string = QString::fromUtf16(reinterpret_cast<const ushort*>(input.data()), int(input.size()));
return applyLineBreaking(lineBreakPoints);
}
std::u16string BiDi::getLine(std::size_t start, std::size_t end) {
- return impl->string.mid(static_cast<int32_t>(start), static_cast<int32_t>(end - start)).toStdU16String();
+ auto utf16 = impl->string.mid(static_cast<int32_t>(start), static_cast<int32_t>(end - start));
+ return std::u16string(reinterpret_cast<const char16_t*>(utf16.utf16()), utf16.length());
}
} // end namespace mbgl