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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? mangle.c

?? C編譯器源碼是我到處找來(lái)的,看了之后很有收獲
?? C
字號(hào):
/*
 * 68K/386 32-bit C compiler.
 *
 * copyright (c) 1997, David Lindauer
 * 
 * This compiler is intended for educational use.  It may not be used
 * for profit without the express written consent of the author.
 *
 * It may be freely redistributed, as long as this notice remains intact
 * and either the original sources or derived sources 
 * are distributed along with any executables derived from the originals.
 *
 * The author is not responsible for any damages that may arise from use
 * of this software, either idirect or consequential.
 *
 * v1.35 March 1997
 * David Lindauer, gclind01@starbase.spd.louisville.edu
 *
 * Credits to Mathew Brandt for original K&R C compiler
 *
 */
/* Handles name mangling
 */
#include        <stdio.h>
#include				<malloc.h>
#include				<ctype.h>
#include        "expr.h"
#include        "c.h"
#include 				"errors.h"

extern TABLE oldlsym,lsyms,gsyms;
extern int prm_cplusplus,prm_cmangle;
#define HASHTABLESIZE 1023

#ifdef CPLUSPLUS
char destructor_name[] = "$dtr";
char constructor_name[] = "$ctr";

char *tn_void = "void";
char *tn_char = "char";
char *tn_int = "int";
char *tn_long = "long" ;
char *tn_short = "short";
char *tn_unsigned = "unsigned ";
char *tn_ellipse = "...";
char *tn_float = "float";
char *tn_double = "double";
char *tn_longdouble = "long double";
#endif /* CPLUSPLUS */

/* Insert an overloaded function ref into the function table
 */
