亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? serialize.cpp

?? Full support for extended regular expressions (those with intersection and complement); Support for
?? CPP
字號:

#include <stdio.h>
#include "dolphin.h"
using namespace std;
using namespace Whale;

//#define LISP_MODE

string serialize_expression(NonterminalExpression *expr);
string serialize_logical_expression(NonterminalExpressionC *expr);
string serialize_single_symbol(int t);
string serialize_string(vector<int> &v);

string serialize_expression(NonterminalExpression *expr)
{
	if(typeid(*expr)==typeid(NonterminalExpressionDisjunction))
	{
		NonterminalExpressionDisjunction &expr_d=*dynamic_cast<NonterminalExpressionDisjunction *>(expr);
	#ifndef LISP_MODE
		return serialize_expression(expr_d.expr1) + " | " + serialize_expression(expr_d.expr2);
	#else
		return string("(| ") + serialize_expression(expr_d.expr1) + " " + serialize_expression(expr_d.expr2) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionConjunction))
	{
		NonterminalExpressionConjunction &expr_c=*dynamic_cast<NonterminalExpressionConjunction *>(expr);
	#ifndef LISP_MODE
		return serialize_expression(expr_c.expr1) + " & " + serialize_expression(expr_c.expr2);
	#else
		return string("(& ") + serialize_expression(expr_c.expr1) + " " + serialize_expression(expr_c.expr2) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionConcatenation))
	{
		NonterminalExpressionConcatenation &expr_cat=*dynamic_cast<NonterminalExpressionConcatenation *>(expr);
	#ifndef LISP_MODE
		return serialize_expression(expr_cat.expr1) + " " + serialize_expression(expr_cat.expr2);
	#else
		return string("(. ") + serialize_expression(expr_cat.expr1) + " " + serialize_expression(expr_cat.expr2) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionComplement))
	{
		NonterminalExpressionComplement &expr_com=*dynamic_cast<NonterminalExpressionComplement *>(expr);
	#ifndef LISP_MODE
		return "~" + serialize_expression(expr_com.expr);
	#else
		return string("(~ ") + serialize_expression(expr_com.expr) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionOmittable))
	{
		NonterminalExpressionOmittable &expr_om=*dynamic_cast<NonterminalExpressionOmittable *>(expr);
	#ifndef LISP_MODE
		return "[" + serialize_expression(expr_om.expr) + "]";
	#else
		return string("([] ") + serialize_expression(expr_om.expr) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionInParentheses))
	{
		NonterminalExpressionInParentheses &expr_p=*dynamic_cast<NonterminalExpressionInParentheses *>(expr);
		return "(" + serialize_expression(expr_p.expr) + ")";
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionIteration))
	{
		NonterminalExpressionIteration &expr_it=*dynamic_cast<NonterminalExpressionIteration *>(expr);
	#ifndef LISP_MODE
		return serialize_expression(expr_it.expr) + expr_it.sign->text;
	#else
		return string(expr_it.reflexive ? "(* " : "(+ ") + serialize_expression(expr_it.expr) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionCondition))
	{
		NonterminalExpressionCondition &expr_cond=*dynamic_cast<NonterminalExpressionCondition *>(expr);
	#ifndef LISP_MODE
		return string("condition(") + serialize_logical_expression(expr_cond.condition) + ")";
	#else
		return string("(condition ") + serialize_logical_expression(expr_cond.condition) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionRange))
	{
		NonterminalExpressionRange &expr_r=*dynamic_cast<NonterminalExpressionRange *>(expr);
		
	#ifndef LISP_MODE
		return "range(" + serialize_single_symbol(expr_r.first) +
			", " + serialize_single_symbol(expr_r.last) + ")";
	#else
		return string("(range ") + serialize_single_symbol(expr_r.first) +
			" " + serialize_single_symbol(expr_r.last) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionContains))
	{
		NonterminalExpressionContains &expr_cont=*dynamic_cast<NonterminalExpressionContains *>(expr);
	#ifndef LISP_MODE
		return "contains(" + serialize_expression(expr_cont.expr) + ")";
	#else
		return "(contains " + serialize_expression(expr_cont.expr) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionEpsilon))
	{
		return "epsilon";
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionSharpSign))
	{
		return "#";
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionSymbol))
	{
		NonterminalExpressionSymbol &expr_s=*dynamic_cast<NonterminalExpressionSymbol *>(expr);
		vector<int> &v=expr_s.expr->s;
		if(expr_s.expr->is_nts)
			return data.nonterminals[expr_s.expr->nn].name;
		else if(!v.size())
			return "\x22\x22";
		else if(v.size()==1)
			return serialize_single_symbol(v[0]);
		else
			return serialize_string(v);
	}
	else
	{
		assert(false);
		return ""; // to please the compiler
	}
}

