diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/deprecated/kmp/kmp.cpp | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/deprecated/kmp/kmp.cpp')
-rw-r--r-- | library/cpp/deprecated/kmp/kmp.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/library/cpp/deprecated/kmp/kmp.cpp b/library/cpp/deprecated/kmp/kmp.cpp new file mode 100644 index 00000000000..d02074c94ae --- /dev/null +++ b/library/cpp/deprecated/kmp/kmp.cpp @@ -0,0 +1,21 @@ +#include "kmp.h" + +#include <util/generic/yexception.h> + +TKMPMatcher::TKMPMatcher(const char* patternBegin, const char* patternEnd) + : Pattern(patternBegin, patternEnd) +{ + ComputePrefixFunction(); +} + +TKMPMatcher::TKMPMatcher(const TString& pattern) + : Pattern(pattern) +{ + ComputePrefixFunction(); +} + +void TKMPMatcher::ComputePrefixFunction() { + ssize_t* pf; + ::ComputePrefixFunction(Pattern.data(), Pattern.data() + Pattern.size(), &pf); + PrefixFunction.Reset(pf); +} |