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

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

?? soapcpp2.y

?? linux下開發的soap協議。建議大家學習學習!
?? Y
?? 第 1 頁 / 共 3 頁
字號:
			}	| aexp	;obex	: oexp		{ $$ = $1; }	;/* aexp : and-expression */aexp	: abex AN rexp			{ $$.hasval = False;			  $$.typ = mkint();			}	| rexp	;abex	: aexp		{ $$ = $1; }	;/* rexp : relational expression */rexp	: rexp '|' rexp	{ $$ = iop("|", $1, $3); }	| rexp '^' rexp	{ $$ = iop("^", $1, $3); }	| rexp '&' rexp	{ $$ = iop("&", $1, $3); }	| rexp EQ  rexp	{ $$ = relop("==", $1, $3); }	| rexp NE  rexp	{ $$ = relop("!=", $1, $3); }	| rexp '<' rexp	{ $$ = relop("<", $1, $3); }	| rexp LE  rexp	{ $$ = relop("<=", $1, $3); }	| rexp '>' rexp	{ $$ = relop(">", $1, $3); }	| rexp GE  rexp	{ $$ = relop(">=", $1, $3); }	| rexp LS  rexp	{ $$ = iop("<<", $1, $3); }	| rexp RS  rexp	{ $$ = iop(">>", $1, $3); }	| rexp '+' rexp	{ $$ = op("+", $1, $3); }	| rexp '-' rexp	{ $$ = op("-", $1, $3); }	| rexp '*' rexp	{ $$ = op("*", $1, $3); }	| rexp '/' rexp	{ $$ = op("/", $1, $3); }	| rexp '%' rexp	{ $$ = iop("%", $1, $3); }	| lexp	;/* lexp : lvalue kind of expression with optional prefix contructs */lexp	: '!' lexp	{ if ($2.hasval)				$$.val.i = !$2.val.i;			  $$.typ = $2.typ;			  $$.hasval = $2.hasval;			}	| '~' lexp	{ if ($2.hasval)				$$.val.i = ~$2.val.i;			  $$.typ = $2.typ;			  $$.hasval = $2.hasval;			}	| '-' lexp	{ if ($2.hasval) {				if (integer($2.typ))					$$.val.i = -$2.val.i;				else if (real($2.typ))					$$.val.r = -$2.val.r;				else	typerror("string?");			  }			  $$.typ = $2.typ;			  $$.hasval = $2.hasval;			}	| '+' lexp	{ $$ = $2; }	| '*' lexp	{ if ($2.typ->type == Tpointer) {			  	$$.typ = (Tnode*) $2.typ->ref;			  } else			  	typerror("dereference of non-pointer type");			  $$.sto = Snone;			  $$.hasval = False;			}	| '&' lexp	{ $$.typ = mkpointer($2.typ);			  $$.sto = Snone;			  $$.hasval = False;			}	| SIZEOF '(' texp ')'			{ $$.hasval = True;			  $$.typ = mkint();			  $$.val.i = $3.typ->width;			}	| pexp	;/* pexp : primitive expression with optional postfix constructs */pexp	: '(' expr ')'	{ $$ = $2; }	| ID		{ if ((p = enumentry($1)) == (Entry*) 0)				p = undefined($1);			  else			  	$$.hasval = True;			  $$.typ = p->info.typ;			  $$.val = p->info.val;			}	| LNG		{ $$.typ = mkint();			  $$.hasval = True;			  $$.val.i = $1;			}	| DBL		{ $$.typ = mkfloat();			  $$.hasval = True;			  $$.val.r = $1;			}	| CHR		{ $$.typ = mkchar();			  $$.hasval = True;			  $$.val.i = $1;			}	| STR		{ $$.typ = mkstring();			  $$.hasval = True;			  $$.val.s = $1;			}	| CFALSE	{ $$.typ = mkbool();			  $$.hasval = True;			  $$.val.i = 0;			}	| CTRUE		{ $$.typ = mkbool();			  $$.hasval = True;			  $$.val.i = 1;			}	;%%/* * ??? */intyywrap(){  return 1;}/******************************************************************************\	Support routines\******************************************************************************/static Nodeop(const char *op, Node p, Node q){	Node	r;	Tnode	*typ;	r.typ = p.typ;	r.sto = Snone;	if (p.hasval && q.hasval) {		if (integer(p.typ) && integer(q.typ))			switch (op[0]) {			case '|':	r.val.i = p.val.i |  q.val.i; break;			case '^':	r.val.i = p.val.i ^  q.val.i; break;			case '&':	r.val.i = p.val.i &  q.val.i; break;			case '<':	r.val.i = p.val.i << q.val.i; break;			case '>':	r.val.i = p.val.i >> q.val.i; break;			case '+':	r.val.i = p.val.i +  q.val.i; break;			case '-':	r.val.i = p.val.i -  q.val.i; break;			case '*':	r.val.i = p.val.i *  q.val.i; break;			case '/':	r.val.i = p.val.i /  q.val.i; break;			case '%':	r.val.i = p.val.i %  q.val.i; break;			default:	typerror(op);			}		else if (real(p.typ) && real(q.typ))			switch (op[0]) {			case '+':	r.val.r = p.val.r + q.val.r; break;			case '-':	r.val.r = p.val.r - q.val.r; break;			case '*':	r.val.r = p.val.r * q.val.r; break;			case '/':	r.val.r = p.val.r / q.val.r; break;			default:	typerror(op);			}		else	semerror("illegal constant operation");		r.hasval = True;	} else {		typ = mgtype(p.typ, q.typ);		r.hasval = False;	}	return r;}static Nodeiop(const char *iop, Node p, Node q){	if (integer(p.typ) && integer(q.typ))		return op(iop, p, q);	typerror("integer operands only");	return p;}static Noderelop(const char *op, Node p, Node q){	Node	r;	Tnode	*typ;	r.typ = mkint();	r.sto = Snone;	r.hasval = False;	if (p.typ->type != Tpointer || p.typ != q.typ)		typ = mgtype(p.typ, q.typ);	return r;}/******************************************************************************\	Scope management\******************************************************************************//*mkscope - initialize scope stack with a new table and offset*/static voidmkscope(Table *table, int offset){	sp = stack-1;	enterscope(table, offset);}/*enterscope - enter a new scope by pushing a new table and offset on the stack*/static voidenterscope(Table *table, int offset){	if (++sp == stack+MAXNEST)		execerror("maximum scope depth exceeded");	sp->table = table;	sp->val = 0;	sp->offset = offset;	sp->grow = True;	/* by default, offset grows */	sp->mask = False;}/*exitscope - exit a scope by popping the table and offset from the stack*/static voidexitscope(){	check(sp-- != stack, "exitscope() has no matching enterscope()");}/******************************************************************************\	Undefined symbol\******************************************************************************/static Entry*undefined(Symbol *sym){	Entry	*p;	sprintf(errbuf, "undefined identifier `%s'", sym->name);	semwarn(errbuf);	p = enter(sp->table, sym);	p->level = GLOBAL;	p->info.typ = mkint();	p->info.sto = Sextern;	p->info.hasval = False;	return p;}/*mgtype - return most general type among two numerical types*/Tnode*mgtype(Tnode *typ1, Tnode *typ2){	if (numeric(typ1) && numeric(typ2)) {		if (typ1->type < typ2->type)			return typ2;	} else	typerror("non-numeric type");	return typ1;}/******************************************************************************\	Type checks\******************************************************************************/static intinteger(Tnode *typ){	switch (typ->type) {	case Tchar:	case Tshort:	case Tint:	case Tlong:	return True;	}	return False;}static intreal(Tnode *typ){	switch (typ->type) {	case Tfloat:	case Tdouble:	return True;	}	return False;}static intnumeric(Tnode *typ){	return integer(typ) || real(typ);}static intpointer(Tnode *typ){	return typ->type == Tpointer;}static voidadd_fault(Table *gt){ Table *t;  Entry *p;  Symbol *s = lookup("SOAP_ENV__Fault");  p = entry(classtable, s);  if (!p)  { t = mktable((Table*)0);    p = enter(t, lookup("faultcode"));    p->info.typ = mkstring();    p = enter(t, lookup("faultstring"));    p->info.typ = mkstring();    p = enter(t, lookup("faultactor"));    p->info.typ = mkstring();    p = enter(t, lookup("detail"));    p->info.typ = mkstring();    p = enter(classtable, s);    p->info.typ = mkstruct(t, 16);    p->info.typ->id = s;    custom_fault = 0;  }}static voidadd_header(Table *gt){ Table *t;  Entry *p;  Symbol *s = lookup("SOAP_ENV__Header");  p = entry(classtable, s);  if (!p)  { t = mktable((Table*)0);    p = enter(t, lookup("dummy"));    p->info.typ = mkpointer(mkvoid());    p = enter(classtable, s);    p->info.typ = mkstruct(t, 4);    p->info.typ->id = s;    custom_header = 0;  }}static voidadd_response(Entry *fun, Entry *ret){ Table *t;  Entry *p, *q;  Symbol *s;  int n = strlen(fun->sym->name);  char *r = (char*)emalloc(n+9);  strcpy(r, fun->sym->name);  strcat(r, "Response");  if (!(s = lookup(r)))    s = install(r, ID);  free(r);  t = mktable((Table*)0);  q = enter(t, ret->sym);  q->info = ret->info;  if (q->info.typ->type == Treference)    q->info.typ = (Tnode*)q->info.typ->ref;  p = enter(classtable, s);  p->info.typ = mkstruct(t, 4);  p->info.typ->id = s;  fun->info.typ->response = p;}/*dumptbl(Table *t){  Entry *p;  fprintf(stderr, " (level %d) ", t->level);  for (p = t->list; p; p = p->next)    {      switch (p->info.sto)	{	case Sregister:	  fprintf(stderr, "register ");	  break;	case Sstatic:	  fprintf(stderr, "static ");	  break;	case Sextern:	  fprintf(stderr, "extern ");	  break;	case Stypedef:	  fprintf(stderr, "typedef ");	}      dumptyp(p->info.typ);    fprintf(stderr, " %s=%d (%d)", p->sym->name, p->info.val.i, p->lineno);    }     if (t->prev)    {      fprintf(stderr, "##(linked to table:##\n");      dumptbl(t->prev);      fprintf(stderr, ")");    }}*//*char *dumptyp(Tnode *p){ char *s;  switch (p->type)  {    case Tvoid:      return "void");    case Tchar:      return "char";    case Tshort:      return "short";    case Tint:      return "int";    case Tlong:      return "long";    case Tllong:      return "LONG64";    case Tfloat:      return "float";    case Tdouble:      return "double";    case Tuchar:      return "unsigned char";    case Tushort:      return "unsigned short";    case Tuint:      return "unsigned int";    case Tulong:      return "unsigned long";    case Tullong:      return "ULONG64";    case Tenum:      s = (char*)emalloc(strlen(p->id->name)+6);      strcpy(s, "enum ");      return strcat(s, p->id->name);    case Tclass:      return p->id->name;      break;    case Tstruct:      s = (char*)emalloc(strlen(p->id->name)+8);      strcpy(s, "struct ");      return strcat(s, p->id->name);    case Tunion:      s = (char*)emalloc(strlen(p->id->name)+8);      strcpy(s, "union ");      return strcat(s, p->id->name);    case Tpointer:      dumptyp(p->ref);      fprintf(stderr, "*");      break;    case Tarray:      fprintf(stderr, "[%d]", p->width/((Tnode*)p->ref)->width);      break;    case Tfun:      if (p->ref)	{	  fprintf(stderr, "int(");	  dumptyp(p->ref);	  fprintf(stderr, ")");	}      else	fprintf(stderr, "int()");      break;    }}*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本一本大道香蕉久在线精品| 美国毛片一区二区| 久久午夜色播影院免费高清| 日韩一区二区三区在线视频| 国产欧美精品一区二区三区四区 | 日韩午夜在线影院| 亚洲日本在线观看| 国产精品理伦片| 狠狠色狠狠色综合系列| jizz一区二区| 亚洲欧美日韩在线| 国产欧美日韩综合精品一区二区| 亚洲自拍欧美精品| 日本丰满少妇一区二区三区| 国产人伦精品一区二区| 亚洲一区在线观看视频| 国产精品亚洲综合一区在线观看| 色哟哟日韩精品| 2017欧美狠狠色| 香蕉影视欧美成人| 成人小视频免费在线观看| 欧美二区三区91| 国产精品久久久99| 久久99精品久久久久久久久久久久 | 成人午夜短视频| 日本福利一区二区| 亚洲区小说区图片区qvod| 日本中文字幕一区二区视频 | 亚洲制服丝袜在线| 久久99精品久久久久久| 在线精品视频一区二区| 国产精品天美传媒| 国产原创一区二区| 欧美电影免费提供在线观看| 日韩av电影天堂| 欧美亚洲动漫制服丝袜| 一区二区三区自拍| 欧美日韩免费在线视频| 久久福利视频一区二区| 中文在线一区二区| 日本高清成人免费播放| 亚洲国产精品欧美一二99 | 一本大道av一区二区在线播放| 欧美经典三级视频一区二区三区| 国产美女精品一区二区三区| 久久蜜桃一区二区| 福利一区二区在线| 亚洲日本成人在线观看| 欧美在线观看一二区| 日日夜夜精品视频免费| 久久综合久久鬼色中文字| 偷拍一区二区三区四区| 日韩三级免费观看| 国产精品影视天天线| 亚洲激情av在线| 欧美挠脚心视频网站| 国产一区二区美女诱惑| 亚洲日本乱码在线观看| 欧美一区二区三区视频| 99久久精品一区| 久久精品国产久精国产爱| 欧美激情在线一区二区| 欧美群妇大交群的观看方式| 国产美女娇喘av呻吟久久| 亚洲国产综合色| 亚洲欧洲日韩在线| 久久综合九色综合久久久精品综合| 一本大道久久a久久综合| 国产一区二区免费看| 五月综合激情婷婷六月色窝| 国产亚洲精品资源在线26u| 久久久久久久久久久黄色| 精品视频在线视频| 91黄色小视频| 成人精品国产福利| 国产成人精品亚洲日本在线桃色| 日本伊人精品一区二区三区观看方式| 久久亚洲精华国产精华液 | 欧美大片在线观看| 欧美四级电影网| 色94色欧美sute亚洲13| 97国产精品videossex| 东方欧美亚洲色图在线| 国产精品一区二区久久不卡 | 97久久超碰国产精品电影| 国产丶欧美丶日本不卡视频| 极品少妇一区二区| 国产成人免费视频一区| 粉嫩高潮美女一区二区三区| 成人h版在线观看| 91丨九色丨蝌蚪丨老版| 91香蕉视频在线| 成人免费毛片app| 色美美综合视频| 在线观看91精品国产麻豆| 欧美精品色一区二区三区| 精品免费国产一区二区三区四区| 精品视频全国免费看| 亚洲精品在线观看网站| 欧美高清在线一区二区| 亚洲激情欧美激情| 免费人成在线不卡| 国产成人免费xxxxxxxx| 2023国产一二三区日本精品2022| 国产亚洲午夜高清国产拍精品| 亚洲日穴在线视频| 久久99国产精品免费网站| 99天天综合性| 久久久一区二区| 午夜精品久久久久影视| 国产精品1区2区| 欧美精品v国产精品v日韩精品| 国产午夜久久久久| 久久精品国产99国产| 欧美高清性hdvideosex| 亚洲欧美影音先锋| 国产一区视频在线看| 8v天堂国产在线一区二区| 亚洲日本在线天堂| 国产成人日日夜夜| 欧美tickling挠脚心丨vk| 亚洲一卡二卡三卡四卡| 色悠悠久久综合| 综合久久综合久久| 成人国产视频在线观看| 亚洲最新视频在线播放| 91在线精品一区二区三区| 国产欧美视频一区二区三区| 国产麻豆成人传媒免费观看| 精品国产乱码久久久久久夜甘婷婷 | 92国产精品观看| 亚洲欧洲av另类| 91黄色免费版| 激情小说欧美图片| 久久综合中文字幕| 韩国中文字幕2020精品| 国产性做久久久久久| 丁香网亚洲国际| 国产精品久久久久影院| 色婷婷av久久久久久久| 一区二区三区在线观看网站| 91精品一区二区三区在线观看| 久久国产欧美日韩精品| 中文字幕日本不卡| 日本高清不卡视频| 久久精品国产精品青草| 亚洲欧美国产高清| 日韩欧美国产一二三区| 成人美女视频在线看| 五月天激情综合| 亚洲国产高清在线| 欧美老年两性高潮| 粉嫩av一区二区三区| 日韩精品乱码av一区二区| 中文成人av在线| 欧美成人国产一区二区| 欧洲激情一区二区| 成人黄色免费短视频| 久久国产精品99久久人人澡| 一区二区在线观看视频在线观看| 精品日韩在线观看| 91精品国产综合久久久久| aaa亚洲精品| 成人成人成人在线视频| 国产一区二区调教| gogo大胆日本视频一区| 国产精品综合在线视频| 九九国产精品视频| 日本特黄久久久高潮| 亚洲大片在线观看| 亚洲gay无套男同| 亚洲电影中文字幕在线观看| 亚洲欧美乱综合| 亚洲色图在线看| 亚洲专区一二三| 丝瓜av网站精品一区二区 | 另类中文字幕网| 美女视频免费一区| 麻豆专区一区二区三区四区五区| 午夜成人免费视频| 免费不卡在线观看| 国产一区二区三区四区在线观看 | 精品免费国产一区二区三区四区| 精品欧美黑人一区二区三区| 久久久无码精品亚洲日韩按摩| 久久久不卡网国产精品一区| 国产精品国产成人国产三级| 亚洲人成7777| 麻豆精品在线看| 不卡av在线免费观看| 欧美亚洲综合久久| 日韩美女在线视频| 1024成人网| 麻豆91在线播放| av电影在线观看不卡| 日韩欧美国产三级| 一区二区三区四区五区视频在线观看| 午夜视频久久久久久| 国产 欧美在线| 欧美一区二区三区爱爱|