| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688 | package urnimport (	"fmt")var (	errPrefix         = "expecting the prefix to be the \"urn\" string (whatever case) [col %d]"	errIdentifier     = "expecting the identifier to be string (1..31 alnum chars, also containing dashes but not at its start) [col %d]"	errSpecificString = "expecting the specific string to be a string containing alnum, hex, or others ([()+,-.:=@;$_!*']) chars [col %d]"	errNoUrnWithinID  = "expecting the identifier to not contain the \"urn\" reserved string [col %d]"	errHex            = "expecting the specific string hex chars to be well-formed (%%alnum{2}) [col %d]"	errParse          = "parsing error [col %d]")const start int = 1const firstFinal int = 44const enFail int = 46const enMain int = 1// Machine is the interface representing the FSMtype Machine interface {	Error() error	Parse(input []byte) (*URN, error)}type machine struct {	data           []byte	cs             int	p, pe, eof, pb int	err            error	tolower        []int}// NewMachine creates a new FSM able to parse RFC 2141 strings.func NewMachine() Machine {	m := &machine{}	return m}// Err returns the error that occurred on the last call to Parse.//// If the result is nil, then the line was parsed successfully.func (m *machine) Error() error {	return m.err}func (m *machine) text() []byte {	return m.data[m.pb:m.p]}// Parse parses the input byte array as a RFC 2141 string.func (m *machine) Parse(input []byte) (*URN, error) {	m.data = input	m.p = 0	m.pb = 0	m.pe = len(input)	m.eof = len(input)	m.err = nil	m.tolower = []int{}	output := &URN{}	{		m.cs = start	}	{		if (m.p) == (m.pe) {			goto _testEof		}		switch m.cs {		case 1:			goto stCase1		case 0:			goto stCase0		case 2:			goto stCase2		case 3:			goto stCase3		case 4:			goto stCase4		case 5:			goto stCase5		case 6:			goto stCase6		case 7:			goto stCase7		case 8:			goto stCase8		case 9:			goto stCase9		case 10:			goto stCase10		case 11:			goto stCase11		case 12:			goto stCase12		case 13:			goto stCase13		case 14:			goto stCase14		case 15:			goto stCase15		case 16:			goto stCase16		case 17:			goto stCase17		case 18:			goto stCase18		case 19:			goto stCase19		case 20:			goto stCase20		case 21:			goto stCase21		case 22:			goto stCase22		case 23:			goto stCase23		case 24:			goto stCase24		case 25:			goto stCase25		case 26:			goto stCase26		case 27:			goto stCase27		case 28:			goto stCase28		case 29:			goto stCase29		case 30:			goto stCase30		case 31:			goto stCase31		case 32:			goto stCase32		case 33:			goto stCase33		case 34:			goto stCase34		case 35:			goto stCase35		case 36:			goto stCase36		case 37:			goto stCase37		case 38:			goto stCase38		case 44:			goto stCase44		case 39:			goto stCase39		case 40:			goto stCase40		case 45:			goto stCase45		case 41:			goto stCase41		case 42:			goto stCase42		case 43:			goto stCase43		case 46:			goto stCase46		}		goto stOut	stCase1:		switch (m.data)[(m.p)] {		case 85:			goto tr1		case 117:			goto tr1		}		goto tr0	tr0:		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr3:		m.err = fmt.Errorf(errPrefix, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr6:		m.err = fmt.Errorf(errIdentifier, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr41:		m.err = fmt.Errorf(errSpecificString, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr44:		m.err = fmt.Errorf(errHex, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errSpecificString, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr50:		m.err = fmt.Errorf(errPrefix, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errIdentifier, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	tr52:		m.err = fmt.Errorf(errNoUrnWithinID, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errIdentifier, m.p)		(m.p)--		{			goto st46		}		m.err = fmt.Errorf(errParse, m.p)		(m.p)--		{			goto st46		}		goto st0	stCase0:	st0:		m.cs = 0		goto _out	tr1:		m.pb = m.p		goto st2	st2:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof2		}	stCase2:		switch (m.data)[(m.p)] {		case 82:			goto st3		case 114:			goto st3		}		goto tr0	st3:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof3		}	stCase3:		switch (m.data)[(m.p)] {		case 78:			goto st4		case 110:			goto st4		}		goto tr3	st4:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof4		}	stCase4:		if (m.data)[(m.p)] == 58 {			goto tr5		}		goto tr0	tr5:		output.prefix = string(m.text())		goto st5	st5:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof5		}	stCase5:		switch (m.data)[(m.p)] {		case 85:			goto tr8		case 117:			goto tr8		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto tr7			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto tr7			}		default:			goto tr7		}		goto tr6	tr7:		m.pb = m.p		goto st6	st6:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof6		}	stCase6:		switch (m.data)[(m.p)] {		case 45:			goto st7		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st7			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st7			}		default:			goto st7		}		goto tr6	st7:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof7		}	stCase7:		switch (m.data)[(m.p)] {		case 45:			goto st8		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st8			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st8			}		default:			goto st8		}		goto tr6	st8:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof8		}	stCase8:		switch (m.data)[(m.p)] {		case 45:			goto st9		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st9			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st9			}		default:			goto st9		}		goto tr6	st9:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof9		}	stCase9:		switch (m.data)[(m.p)] {		case 45:			goto st10		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st10			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st10			}		default:			goto st10		}		goto tr6	st10:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof10		}	stCase10:		switch (m.data)[(m.p)] {		case 45:			goto st11		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st11			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st11			}		default:			goto st11		}		goto tr6	st11:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof11		}	stCase11:		switch (m.data)[(m.p)] {		case 45:			goto st12		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st12			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st12			}		default:			goto st12		}		goto tr6	st12:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof12		}	stCase12:		switch (m.data)[(m.p)] {		case 45:			goto st13		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st13			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st13			}		default:			goto st13		}		goto tr6	st13:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof13		}	stCase13:		switch (m.data)[(m.p)] {		case 45:			goto st14		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st14			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st14			}		default:			goto st14		}		goto tr6	st14:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof14		}	stCase14:		switch (m.data)[(m.p)] {		case 45:			goto st15		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st15			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st15			}		default:			goto st15		}		goto tr6	st15:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof15		}	stCase15:		switch (m.data)[(m.p)] {		case 45:			goto st16		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st16			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st16			}		default:			goto st16		}		goto tr6	st16:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof16		}	stCase16:		switch (m.data)[(m.p)] {		case 45:			goto st17		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st17			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st17			}		default:			goto st17		}		goto tr6	st17:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof17		}	stCase17:		switch (m.data)[(m.p)] {		case 45:			goto st18		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st18			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st18			}		default:			goto st18		}		goto tr6	st18:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof18		}	stCase18:		switch (m.data)[(m.p)] {		case 45:			goto st19		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st19			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st19			}		default:			goto st19		}		goto tr6	st19:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof19		}	stCase19:		switch (m.data)[(m.p)] {		case 45:			goto st20		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st20			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st20			}		default:			goto st20		}		goto tr6	st20:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof20		}	stCase20:		switch (m.data)[(m.p)] {		case 45:			goto st21		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st21			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st21			}		default:			goto st21		}		goto tr6	st21:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof21		}	stCase21:		switch (m.data)[(m.p)] {		case 45:			goto st22		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st22			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st22			}		default:			goto st22		}		goto tr6	st22:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof22		}	stCase22:		switch (m.data)[(m.p)] {		case 45:			goto st23		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st23			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st23			}		default:			goto st23		}		goto tr6	st23:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof23		}	stCase23:		switch (m.data)[(m.p)] {		case 45:			goto st24		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st24			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st24			}		default:			goto st24		}		goto tr6	st24:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof24		}	stCase24:		switch (m.data)[(m.p)] {		case 45:			goto st25		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st25			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st25			}		default:			goto st25		}		goto tr6	st25:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof25		}	stCase25:		switch (m.data)[(m.p)] {		case 45:			goto st26		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st26			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st26			}		default:			goto st26		}		goto tr6	st26:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof26		}	stCase26:		switch (m.data)[(m.p)] {		case 45:			goto st27		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st27			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st27			}		default:			goto st27		}		goto tr6	st27:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof27		}	stCase27:		switch (m.data)[(m.p)] {		case 45:			goto st28		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st28			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st28			}		default:			goto st28		}		goto tr6	st28:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof28		}	stCase28:		switch (m.data)[(m.p)] {		case 45:			goto st29		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st29			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st29			}		default:			goto st29		}		goto tr6	st29:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof29		}	stCase29:		switch (m.data)[(m.p)] {		case 45:			goto st30		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st30			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st30			}		default:			goto st30		}		goto tr6	st30:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof30		}	stCase30:		switch (m.data)[(m.p)] {		case 45:			goto st31		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st31			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st31			}		default:			goto st31		}		goto tr6	st31:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof31		}	stCase31:		switch (m.data)[(m.p)] {		case 45:			goto st32		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st32			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st32			}		default:			goto st32		}		goto tr6	st32:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof32		}	stCase32:		switch (m.data)[(m.p)] {		case 45:			goto st33		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st33			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st33			}		default:			goto st33		}		goto tr6	st33:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof33		}	stCase33:		switch (m.data)[(m.p)] {		case 45:			goto st34		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st34			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st34			}		default:			goto st34		}		goto tr6	st34:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof34		}	stCase34:		switch (m.data)[(m.p)] {		case 45:			goto st35		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st35			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st35			}		default:			goto st35		}		goto tr6	st35:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof35		}	stCase35:		switch (m.data)[(m.p)] {		case 45:			goto st36		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st36			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st36			}		default:			goto st36		}		goto tr6	st36:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof36		}	stCase36:		switch (m.data)[(m.p)] {		case 45:			goto st37		case 58:			goto tr10		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st37			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st37			}		default:			goto st37		}		goto tr6	st37:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof37		}	stCase37:		if (m.data)[(m.p)] == 58 {			goto tr10		}		goto tr6	tr10:		output.ID = string(m.text())		goto st38	st38:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof38		}	stCase38:		switch (m.data)[(m.p)] {		case 33:			goto tr42		case 36:			goto tr42		case 37:			goto tr43		case 61:			goto tr42		case 95:			goto tr42		}		switch {		case (m.data)[(m.p)] < 48:			if 39 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 46 {				goto tr42			}		case (m.data)[(m.p)] > 59:			switch {			case (m.data)[(m.p)] > 90:				if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {					goto tr42				}			case (m.data)[(m.p)] >= 64:				goto tr42			}		default:			goto tr42		}		goto tr41	tr42:		m.pb = m.p		goto st44	st44:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof44		}	stCase44:		switch (m.data)[(m.p)] {		case 33:			goto st44		case 36:			goto st44		case 37:			goto st39		case 61:			goto st44		case 95:			goto st44		}		switch {		case (m.data)[(m.p)] < 48:			if 39 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 46 {				goto st44			}		case (m.data)[(m.p)] > 59:			switch {			case (m.data)[(m.p)] > 90:				if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {					goto st44				}			case (m.data)[(m.p)] >= 64:				goto st44			}		default:			goto st44		}		goto tr41	tr43:		m.pb = m.p		goto st39	st39:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof39		}	stCase39:		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st40			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st40			}		default:			goto tr46		}		goto tr44	tr46:		m.tolower = append(m.tolower, m.p-m.pb)		goto st40	st40:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof40		}	stCase40:		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st45			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st45			}		default:			goto tr48		}		goto tr44	tr48:		m.tolower = append(m.tolower, m.p-m.pb)		goto st45	st45:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof45		}	stCase45:		switch (m.data)[(m.p)] {		case 33:			goto st44		case 36:			goto st44		case 37:			goto st39		case 61:			goto st44		case 95:			goto st44		}		switch {		case (m.data)[(m.p)] < 48:			if 39 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 46 {				goto st44			}		case (m.data)[(m.p)] > 59:			switch {			case (m.data)[(m.p)] > 90:				if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {					goto st44				}			case (m.data)[(m.p)] >= 64:				goto st44			}		default:			goto st44		}		goto tr44	tr8:		m.pb = m.p		goto st41	st41:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof41		}	stCase41:		switch (m.data)[(m.p)] {		case 45:			goto st7		case 58:			goto tr10		case 82:			goto st42		case 114:			goto st42		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st7			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st7			}		default:			goto st7		}		goto tr6	st42:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof42		}	stCase42:		switch (m.data)[(m.p)] {		case 45:			goto st8		case 58:			goto tr10		case 78:			goto st43		case 110:			goto st43		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st8			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st8			}		default:			goto st8		}		goto tr50	st43:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof43		}	stCase43:		if (m.data)[(m.p)] == 45 {			goto st9		}		switch {		case (m.data)[(m.p)] < 65:			if 48 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 57 {				goto st9			}		case (m.data)[(m.p)] > 90:			if 97 <= (m.data)[(m.p)] && (m.data)[(m.p)] <= 122 {				goto st9			}		default:			goto st9		}		goto tr52	st46:		if (m.p)++; (m.p) == (m.pe) {			goto _testEof46		}	stCase46:		switch (m.data)[(m.p)] {		case 10:			goto st0		case 13:			goto st0		}		goto st46	stOut:	_testEof2:		m.cs = 2		goto _testEof	_testEof3:		m.cs = 3		goto _testEof	_testEof4:		m.cs = 4		goto _testEof	_testEof5:		m.cs = 5		goto _testEof	_testEof6:		m.cs = 6		goto _testEof	_testEof7:		m.cs = 7		goto _testEof	_testEof8:		m.cs = 8		goto _testEof	_testEof9:		m.cs = 9		goto _testEof	_testEof10:		m.cs = 10		goto _testEof	_testEof11:		m.cs = 11		goto _testEof	_testEof12:		m.cs = 12		goto _testEof	_testEof13:		m.cs = 13		goto _testEof	_testEof14:		m.cs = 14		goto _testEof	_testEof15:		m.cs = 15		goto _testEof	_testEof16:		m.cs = 16		goto _testEof	_testEof17:		m.cs = 17		goto _testEof	_testEof18:		m.cs = 18		goto _testEof	_testEof19:		m.cs = 19		goto _testEof	_testEof20:		m.cs = 20		goto _testEof	_testEof21:		m.cs = 21		goto _testEof	_testEof22:		m.cs = 22		goto _testEof	_testEof23:		m.cs = 23		goto _testEof	_testEof24:		m.cs = 24		goto _testEof	_testEof25:		m.cs = 25		goto _testEof	_testEof26:		m.cs = 26		goto _testEof	_testEof27:		m.cs = 27		goto _testEof	_testEof28:		m.cs = 28		goto _testEof	_testEof29:		m.cs = 29		goto _testEof	_testEof30:		m.cs = 30		goto _testEof	_testEof31:		m.cs = 31		goto _testEof	_testEof32:		m.cs = 32		goto _testEof	_testEof33:		m.cs = 33		goto _testEof	_testEof34:		m.cs = 34		goto _testEof	_testEof35:		m.cs = 35		goto _testEof	_testEof36:		m.cs = 36		goto _testEof	_testEof37:		m.cs = 37		goto _testEof	_testEof38:		m.cs = 38		goto _testEof	_testEof44:		m.cs = 44		goto _testEof	_testEof39:		m.cs = 39		goto _testEof	_testEof40:		m.cs = 40		goto _testEof	_testEof45:		m.cs = 45		goto _testEof	_testEof41:		m.cs = 41		goto _testEof	_testEof42:		m.cs = 42		goto _testEof	_testEof43:		m.cs = 43		goto _testEof	_testEof46:		m.cs = 46		goto _testEof	_testEof:		{		}		if (m.p) == (m.eof) {			switch m.cs {			case 44, 45:				raw := m.text()				output.SS = string(raw)				// Iterate upper letters lowering them				for _, i := range m.tolower {					raw[i] = raw[i] + 32				}				output.norm = string(raw)			case 1, 2, 4:				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 3:				m.err = fmt.Errorf(errPrefix, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 41:				m.err = fmt.Errorf(errIdentifier, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 38:				m.err = fmt.Errorf(errSpecificString, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 42:				m.err = fmt.Errorf(errPrefix, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errIdentifier, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 43:				m.err = fmt.Errorf(errNoUrnWithinID, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errIdentifier, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			case 39, 40:				m.err = fmt.Errorf(errHex, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errSpecificString, m.p)				(m.p)--				{					goto st46				}				m.err = fmt.Errorf(errParse, m.p)				(m.p)--				{					goto st46				}			}		}	_out:		{		}	}	if m.cs < firstFinal || m.cs == enFail {		return nil, m.err	}	return output, nil}
 |