1
2
3
4
5
6
7 package lazyregexp
8
9 import (
10 "os"
11 "regexp"
12 "strings"
13 "sync"
14 )
15
16
17
18 type Regexp struct {
19 str string
20 once sync.Once
21 rx *regexp.Regexp
22 }
23
24 func (r *Regexp) re() *regexp.Regexp {
25 r.once.Do(r.build)
26 return r.rx
27 }
28
29 func (r *Regexp) build() {
30 r.rx = regexp.MustCompile(r.str)
31 r.str = ""
32 }
33
34 func (r *Regexp) FindSubmatch(s []byte) [][]byte {
35 return r.re().FindSubmatch(s)
36 }
37
38 func (r *Regexp) FindStringSubmatch(s string) []string {
39 return r.re().FindStringSubmatch(s)
40 }
41
42 func (r *Regexp) FindStringSubmatchIndex(s string) []int {
43 return r.re().FindStringSubmatchIndex(s)
44 }
45
46 func (r *Regexp) ReplaceAll(src, repl []byte) []byte {
47 return r.re().ReplaceAll(src, repl)
48 }
49
50 func (r *Regexp) ReplaceAllString(src, repl string) string {
51 return r.re().ReplaceAllString(src, repl)
52 }
53
54 func (r *Regexp) FindString(s string) string {
55 return r.re().FindString(s)
56 }
57
58 func (r *Regexp) FindAllString(s string, n int) []string {
59 return r.re().FindAllString(s, n)
60 }
61
62 func (r *Regexp) MatchString(s string) bool {
63 return r.re().MatchString(s)
64 }
65
66 func (r *Regexp) SubexpNames() []string {
67 return r.re().SubexpNames()
68 }
69
70 var inTest = len(os.Args) > 0 && strings.HasSuffix(strings.TrimSuffix(os.Args[0], ".exe"), ".test")
71
72
73
74
75 func New(str string) *Regexp {
76 lr := &Regexp{str: str}
77 if inTest {
78
79 lr.re()
80 }
81 return lr
82 }
83
View as plain text