string serialize_logical_expression(NonterminalExpressionC *expr)
{
//	return "chaos"; // Hail RSL!
	
	if(typeid(*expr)==typeid(NonterminalExpressionC_Disjunction))
	{
		NonterminalExpressionC_Disjunction &expr_d=*dynamic_cast<NonterminalExpressionC_Disjunction *>(expr);
	#ifndef LISP_MODE
		return serialize_logical_expression(expr_d.expr1) + " | " +
			serialize_logical_expression(expr_d.expr2);
	#else
		return "(| " + serialize_logical_expression(expr_d.expr1) +
			serialize_logical_expression(expr_d.expr2) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_Conjunction))
	{
		NonterminalExpressionC_Conjunction &expr_c=*dynamic_cast<NonterminalExpressionC_Conjunction *>(expr);
	#ifndef LISP_MODE
		return serialize_logical_expression(expr_c.expr1) + " & " +
			serialize_logical_expression(expr_c.expr2);
	#else
		return "(& " + serialize_logical_expression(expr_c.expr1) +
			serialize_logical_expression(expr_c.expr2) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_Complement))
	{
		NonterminalExpressionC_Complement &expr_com=*dynamic_cast<NonterminalExpressionC_Complement *>(expr);
	#ifndef LISP_MODE
		return "~" + serialize_logical_expression(expr_com.expr);
	#else
		return "(~ " + serialize_logical_expression(expr_com.expr) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_InParentheses))
	{
		NonterminalExpressionC_InParentheses &expr_p=*dynamic_cast<NonterminalExpressionC_InParentheses *>(expr);
		return "(" + serialize_logical_expression(expr_p.expr) + ")";
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_Comparison))
	{
		NonterminalExpressionC_Comparison &expr_cmp=*dynamic_cast<NonterminalExpressionC_Comparison *>(expr);
	#ifndef LISP_MODE
		return string("c") + NonterminalExpressionC_Comparison::operation_to_s(expr_cmp.actual_operation) +
			serialize_single_symbol(expr_cmp.symbol);
	#else
		return string("(") + NonterminalExpressionC_Comparison::operation_to_s(expr_cmp.actual_operation) +
			" c " + serialize_single_symbol(expr_cmp.symbol) + ")";
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_In))
	{
		NonterminalExpressionC_In &expr_in=*dynamic_cast<NonterminalExpressionC_In *>(expr);
	#ifndef LISP_MODE
		return string("c in ") + string(data.nonterminals[expr_in.nn].name);
	#else
		return string("(in c ") + string(data.nonterminals[expr_in.nn].name) + string(")");
	#endif
	}
	else if(typeid(*expr)==typeid(NonterminalExpressionC_Constant))
	{
		NonterminalExpressionC_Constant &expr_const=*dynamic_cast<NonterminalExpressionC_Constant *>(expr);
		return string(expr_const.value ? "true" : "false");
	}
	else
	{
		assert(false);
		return ""; // to please the compiler
	}
}

