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

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

?? mangle.c

?? 本程序集是Allen I. Holub所寫的《Compiler Design in C》一書的附隨軟件
?? C
字號:
/*
 * 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
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀精品一区二区三区在线观看| 成人黄色小视频| 3d动漫精品啪啪| 国产成人午夜精品影院观看视频 | 欧美另类videos死尸| 久久国产欧美日韩精品| 一区二区三区中文在线| 久久婷婷色综合| 日韩美一区二区三区| 91亚洲精华国产精华精华液| 日本亚洲视频在线| 亚洲欧美在线另类| 精品免费视频.| 欧美人xxxx| 91丨九色丨尤物| 91免费小视频| 懂色av一区二区三区免费观看| 一区二区三区在线视频播放| 欧美日韩成人综合天天影院| av资源站一区| 成人av网站在线| 国产精品自拍在线| 国产一区二区三区日韩| 国产麻豆视频精品| 国产成人福利片| 懂色中文一区二区在线播放| 成人免费福利片| 91丨porny丨蝌蚪视频| 国产一区二区久久| 国产不卡免费视频| 岛国一区二区在线观看| 成人精品视频一区二区三区 | 欧美图区在线视频| 欧美一级电影网站| 中文字幕日韩精品一区| 亚洲乱码国产乱码精品精可以看| 亚洲欧美日韩国产成人精品影院| 亚洲激情成人在线| 黄色精品一二区| 色综合久久综合| 欧美成人猛片aaaaaaa| 亚洲综合在线五月| 国产乱码精品一区二区三区忘忧草| 成人av资源在线| 日韩久久免费av| 怡红院av一区二区三区| 久久精品国产99| 欧美日韩成人在线一区| 国产精品三级av| 久久成人18免费观看| 欧洲一区在线电影| 国产精品欧美久久久久无广告| 国产精品不卡在线| 国产成人一区在线| 亚洲精品在线免费播放| 午夜精品福利一区二区三区av| 国产成人精品免费视频网站| 91精品国产综合久久久久久漫画| 中文字幕va一区二区三区| 日本不卡高清视频| 欧美猛男超大videosgay| 亚洲欧洲性图库| 粉嫩久久99精品久久久久久夜| 欧美一级精品大片| 另类小说图片综合网| 欧美一区二区在线视频| 日本最新不卡在线| 欧美日韩国产综合一区二区三区| 亚洲激情在线播放| 色8久久精品久久久久久蜜| 亚洲精品v日韩精品| 欧洲一区在线电影| 午夜视频一区在线观看| 欧美日韩高清一区二区不卡| 亚洲6080在线| 国产色一区二区| 在线影院国内精品| 秋霞影院一区二区| 日韩欧美亚洲国产精品字幕久久久| 麻豆国产一区二区| 亚洲免费av观看| 欧美精品一区二区三区高清aⅴ| 国产麻豆9l精品三级站| 亚洲三级小视频| 久久色视频免费观看| 欧美色综合天天久久综合精品| 日韩国产欧美三级| 成人免费在线视频观看| 精品国产成人系列| 91精品在线麻豆| 一本高清dvd不卡在线观看| 国产一区二区三区综合 | 国产精品欧美经典| 3d成人动漫网站| 日本道免费精品一区二区三区| 国产乱对白刺激视频不卡| 亚洲无线码一区二区三区| 国产精品三级视频| 国产精品系列在线| 久久夜色精品国产噜噜av| 91久久精品一区二区| 成人晚上爱看视频| 蜜桃久久久久久| 日韩av电影免费观看高清完整版| 一区二区三区在线观看网站| 国产天堂亚洲国产碰碰| 欧美国产国产综合| 中文字幕亚洲区| 亚洲欧美日韩精品久久久久| 亚洲欧美日韩国产综合| 亚洲国产综合在线| 日韩av中文在线观看| 激情六月婷婷综合| 成人国产精品免费网站| 99这里都是精品| 欧美影片第一页| 7777女厕盗摄久久久| 日韩欧美中文一区| 亚洲在线中文字幕| 青青草精品视频| 国产黄色成人av| 91浏览器在线视频| 精品美女在线播放| 日韩美女久久久| 蜜臀99久久精品久久久久久软件| 韩国精品在线观看| 在线免费不卡电影| 国产欧美精品一区二区三区四区| 亚洲日穴在线视频| 美女视频免费一区| 成人美女视频在线观看18| 91麻豆精品久久久久蜜臀| 亚洲精品少妇30p| 国产精品一区二区三区网站| 欧美性受极品xxxx喷水| 国产三级精品视频| 亚洲成人av电影在线| 丰满少妇在线播放bd日韩电影| 欧美在线不卡一区| 亚洲精品视频免费看| 日韩av电影免费观看高清完整版 | 国产精品一区二区三区99| 91一区二区三区在线观看| 精品国产一区二区三区不卡| 亚洲制服丝袜av| 欧美日韩精品欧美日韩精品一综合| 中文字幕一区二区三区在线播放| 日韩不卡一区二区三区| 欧美日韩一区二区电影| 亚洲成a人片在线不卡一二三区| 色综合天天综合网天天看片| 国产精品女人毛片| 成熟亚洲日本毛茸茸凸凹| 国产精品久久免费看| 不卡免费追剧大全电视剧网站| 国产午夜精品久久| 成人av集中营| 亚洲18女电影在线观看| 日韩欧美国产一区在线观看| 蜜桃视频一区二区| 久久久久久久国产精品影院| 成人av集中营| 亚洲永久免费av| 欧美videos中文字幕| av网站免费线看精品| 亚洲黄色av一区| 日韩一区二区不卡| aaa亚洲精品| 久久99精品久久久久婷婷| 国产精品国产三级国产三级人妇 | 国产日韩亚洲欧美综合| 91国偷自产一区二区使用方法| 亚洲成人福利片| 中日韩免费视频中文字幕| 欧美精品vⅰdeose4hd| 91在线porny国产在线看| 九九热在线视频观看这里只有精品| 自拍偷拍欧美激情| 国产拍欧美日韩视频二区| 日韩一二在线观看| 在线观看91av| 欧美浪妇xxxx高跟鞋交| 99视频精品在线| 丁香婷婷综合激情五月色| 美女精品自拍一二三四| 亚洲午夜成aⅴ人片| 亚洲欧美激情在线| 亚洲综合激情另类小说区| 欧美激情一区二区三区全黄| 精品国产麻豆免费人成网站| 欧美日韩精品免费| 日韩一区二区三免费高清| 91精品麻豆日日躁夜夜躁| 4438x亚洲最大成人网| 欧美一区二区美女| 久久久精品免费观看| 久久久国产一区二区三区四区小说 | 欧美一区二区久久久| 欧美tickling网站挠脚心| 精品国产伦一区二区三区观看方式|