From 0bae69b9cf1e27ca5548fc440785778b326fcc37 Mon Sep 17 00:00:00 2001 From: Silent Date: Sun, 14 Jan 2018 02:03:58 +0100 Subject: [PATCH] Refactor patterns to construct std::string_view earlier --- SilentPatch/Patterns.h | 34 +++++++++++++++------------------- 1 file changed, 15 insertions(+), 19 deletions(-) diff --git a/SilentPatch/Patterns.h b/SilentPatch/Patterns.h index 98823cf..059a809 100644 --- a/SilentPatch/Patterns.h +++ b/SilentPatch/Patterns.h @@ -112,25 +112,22 @@ namespace hook } public: - template - pattern(const char (&pattern)[Len]) + pattern(std::string_view pattern) : pattern(getRVA(0)) { - Initialize(std::string_view(pattern, Len-1)); + Initialize(std::move(pattern)); } - template - inline pattern(void* module, const char (&pattern)[Len]) + inline pattern(void* module, std::string_view pattern) : pattern(module) { - Initialize(std::string_view(pattern, Len-1)); + Initialize(std::move(pattern)); } - template - inline pattern(uintptr_t begin, uintptr_t end, const char (&pattern)[Len]) + inline pattern(uintptr_t begin, uintptr_t end, std::string_view pattern) : m_rangeStart(begin), m_rangeEnd(end) { - Initialize(std::string_view(pattern, Len-1)); + Initialize(std::move(pattern)); } inline pattern&& count(uint32_t expected) @@ -182,13 +179,14 @@ namespace hook } template - inline void for_each_result(Pred&& pred) + inline Pred for_each_result(Pred&& pred) { EnsureMatches(UINT32_MAX); for ( auto it : m_matches ) { std::forward(pred)(it); } + return std::forward(pred); } public: @@ -198,22 +196,20 @@ namespace hook #endif }; - template - pattern make_module_pattern(void* module, const char (&bytes)[Len]) + inline pattern make_module_pattern(void* module, std::string_view bytes) { - return pattern(module, bytes); + return pattern(module, std::move(bytes)); } - template - pattern make_range_pattern(uintptr_t begin, uintptr_t end, const char(&bytes)[Len]) + inline pattern make_range_pattern(uintptr_t begin, uintptr_t end, std::string_view bytes) { - return pattern(begin, end, bytes); + return pattern(begin, end, std::move(bytes)); } - template - auto get_pattern(const char(&pattern_string)[Len], ptrdiff_t offset = 0) + template + inline auto get_pattern(std::string_view pattern_string, ptrdiff_t offset = 0) { - return pattern(pattern_string).get_first(offset); + return pattern(std::move(pattern_string)).get_first(offset); } }