string serialize_single_symbol(int t)
{
	if(t>=0x20 && t<=0x7f && t!=39)
		return "'"+string(1, char(t))+"'";
	else if(t=='\n')
		return "'\\n'";
	else if(t=='\r')
		return "'\\r'";
	else if(t=='\t')
		return "'\\t'";
	else
	{
		char buf[20];
		sprintf(buf, "0x%x", t);
		return string(buf);
	}
}

string serialize_string(vector<int> &v)
{
	string s;
	for(int i=0; i<v.size(); i++)
	{
		unsigned int t=v[i];
		if(t>=0x20 && t<=0x7f && t!=34)
			s+=char(t);
		else if(t=='\n')
			s+="\\n";
		else if(t=='\r')
			s+="\\r";
		else if(t=='\t')
			s+="\\t";
		else if(t<256 && i<v.size()-1 && !isxdigit(v[i+1]))
		{
			char buf[10];
			sprintf(buf, "\\x%x", t);
			s+=string(buf);
		}
		else
		{
			char buf[20];
			sprintf(buf, (t<=0xffff ? "\\u%04x" : "\\U%08x"), t);
			s+=string(buf);
		}
	}
	return "\x22" + s + "\x22";
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久国产精麻豆99网站 | 精品日韩在线一区| 精品国产1区二区| 一区二区在线看| 精品一区精品二区高清| 日本韩国一区二区三区| 久久久久久久久久久久久久久99 | 成人免费视频播放| 91麻豆精品国产91久久久资源速度 | 精品视频免费在线| 国产精品美日韩| 久久99久久久久| 欧美日韩国产首页| 亚洲三级小视频| 国产不卡视频一区| 精品成a人在线观看| 亚洲成av人片观看| 色狠狠色噜噜噜综合网| 中文字幕欧美国产| 国产一区二区伦理片| 91精品国产综合久久精品| 亚洲蜜臀av乱码久久精品蜜桃| 久久99国内精品| 日韩一级视频免费观看在线| 一区二区久久久| 99riav一区二区三区| 久久午夜国产精品| 老色鬼精品视频在线观看播放| 欧美日韩一区二区在线观看| 亚洲精品成人在线| 91免费精品国自产拍在线不卡| 国产亚洲成av人在线观看导航| 麻豆精品一二三| 日韩精品一区二区三区中文不卡 | 国产乱子伦视频一区二区三区| 欧美一区二区女人| 男男视频亚洲欧美| 欧美高清性hdvideosex| 亚洲成av人综合在线观看| 欧美日韩色一区| 日韩精品一级二级| 69久久99精品久久久久婷婷| 午夜视频一区二区三区| 欧美丰满美乳xxx高潮www| 午夜一区二区三区在线观看| 欧美日韩综合在线免费观看| 亚洲综合激情另类小说区| 欧美日韩成人一区二区| 秋霞电影网一区二区| 日韩美女在线视频| 国产99精品国产| 日韩一区有码在线| 欧美丝袜自拍制服另类| 日本视频中文字幕一区二区三区| 日韩女优毛片在线| 国产成人免费在线观看不卡| 综合婷婷亚洲小说| 欧美精品自拍偷拍| 国产麻豆午夜三级精品| 中文字幕五月欧美| 51精品秘密在线观看| 韩国欧美国产一区| |精品福利一区二区三区| 欧美日韩精品欧美日韩精品一综合| 男女激情视频一区| 中文字幕在线不卡视频| 欧美日韩极品在线观看一区| 久久精品国产77777蜜臀| 欧美国产精品一区二区| 欧美精品一卡两卡| 国产.欧美.日韩| 偷拍一区二区三区| 中文字幕av在线一区二区三区| 色狠狠一区二区三区香蕉| 久久国产精品72免费观看| 亚洲精品一二三四区| 欧美一区二区播放| 成人18视频在线播放| 免费观看在线色综合| 亚洲女人的天堂| 精品国产乱码久久久久久图片| 97精品国产露脸对白| 青青草原综合久久大伊人精品优势 | 国产精品美女www爽爽爽| 69堂成人精品免费视频| 91在线视频播放| 看国产成人h片视频| 一区二区三区四区激情| 欧美国产日产图区| 日韩精品专区在线影院重磅| 色播五月激情综合网| 国产精品系列在线观看| 蜜臀99久久精品久久久久久软件| 亚洲欧美日本韩国| 中文一区在线播放| 精品国产一区二区精华| 欧美视频精品在线观看| 91一区在线观看| 国产成人av一区二区| 久久国产剧场电影| 日韩成人伦理电影在线观看| 亚洲宅男天堂在线观看无病毒| 欧美国产乱子伦| 久久久国产午夜精品| 日韩免费视频一区二区| 欧美人妖巨大在线| 欧美日韩在线播放一区| 91久久精品一区二区二区| 国产99久久久国产精品免费看| 免费人成在线不卡| 日本不卡123| 喷水一区二区三区| 奇米影视一区二区三区小说| 午夜精品福利一区二区蜜股av | 99精品视频一区| 成人午夜视频在线观看| 国产不卡在线视频| 国产69精品一区二区亚洲孕妇| 国产乱国产乱300精品| 国产麻豆91精品| 国产传媒一区在线| 国产黄色精品网站| 高清视频一区二区| av中文字幕一区| 色噜噜偷拍精品综合在线| 欧美在线视频你懂得| 欧美人与禽zozo性伦| 欧美一级国产精品| 久久综合九色综合欧美就去吻| 久久久久久久综合日本| 国产精品人成在线观看免费| 中文字幕一区二区三区不卡在线| 中文字幕一区视频| 亚洲午夜免费福利视频| 蜜桃视频一区二区| 国产福利一区二区三区在线视频| 91精品国产综合久久国产大片| 欧美一区二区三区影视| 精品伦理精品一区| 中文字幕免费不卡| 亚洲一区二区四区蜜桃| 日韩电影在线免费| 国产精品一卡二| 色欧美片视频在线观看在线视频| 欧美三级在线播放| 26uuu另类欧美亚洲曰本| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲免费在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 国产高清久久久久| 在线观看国产日韩| www国产精品av| 亚洲综合色自拍一区| 久久国内精品视频| 色综合久久久久久久久| 日韩视频不卡中文| 亚洲视频在线一区| 九九精品视频在线看| 91福利国产精品| 久久久国产综合精品女国产盗摄| 亚洲夂夂婷婷色拍ww47| 国产成人av一区二区三区在线| 欧美系列一区二区| 欧美国产精品专区| 久久草av在线| 欧美日韩在线观看一区二区| 久久九九久久九九| 亚洲成人第一页| 波多野结衣中文字幕一区二区三区 | 一区二区三区视频在线看| 韩国中文字幕2020精品| 欧美日韩三级视频| 成人免费在线视频| 国产精品一线二线三线精华| 欧美挠脚心视频网站| 亚洲日本一区二区| 国产成人午夜精品影院观看视频 | 亚洲成人精品一区二区| 成人av中文字幕| 久久夜色精品国产欧美乱极品| 午夜精品久久久| 欧美亚一区二区| 亚洲色大成网站www久久九九| 国产精品亚洲午夜一区二区三区| 日韩一区二区三区观看| 亚洲成a天堂v人片| 日本丶国产丶欧美色综合| 国产精品乱码久久久久久 | 亚洲一区自拍偷拍| 91亚洲精品久久久蜜桃| 国产女主播一区| 国产高清不卡一区二区| 精品理论电影在线| 日本亚洲天堂网| 91精品久久久久久久99蜜桃| 午夜视频在线观看一区二区三区| 欧美亚洲丝袜传媒另类| 亚洲欧美激情在线| 色综合色狠狠天天综合色| 亚洲女同女同女同女同女同69|