void funcrefinsert(char *name, char *mangname, TYP *tp, TABLE *tbl)
{
#ifdef CPLUSPLUS
	char buf[100];
	SYM *sp,*sp1;
	sp = xalloc(sizeof(SYM));
	buf[0] = '$';
	buf[1] = '$';
	strcpy(&buf[2],name);
	sp->defalt = mangname;
	sp->storage_class = sc_defunc;
	sp->value.overlist.head = 0;
	sp->name = litlate(buf);
	sp->tp = tp;
	sp1 = search(buf,tbl);
	if (sp1)
		if (sp1->value.overlist.head == 0)
			sp1->value.overlist.head = sp1->value.overlist.tail = sp;
		else
			sp1->value.overlist.tail = sp1->value.overlist.tail->next = sp;
	else
		insert(sp,tbl);
#endif
}
#ifdef CPLUSPLUS
/* See if two C++ functions match */
static int fomatch(TYP *tp1, TYP *tp2)
{
	SYM *sp1 = tp1->lst.head;
	SYM *sp2 = tp2->lst.head;
	if (sp1 == (SYM *)-1 && sp2 == (SYM *)-1)
		return TRUE;
	if (sp1 && sp1->defalt)
		return TRUE;
	while (sp2 && sp1) {
		if (sp1->tp->type == bt_ellipse)
			return TRUE;
		if (!exactype(sp1->tp, sp2->tp) && !(isscalar(tp1) && isscalar(tp2)))
			return FALSE;
		if (sp1->defalt)
			return TRUE;
		sp1 = sp1->next;
		sp2 = sp2->next;
	}
	return sp1 == sp2;
}
#endif
/* Search the tables looking for a match for an argument type list */
SYM *funcovermatch(char *name,TYP *tp)
{
#ifdef CPLUSPLUS
	char buf1[100];
	TABLE *tbl1, *tbl2;
	if (prm_cplusplus) {
		SYM *sp2,*sp3,*sp4=0,*sp5=0,*sp6,*sp7;
		tbl1 = &lsyms;
		tbl2 = &gsyms;
		buf1[0] = '$';
		buf1[1] = '$';
		strcpy(&buf1[2],name);
		sp2 = search(buf1,tbl1);
		sp3 = search(buf1,tbl2);
		if (sp2)
			if (fomatch(sp2->tp,tp)) 
				sp4 = sp2;
		if (sp3)
			if (fomatch(sp3->tp,tp)) 
				sp5 = sp3;
		if (sp4 && sp5) {
			genfunc2error(ERR_AMBIGFUNC,sp4->defalt,sp5->defalt);
			return gsearch(sp4->defalt);
		}
		if (sp2) {
			sp6 = sp2->value.overlist.head;
			while (sp6) {
				if (fomatch(sp6->tp,tp)) {
					if (sp4) {
						genfunc2error(ERR_AMBIGFUNC,sp4->defalt,sp6->defalt);
						return gsearch(sp4->defalt);
					}
					else if (sp5) {
						genfunc2error(ERR_AMBIGFUNC,sp5->defalt,sp6->defalt);
						return gsearch(sp5->defalt);
					}
					else sp4 = sp6;
				}
				sp6 = sp6->next;
			}
		}
		if (sp3) {
			sp7 = sp3->value.overlist.head;
			while (sp7) {
				if (fomatch(sp7->tp,tp)) {
					if (sp4) {
						genfunc2error(ERR_AMBIGFUNC,sp4->defalt,sp7->defalt);
						return gsearch(sp4->defalt);
					}
					else if (sp5) {
						genfunc2error(ERR_AMBIGFUNC,sp5->defalt,sp7->defalt);
						return gsearch(sp5->defalt);
					}
					else sp5 = sp7;
				}
				sp7 = sp7->next;
			}
		}
		if (sp4)
			return gsearch(sp4->defalt);
		if (sp5)
			return gsearch(sp5->defalt);
	}
#endif
	return(gsearch(name));
}
#ifdef CPLUSPLUS
/* Mangle one C++ argument */
static char *cpponearg(char *buf,TYP *tp)
{
start:
	switch (tp->type) {
		case bt_ptrfunc:
			*buf++ = 'q';
			buf = cppargs(buf,tp->lst.head);
			*buf++ = '$';
			tp = tp->btp;
			goto start;
		case bt_struct:
		case bt_union:
		case bt_class:
		case bt_enum:
			sprintf(buf,"%d%s",strlen(tp->sname+1),tp->sname+1);
			buf = buf + strlen(buf);
			break;
		case bt_unsignedshort:
			*buf++ = 'u';
		case bt_short:
			*buf++ = 's';
			break;
		case bt_unsigned:
			*buf++ = 'u';
		case bt_long:
			*buf++ = 'i';
			break;
		case bt_unsignedchar:
			*buf++ = 'u';
		case bt_char:
			*buf++ = 'c';
			break;
		case bt_float:
			*buf++ = 'f';
			break;
		case bt_double:
			*buf++ = 'd';
			break;
		case bt_longdouble:
			*buf++ = 'g';
			break;
		case bt_pointer:
			*buf++ = 'p';
			tp = tp->btp;
			goto start;
		case bt_ref:
			*buf++ = 'r';
			tp = tp->btp;
			goto start;
		case bt_ellipse:
			*buf++ = 'e';
			break;
	}
	*buf = 0;
	return buf;
}
/* Mangle an entire C++ function */
static char *cppargs(char *buf,SYM *sp)
{
	*buf++ = 'q';
	if (sp == (SYM *)-1) {
		*buf++ = 'v';
	}
	else while (sp) {
		buf = cpponearg(buf,sp->tp);
		sp = sp->next;
	}
	*buf=0;
	return buf + strlen(buf);
}
/* Wrapper for function name mangling */
char * cppmangle(char *name, TYP *tp)
{
	char buf[100];
	if (*name == 0)
		return 0;
	if (prm_cmangle)
		name++;
	sprintf(buf,"@%s$",name);
	cppargs(buf+strlen(buf),tp->lst.head);
	return(litlate(buf));
}
	
/* Unmangle a pointer reference */
char * putptr(char *buf, int *ptr, int **ptrs)
{
	int *p = *ptrs;
	buf = buf+strlen(buf);
	while ((*ptr)--) {
		*buf++ = ' ';
		if (*p++) 
			*buf++= '&';
		else
			*buf++ = '*';
	}
	*ptr = 0;
	*buf = 0;
	return buf;
}			
			
