mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
| // Copyright 2011 The Go Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package strings
 | |
| 
 | |
| func (r *Replacer) Replacer() interface{} {
 | |
| 	return r.r
 | |
| }
 | |
| 
 | |
| func (r *Replacer) PrintTrie() string {
 | |
| 	gen := r.r.(*genericReplacer)
 | |
| 	return gen.printNode(&gen.root, 0)
 | |
| }
 | |
| 
 | |
| func (r *genericReplacer) printNode(t *trieNode, depth int) (s string) {
 | |
| 	if t.priority > 0 {
 | |
| 		s += "+"
 | |
| 	} else {
 | |
| 		s += "-"
 | |
| 	}
 | |
| 	s += "\n"
 | |
| 
 | |
| 	if t.prefix != "" {
 | |
| 		s += Repeat(".", depth) + t.prefix
 | |
| 		s += r.printNode(t.next, depth+len(t.prefix))
 | |
| 	} else if t.table != nil {
 | |
| 		for b, m := range r.mapping {
 | |
| 			if int(m) != r.tableSize && t.table[m] != nil {
 | |
| 				s += Repeat(".", depth) + string([]byte{byte(b)})
 | |
| 				s += r.printNode(t.table[m], depth+1)
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	return
 | |
| }
 | |
| 
 | |
| func StringFind(pattern, text string) int {
 | |
| 	return makeStringFinder(pattern).next(text)
 | |
| }
 | |
| 
 | |
| func DumpTables(pattern string) ([]int, []int) {
 | |
| 	finder := makeStringFinder(pattern)
 | |
| 	return finder.badCharSkip[:], finder.goodSuffixSkip
 | |
| }
 |