aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Document.cxx
diff options
context:
space:
mode:
authorNeil <nyamatongwe@gmail.com>2019-03-20 19:18:57 +1100
committerNeil <nyamatongwe@gmail.com>2019-03-20 19:18:57 +1100
commit31a735c8ec0a4f7c62b162cd1c173bfef76737c5 (patch)
treee7a3ad283f5b7c44d79cfbcdb78d8cdf34b68bf2 /src/Document.cxx
parent4ac748ba2238d3abd5227918d8174507d8fa3ec1 (diff)
downloadscintilla-mirror-31a735c8ec0a4f7c62b162cd1c173bfef76737c5.tar.gz
Backport: Implement WStringFromUTF8 to simplify code that creates wstring objects for
regular expressions and calling the Win32 API. Backport of changeset 7325:6148329fb2f3, but replaced std::string_view usage with const char* and size_t components. Also used #ifdef instead of C++17 `if constexpr` at suggestion of Neil.
Diffstat (limited to 'src/Document.cxx')
-rw-r--r--src/Document.cxx11
1 files changed, 2 insertions, 9 deletions
diff --git a/src/Document.cxx b/src/Document.cxx
index f1079398d..4aad2e370 100644
--- a/src/Document.cxx
+++ b/src/Document.cxx
@@ -3061,16 +3061,9 @@ Sci::Position Cxx11RegexFindText(const Document *doc, Sci::Position minPos, Sci:
bool matched = false;
if (SC_CP_UTF8 == doc->dbcsCodePage) {
- const size_t lenS = strlen(s);
- std::vector<wchar_t> ws(lenS + 1);
-#if WCHAR_T_IS_16
- const size_t outLen = UTF16FromUTF8(s, lenS, &ws[0], lenS);
-#else
- const size_t outLen = UTF32FromUTF8(s, lenS, reinterpret_cast<unsigned int *>(&ws[0]), lenS);
-#endif
- ws[outLen] = 0;
+ const std::wstring ws = WStringFromUTF8(s, strlen(s));
std::wregex regexp;
- regexp.assign(&ws[0], flagsRe);
+ regexp.assign(ws, flagsRe);
matched = MatchOnLines<UTF8Iterator>(doc, regexp, resr, search);
} else {