Server IP : 85.214.239.14 / Your IP : 3.148.108.244 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/2/cwd/proc/3/root/usr/share/doc/re2c/examples/go/submatch/ |
Upload File : |
// Code generated by re2c, DO NOT EDIT. //line "go/submatch/03_posix.re":1 //go:generate re2go $INPUT -o $OUTPUT package main import "reflect" // Maximum number of capturing groups among all rules. //line "go/submatch/03_posix.go":10 var YYMAXNMATCH int = 4 //line "go/submatch/03_posix.re":7 type SemVer struct { major, minor, patch int } func s2n(s string) int { // convert pre-parsed string to a number n := 0 for _, c := range s { n = n*10 + int(c-'0') } return n } func parse(str string) *SemVer { var cur, mar int // Allocate memory for capturing parentheses (twice the number of groups). yypmatch := make([]int, YYMAXNMATCH*2) var yynmatch int // Autogenerated tag variables used by the lexer to track tag values. //line "go/submatch/03_posix.go":32 var yyt1 int var yyt2 int var yyt3 int var yyt4 int var yyt5 int //line "go/submatch/03_posix.re":25 //line "go/submatch/03_posix.go":42 { var yych byte yych = str[cur] switch (yych) { case '0','1','2','3','4','5','6','7','8','9': yyt1 = cur goto yy3 default: goto yy1 } yy1: cur += 1 yy2: //line "go/submatch/03_posix.re":54 { return nil } //line "go/submatch/03_posix.go":58 yy3: cur += 1 mar = cur yych = str[cur] switch (yych) { case '.': goto yy4 case '0','1','2','3','4','5','6','7','8','9': goto yy6 default: goto yy2 } yy4: cur += 1 yych = str[cur] switch (yych) { case '0','1','2','3','4','5','6','7','8','9': yyt2 = cur goto yy7 default: goto yy5 } yy5: cur = mar goto yy2 yy6: cur += 1 yych = str[cur] switch (yych) { case '.': goto yy4 case '0','1','2','3','4','5','6','7','8','9': goto yy6 default: goto yy5 } yy7: cur += 1 yych = str[cur] switch (yych) { case 0x00: yyt3 = cur yyt4 = -1 yyt5 = -1 goto yy8 case '.': yyt3 = cur yyt5 = cur goto yy9 case '0','1','2','3','4','5','6','7','8','9': goto yy7 default: goto yy5 } yy8: cur += 1 yynmatch = 4 yypmatch[2] = yyt1 yypmatch[4] = yyt2 yypmatch[5] = yyt3 yypmatch[6] = yyt5 yypmatch[7] = yyt4 yypmatch[0] = yyt1 yypmatch[1] = cur yypmatch[3] = yyt2 yypmatch[3] += -1 //line "go/submatch/03_posix.re":41 { // `yynmatch` is the number of capturing groups if yynmatch != 4 { panic("expected 4 submatch groups") } // Even `yypmatch` values are for opening parentheses, odd values // are for closing parentheses, the first group is the whole match. major := s2n(str[yypmatch[2]:yypmatch[3]]) minor := s2n(str[yypmatch[4]:yypmatch[5]]) patch := 0 if yypmatch[6] != -1 { patch = s2n(str[yypmatch[6]+1:yypmatch[7]]) } return &SemVer{major, minor, patch} } //line "go/submatch/03_posix.go":139 yy9: cur += 1 yych = str[cur] if (yych <= 0x00) { goto yy5 } goto yy11 yy10: cur += 1 yych = str[cur] yy11: switch (yych) { case 0x00: yyt4 = cur goto yy8 case '0','1','2','3','4','5','6','7','8','9': goto yy10 default: goto yy5 } } //line "go/submatch/03_posix.re":55 } func main() { assert_eq := func(x, y *SemVer) { if !reflect.DeepEqual(x, y) { panic("error") } } assert_eq(parse("23.34\000"), &SemVer{23, 34, 0}) assert_eq(parse("1.2.9999\000"), &SemVer{1, 2, 9999}) assert_eq(parse("1.a\000"), nil) }