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

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

?? mangle.c

?? 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一区二区三区免费野_久草精品视频
国产精品456露脸| 精品一区二区三区视频| 国产亚洲综合av| 日韩欧美一级二级三级| 欧美日韩美少妇| 精品视频在线免费看| 欧美在线啊v一区| 在线视频你懂得一区| 在线一区二区三区四区五区| 在线精品视频一区二区三四| 欧美在线短视频| 欧美区在线观看| 日韩一卡二卡三卡| 精品国产乱码久久久久久久| 日韩三级视频中文字幕| 欧美精品一区二区蜜臀亚洲| 国产亚洲美州欧州综合国| 欧美国产亚洲另类动漫| 亚洲欧洲日产国产综合网| 一区二区三区中文字幕| 亚洲成人动漫精品| 麻豆极品一区二区三区| 成人免费视频caoporn| 一本一本大道香蕉久在线精品| 欧美在线观看一区| 精品国产乱码久久久久久浪潮| 中文一区一区三区高中清不卡| 亚洲欧美另类在线| 视频在线在亚洲| 成人免费视频网站在线观看| 在线看不卡av| 久久综合网色—综合色88| 亚洲色图欧美激情| 免费一级欧美片在线观看| 成人一区二区三区视频| 欧美人与性动xxxx| 国产视频911| 亚洲一区二区三区四区在线观看| 国内一区二区视频| 在线观看亚洲一区| 国产精品无人区| 日日摸夜夜添夜夜添亚洲女人| 国产精品白丝jk白祙喷水网站| 欧美色图12p| 国产精品日日摸夜夜摸av| 日韩精品1区2区3区| 99久久精品国产观看| 欧美刺激午夜性久久久久久久| 亚洲天堂a在线| 国产一区二区福利| 欧美区一区二区三区| 亚洲欧美偷拍三级| 国产精品一区专区| 3d成人动漫网站| 有码一区二区三区| eeuss鲁片一区二区三区 | 欧美变态tickle挠乳网站| 1000部国产精品成人观看| 国产一区二区三区在线看麻豆| 欧美日韩国产区一| 一区二区免费视频| 99精品久久只有精品| 国产亲近乱来精品视频| 精品一区二区在线播放| 在线综合视频播放| 亚洲国产精品自拍| 欧美伊人久久久久久久久影院| 国产精品卡一卡二| 成人小视频免费在线观看| 久久女同精品一区二区| 国产一区中文字幕| 日韩精品一区二区三区视频播放 | 国产精一品亚洲二区在线视频| 在线成人午夜影院| 天天综合网 天天综合色| 在线免费观看不卡av| 一级女性全黄久久生活片免费| 99国产精品99久久久久久| 国产精品传媒视频| av激情综合网| 中文字幕中文字幕一区| jizzjizzjizz欧美| 亚洲日本免费电影| 在线免费精品视频| 婷婷综合另类小说色区| 在线不卡的av| 免费成人小视频| 精品国产免费一区二区三区四区| 寂寞少妇一区二区三区| 337p粉嫩大胆噜噜噜噜噜91av| 国产尤物一区二区在线| 中文字幕高清一区| 91久久精品一区二区三区| 亚洲第一福利一区| 欧美一级理论片| 国产精品一区二区视频| 欧美国产亚洲另类动漫| 欧美在线观看一二区| 日产欧产美韩系列久久99| 久久久电影一区二区三区| 成人久久18免费网站麻豆| 亚洲小说欧美激情另类| 日韩免费观看高清完整版在线观看| 国产在线不卡一卡二卡三卡四卡| 中文字幕+乱码+中文字幕一区| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 国产亚洲午夜高清国产拍精品| www.亚洲色图| 日韩黄色免费电影| 国产亚洲成av人在线观看导航 | 日本欧美加勒比视频| 国产亚洲va综合人人澡精品| 91无套直看片红桃| 毛片不卡一区二区| 亚洲蜜桃精久久久久久久| 5858s免费视频成人| 成人网页在线观看| 免费一级片91| 一区二区三区在线免费观看| 日韩欧美一区二区在线视频| 99久久综合国产精品| 视频在线在亚洲| 中文字幕一区二区三区乱码在线| 欧美一二三区精品| 色婷婷综合久久久久中文一区二区| 捆绑调教一区二区三区| 一区二区三区成人在线视频| 国产亚洲欧美日韩日本| 欧美一级高清大全免费观看| 色偷偷久久一区二区三区| 国产91富婆露脸刺激对白| 日韩av一级片| 一区二区成人在线观看| 欧美韩国日本不卡| 久久蜜桃av一区精品变态类天堂| 欧美久久免费观看| 在线免费观看日本欧美| 99久久精品99国产精品| 成人免费高清视频在线观看| 蜜桃精品在线观看| 亚洲国产欧美一区二区三区丁香婷| 欧美国产97人人爽人人喊| 日韩精品一区二区三区四区 | 91国产精品成人| 成人性生交大片免费看中文| 蜜臀a∨国产成人精品| 五月天一区二区| 亚洲成人av福利| 亚洲影视在线播放| 亚洲一区二区精品久久av| 亚洲猫色日本管| 亚洲天堂免费看| 亚洲男人的天堂网| ...av二区三区久久精品| 国产精品视频一二三区| 国产精品久久一卡二卡| 亚洲国产高清在线观看视频| 国产精品国产三级国产a | 在线免费观看日本欧美| 在线观看免费亚洲| 欧美日韩国产首页在线观看| 538在线一区二区精品国产| 91精品国产综合久久久久久久久久| 欧美乱熟臀69xxxxxx| 欧美一区欧美二区| 精品福利在线导航| 中文字幕第一区综合| 亚洲靠逼com| 无吗不卡中文字幕| 亚洲午夜精品17c| 日欧美一区二区| 麻豆中文一区二区| 成人精品鲁一区一区二区| av电影天堂一区二区在线| 一本高清dvd不卡在线观看| 欧美三级日本三级少妇99| 日韩丝袜美女视频| 亚洲国产成人私人影院tom| 亚洲精选视频免费看| 天堂影院一区二区| 久久av老司机精品网站导航| 不卡视频一二三四| 欧美久久久久久蜜桃| 精品精品欲导航| 亚洲视频一区二区在线| 日本午夜一本久久久综合| 国产精品1区二区.| 欧美日韩综合在线免费观看| 精品国产乱码久久久久久图片 | 免费看欧美美女黄的网站| 国产激情视频一区二区三区欧美| 99热在这里有精品免费| 欧美一区二区三区免费大片| 中文字幕中文字幕在线一区| 日韩高清国产一区在线| 色综合久久88色综合天天| 91精品国产品国语在线不卡| 欧美激情艳妇裸体舞| 日韩高清不卡一区二区| 色狠狠综合天天综合综合|