diff options
| author | Andrew Wilkins <axwalk@gmail.com> | 2016-03-15 05:36:43 +0000 |
|---|---|---|
| committer | Andrew Wilkins <axwalk@gmail.com> | 2016-03-15 05:36:43 +0000 |
| commit | 6436a4abd7a2f3a60b230453295dba199d8a59c3 (patch) | |
| tree | 125aef80fc2cf46c5d1758a8ece1fde14e7b13fd /llgo/third_party/gofrontend/libgo/go/regexp/exec.go | |
| parent | 36761bf92427846ce40fdd849615732c852e44dd (diff) | |
| download | bcm5719-llvm-6436a4abd7a2f3a60b230453295dba199d8a59c3.tar.gz bcm5719-llvm-6436a4abd7a2f3a60b230453295dba199d8a59c3.zip | |
[llgo] Roll gofrontend forward
Switch gofrontend to using go.googlesource.com, and
update to 81eb6a3f425b2158c67ee32c0cc973a72ce9d6be.
There are various changes required to update to the
go 1.5 runtime:
typemap.go is changed to accommodate the change in representation for equal/hash algorithms, and the removal of the zero value/type.
CMakeLists.txt is updated to add the build tree to the package search path, so internal packages, which are not installed, are found.
various files changes due to removal of __go_new_nopointers; the same change as in D11863, but with NoUnwindAttribute added to the added runtime functions which are called with "callOnly".
minor cleanups in ssa.go while investigating issues with unwinding/panic handling.
Differential Revisision: http://reviews.llvm.org/D15188
llvm-svn: 263536
Diffstat (limited to 'llgo/third_party/gofrontend/libgo/go/regexp/exec.go')
| -rw-r--r-- | llgo/third_party/gofrontend/libgo/go/regexp/exec.go | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/llgo/third_party/gofrontend/libgo/go/regexp/exec.go b/llgo/third_party/gofrontend/libgo/go/regexp/exec.go index c4cb201f642..518272092ae 100644 --- a/llgo/third_party/gofrontend/libgo/go/regexp/exec.go +++ b/llgo/third_party/gofrontend/libgo/go/regexp/exec.go @@ -35,13 +35,15 @@ type thread struct { // A machine holds all the state during an NFA simulation for p. type machine struct { - re *Regexp // corresponding Regexp - p *syntax.Prog // compiled program - op *onePassProg // compiled onepass program, or notOnePass - q0, q1 queue // two queues for runq, nextq - pool []*thread // pool of available threads - matched bool // whether a match was found - matchcap []int // capture information for the match + re *Regexp // corresponding Regexp + p *syntax.Prog // compiled program + op *onePassProg // compiled onepass program, or notOnePass + maxBitStateLen int // max length of string to search with bitstate + b *bitState // state for backtracker, allocated lazily + q0, q1 queue // two queues for runq, nextq + pool []*thread // pool of available threads + matched bool // whether a match was found + matchcap []int // capture information for the match // cached inputs, to avoid allocation inputBytes inputBytes @@ -76,6 +78,9 @@ func progMachine(p *syntax.Prog, op *onePassProg) *machine { if ncap < 2 { ncap = 2 } + if op == notOnePass { + m.maxBitStateLen = maxBitStateLen(p) + } m.matchcap = make([]int, ncap) return m } @@ -422,18 +427,29 @@ var empty = make([]int, 0) func (re *Regexp) doExecute(r io.RuneReader, b []byte, s string, pos int, ncap int) []int { m := re.get() var i input + var size int if r != nil { i = m.newInputReader(r) } else if b != nil { i = m.newInputBytes(b) + size = len(b) } else { i = m.newInputString(s) + size = len(s) } if m.op != notOnePass { if !m.onepass(i, pos) { re.put(m) return nil } + } else if size < m.maxBitStateLen && r == nil { + if m.b == nil { + m.b = newBitState(m.p) + } + if !m.backtrack(i, pos, size, ncap) { + re.put(m) + return nil + } } else { m.init(ncap) if !m.match(i, pos) { |