/* Argument unmangling for C++ */
static char *unmang1(char *buf, char *name, int *ptr, int **ptrs)
{
start:
		if (isdigit(*name)) {
			int v = *name++ - '0';
			while (isdigit(*name)) 
				v = v*10+ *name++ - '0';
			while (v--) 
				*buf++ = *name++;
			*buf = 0;
		}
		else switch (*name++) {
			case 'q': {
					char buf1[100],buf2[100];
					strcpy(buf1," (*) ");
					buf+=5;
				  name = unmangcppfunc(buf1,name);
					name++;
					name = unmang1(buf2,name,ptr,ptrs);
					buf = putptr(buf,ptr,ptrs);
					strcpy(buf,buf2);
					strcat(buf,buf1);
					buf = buf +strlen(buf);
					
				}
				break;	
			case 'u':
				strcpy(buf,"unsigned ");
				buf = buf+9;
				switch(*name++) {
					case 'i':
						strcpy(buf,tn_int);
						buf = putptr(buf,ptr,ptrs);
						break;
					case 'l':
						strcpy(buf,tn_long);
						buf = putptr(buf,ptr,ptrs);
						break;
					case 's':
						strcpy(buf,tn_short);
						buf = putptr(buf,ptr,ptrs);
						break;
					case 'c':
						strcpy(buf,tn_char);
						buf = putptr(buf,ptr,ptrs);
						break;
				}
			case 'f':
				strcpy(buf,tn_float);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'd':
				strcpy(buf,tn_double);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'g':
				strcpy(buf,tn_longdouble);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'i':
				strcpy(buf,tn_int);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'l':
				strcpy(buf,tn_long);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 's':
				strcpy(buf,tn_short);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'c':
				strcpy(buf,tn_char);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'v':
				strcpy(buf,tn_void);
				buf = putptr(buf,ptr,ptrs);
				break;
			case 'p':
				(*ptrs)[(*ptr)++] = 0;
				goto start;
			case 'r':
				(*ptrs)[(*ptr)++] = 1;
				goto start;
			case 'e':
				strcpy(buf,tn_ellipse);
				break;
			case '$':
				name--;
				return name;
		}
	return name;
}
/* Unmangle an entire C++ function */
static char * unmangcppfunc(char *buf, char *name)
{
	int ptr = 0;
	char ptrs[50];
	*buf++ = '(';
	while (*name && *name != '$') {
		name = unmang1(buf,name,&ptr,&ptrs);
		buf = buf+strlen(buf);
		if (*name && *name != '$')
			*buf++ = ',';
		else
			*buf++ = ')';
	}
	*buf=0;
	return buf;
}
#endif
/* Name unmangling in general */
void unmangle(char *buf, char *name)
{
	if (name[0] == '_' && prm_cmangle) {
		strcpy(buf,&name[1]);
	}
#ifdef CPLUSPLUS
	else 
		if (name[0] != '@')
			strcpy(buf,name);
		else {
			name++;
			while (*name != '$' && *name)
				*buf++ = *name++;
			if (*name) {
				name+=2;
				unmangcppfunc(buf,name);
			}
			else *buf++ = 0;
		}
#endif
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
秋霞午夜av一区二区三区 | 色综合久久久久久久| 久久激五月天综合精品| 丝袜国产日韩另类美女| 亚洲国产精品一区二区久久| 一区二区三区国产| 亚洲午夜电影在线观看| 亚洲成人激情社区| 日韩成人dvd| 乱一区二区av| 国产成人免费视频一区| 国产成a人亚洲| 国产成人av电影在线播放| 成人黄色av电影| 91亚洲精品一区二区乱码| 色视频一区二区| 欧美肥妇bbw| 日韩三级中文字幕| 久久精品人人做人人综合 | 国产精品美女久久久久久久网站| 国产精品三级视频| 亚洲综合免费观看高清完整版在线| 亚洲综合成人在线视频| 日本在线不卡视频| 国产经典欧美精品| 99国产欧美久久久精品| 欧美亚洲一区二区在线| 日韩一区二区三区四区| 久久精品夜夜夜夜久久| 亚洲日本丝袜连裤袜办公室| 亚洲大片在线观看| 久久97超碰色| av一区二区久久| 欧美三级电影网站| 日韩精品一区二区三区视频在线观看 | 性做久久久久久久免费看| 日本成人在线看| 成人亚洲精品久久久久软件| 9久草视频在线视频精品| 欧美日韩午夜在线视频| 精品国产三级a在线观看| 国产精品你懂的| 亚洲一区二区视频在线观看| 久久电影网电视剧免费观看| 国产.精品.日韩.另类.中文.在线.播放 | 欧美中文字幕久久 | 蜜桃精品在线观看| 国产不卡视频在线观看| 色狠狠色狠狠综合| 亚洲精品一区二区三区影院| 亚洲另类在线一区| 久久国产成人午夜av影院| 色综合久久中文字幕| 日韩精品专区在线影院观看| 综合久久给合久久狠狠狠97色 | 欧美日韩中文字幕精品| 国产肉丝袜一区二区| 亚洲一区二区三区美女| 国产福利精品一区二区| 欧美日本高清视频在线观看| 国产精品另类一区| 蜜桃精品视频在线| 欧美视频在线一区| 国产精品伦理在线| 韩国女主播成人在线| 欧美日韩国产欧美日美国产精品| 欧美激情在线看| 奇米四色…亚洲| 欧美性videosxxxxx| 国产精品久久久久影院老司 | 欧美视频三区在线播放| 日本一区二区在线不卡| 美日韩一区二区三区| 在线一区二区三区做爰视频网站| 国产清纯美女被跳蛋高潮一区二区久久w| 亚洲国产裸拍裸体视频在线观看乱了| 成人免费毛片a| 精品久久一二三区| 日产国产高清一区二区三区 | 国产精品久久久久影院| 国产一区二区成人久久免费影院| 欧美唯美清纯偷拍| 亚洲人成网站在线| 成人av中文字幕| 国产三级一区二区| 国产一区二区视频在线播放| 中文字幕在线不卡| 欧美午夜影院一区| 51久久夜色精品国产麻豆| 136国产福利精品导航| 国产麻豆91精品| 日韩色视频在线观看| 日韩成人一级大片| 欧美精品免费视频| 午夜激情一区二区三区| 欧美综合视频在线观看| 亚洲精选视频免费看| 91浏览器打开| 亚洲天堂久久久久久久| 91网站在线观看视频| 亚洲视频一区二区在线观看| 97久久精品人人做人人爽| 国产精品蜜臀av| 99久久精品免费看国产| 中文字幕一区三区| 色94色欧美sute亚洲线路二| 亚洲女同一区二区| 欧美视频中文字幕| 日韩国产欧美一区二区三区| 日韩欧美国产综合| 韩国女主播一区| 久久久久久久精| 成人污视频在线观看| 中文字幕一区二区三区乱码在线| 99天天综合性| 亚洲国产日韩一区二区| 欧美一级精品在线| 国产伦精品一区二区三区免费| 久久精品在线观看| 97精品视频在线观看自产线路二| 亚洲男同性视频| 欧美精品日韩综合在线| 精品一区二区精品| 国产亚洲一二三区| 91麻豆国产自产在线观看| 亚洲不卡av一区二区三区| 91精品婷婷国产综合久久性色| 久久精品久久久精品美女| 久久精品欧美一区二区三区不卡| 成人一区二区三区| 亚洲国产精品影院| 欧美va亚洲va香蕉在线| 高清在线不卡av| 亚洲影院理伦片| 精品久久国产老人久久综合| 高清不卡在线观看| 一区二区三区中文字幕在线观看| 91麻豆精品国产自产在线| 国产一区二区影院| 一区二区三区日韩欧美| 欧美大肚乱孕交hd孕妇| 成人av电影在线网| 日韩高清一区在线| 中文乱码免费一区二区| 欧美三级中文字幕在线观看| 捆绑调教一区二区三区| 中文字幕一区二区三区不卡| 555夜色666亚洲国产免| 成人午夜精品在线| 午夜av一区二区| 国产欧美一区二区精品仙草咪| 欧美自拍偷拍一区| 国产精品一区免费在线观看| 亚洲已满18点击进入久久| 精品国产伦理网| 91久久精品午夜一区二区| 久久99在线观看| 亚洲精品国产a久久久久久| 日韩欧美国产综合| 欧美综合一区二区| 国产成人精品免费在线| 亚洲高清免费观看高清完整版在线观看| 26uuu亚洲综合色欧美 | 中文字幕av一区 二区| 欧美日韩久久不卡| 成人18精品视频| 蜜臀91精品一区二区三区| 亚洲人亚洲人成电影网站色| 精品少妇一区二区三区在线播放| 一本久久综合亚洲鲁鲁五月天| 国产乱码字幕精品高清av| 亚洲精品成人精品456| 91免费国产在线| 欧美亚洲动漫制服丝袜| 午夜久久久影院| 亚洲欧洲99久久| 久久色成人在线| 日韩视频中午一区| 欧美老女人在线| 91黄视频在线观看| 成人性生交大片| 国产一区二区三区久久久| 天天综合网 天天综合色| 夜夜揉揉日日人人青青一国产精品| 国产精品乱码人人做人人爱| 国产亚洲精品免费| 精品国产乱码久久| 日韩精品一区二区三区老鸭窝| 欧美日韩的一区二区| 在线国产电影不卡| 91免费观看视频在线| 成人免费观看男女羞羞视频| 国产酒店精品激情| 国产精品自拍一区| 极品少妇xxxx精品少妇偷拍| 久久国产成人午夜av影院| 麻豆精品一区二区综合av| 视频一区欧美精品| 午夜欧美视频在线观看| 亚洲电影视频在线|