type regexp/syntax.Regexp
67 uses
regexp/syntax (current package)
compile.go#L71: func Compile(re *Regexp) (*Prog, error) {
compile.go#L89: func (c *compiler) compile(re *Regexp) frag {
parse.go#L128: stack []*Regexp // stack of parsed expressions
parse.go#L129: free *Regexp
parse.go#L136: height map[*Regexp]int // regexp height, for height limit check
parse.go#L137: size map[*Regexp]int64 // regexp compiled size, for size limit check
parse.go#L140: func (p *parser) newRegexp(op Op) *Regexp {
parse.go#L144: *re = Regexp{}
parse.go#L146: re = new(Regexp)
parse.go#L153: func (p *parser) reuse(re *Regexp) {
parse.go#L161: func (p *parser) checkLimits(re *Regexp) {
parse.go#L169: func (p *parser) checkSize(re *Regexp) {
parse.go#L200: p.size = make(map[*Regexp]int64)
parse.go#L211: func (p *parser) calcSize(re *Regexp, force bool) int64 {
parse.go#L259: func (p *parser) checkHeight(re *Regexp) {
parse.go#L264: p.height = make(map[*Regexp]int)
parse.go#L274: func (p *parser) calcHeight(re *Regexp, force bool) int {
parse.go#L294: func (p *parser) push(re *Regexp) *Regexp {
parse.go#L397: func (p *parser) op(op Op) *Regexp {
parse.go#L455: func repeatIsValid(re *Regexp, n int) bool {
parse.go#L480: func (p *parser) concat() *Regexp {
parse.go#L500: func (p *parser) alternate() *Regexp {
parse.go#L526: func cleanAlt(re *Regexp) {
parse.go#L552: func (p *parser) collapse(subs []*Regexp, op Op) *Regexp {
parse.go#L592: func (p *parser) factor(sub []*Regexp) []*Regexp {
parse.go#L671: var first *Regexp
parse.go#L678: var ifirst *Regexp
parse.go#L781: func (p *parser) leadingString(re *Regexp) ([]rune, Flags) {
parse.go#L793: func (p *parser) removeLeadingString(re *Regexp, n int) *Regexp {
parse.go#L830: func (p *parser) leadingRegexp(re *Regexp) *Regexp {
parse.go#L847: func (p *parser) removeLeadingRegexp(re *Regexp, reuse bool) *Regexp {
parse.go#L870: func literalRegexp(s string, flags Flags) *Regexp {
parse.go#L871: re := &Regexp{Op: OpLiteral}
parse.go#L890: func Parse(s string, flags Flags) (*Regexp, error) {
parse.go#L894: func parse(s string, flags Flags) (_ *Regexp, err error) {
parse.go#L1298: func isCharClass(re *Regexp) bool {
parse.go#L1306: func matchRune(re *Regexp, r rune) bool {
parse.go#L1343: func mergeCharClass(dst, src *Regexp) {
regexp.go#L17: type Regexp struct {
regexp.go#L20: Sub []*Regexp // subexpressions, if any
regexp.go#L21: Sub0 [1]*Regexp // storage for short Sub
regexp.go#L63: func (x *Regexp) Equal(y *Regexp) bool {
regexp.go#L116: func writeRegexp(b *strings.Builder, re *Regexp) {
regexp.go#L246: func (re *Regexp) String() string {
regexp.go#L293: func (re *Regexp) MaxCap() int {
regexp.go#L307: func (re *Regexp) CapNames() []string {
regexp.go#L313: func (re *Regexp) capNames(names []string) {
simplify.go#L14: func (re *Regexp) Simplify() *Regexp {
simplify.go#L26: nre = new(Regexp)
simplify.go#L45: return &Regexp{Op: OpEmptyMatch}
simplify.go#L64: nre := &Regexp{Op: OpConcat}
simplify.go#L85: var prefix *Regexp
simplify.go#L87: prefix = &Regexp{Op: OpConcat}
simplify.go#L98: nre2 := &Regexp{Op: OpConcat}
simplify.go#L113: return &Regexp{Op: OpNoMatch}
simplify.go#L134: func simplify1(op Op, flags Flags, sub, re *Regexp) *Regexp {
simplify.go#L148: re = &Regexp{Op: op, Flags: flags}
regexp
regexp.go#L274: func minInputLen(re *syntax.Regexp) int {
|
The pages are generated with Golds v0.6.7. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds. |