summaryrefslogtreecommitdiffstats
path: root/src/testdir/test_bench_regexp.vim
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 08:50:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 08:50:31 +0000
commitaed8ce9da277f5ecffe968b324f242c41c3b752a (patch)
treed2e538394cb7a8a7c42a4aac6ccf1a8e3256999b /src/testdir/test_bench_regexp.vim
parentInitial commit. (diff)
downloadvim-aed8ce9da277f5ecffe968b324f242c41c3b752a.tar.xz
vim-aed8ce9da277f5ecffe968b324f242c41c3b752a.zip
Adding upstream version 2:9.0.1378.upstream/2%9.0.1378upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/testdir/test_bench_regexp.vim24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/testdir/test_bench_regexp.vim b/src/testdir/test_bench_regexp.vim
new file mode 100644
index 0000000..eb9f5f8
--- /dev/null
+++ b/src/testdir/test_bench_regexp.vim
@@ -0,0 +1,24 @@
+" Test for benchmarking the RE engine
+
+source check.vim
+CheckFeature reltime
+
+func Measure(file, pattern, arg)
+ for re in range(3)
+ let sstart = reltime()
+ let before = ['set re=' .. re]
+ let after = ['call search("' .. escape(a:pattern, '\\') .. '", "", "", 10000)']
+ let after += ['quit!']
+ let args = empty(a:arg) ? '' : a:arg .. ' ' .. a:file
+ call RunVim(before, after, args)
+ let s = 'file: ' .. a:file .. ', re: ' .. re ..
+ \ ', time: ' .. reltimestr(reltime(sstart))
+ call writefile([s], 'benchmark.out', "a")
+ endfor
+endfunc
+
+func Test_Regex_Benchmark()
+ call Measure('samples/re.freeze.txt', '\s\+\%#\@<!$', '+5')
+endfunc
+
+" vim: shiftwidth=2 sts=2 expandtab