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

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

?? symbol.c

?? 微軟的基于HMM的人臉識別原代碼, 非常經(jīng)典的說
?? C
?? 第 1 頁 / 共 2 頁
字號:
	  case t_struct:
	    if(type->alias)
		break;
	    s = EiC_getInf(type);
	    /*
	     * REM must allow for incomplete
	     * types.
	     */
	    if(!s)
		break;
	    xmark(s,mark);
	    if(!s->cl)
		break;
	    xmark(s->offset,mark);
	    xmark(s->id,mark);
	    xmark(s->type,mark);
	    for(i=0;i<s->n;i++) {
		xmark(s->id[i],mark);
		EiC_marktype(s->type[i],mark);
	    }
	    if(s->ntags) {
		xmark(s->tag,mark);
		for(i=0;i<s->ntags;++i)
		    EiC_marktype(s->tag[i],mark);
	    }
	    break;
	}
	type = nextType(type);
    }
}

static void marklabel(Label_t *l,char mark) 
{
    while(l) {
	xmark(l,mark);
	xmark(l->name,mark);
	l = l->nxt;
    }
}

static void markcode(symentry_t *sym,char mark)
{
    int i;
    InsT_t *inst;
    code_t * code;
    code = EiC_ENV->AR[sym->val.ival].v.p.p;
    xmark(code,mark);
    xmark(code->inst,mark);
    marklabel(code->labels,mark);
    marklabel(code->gotos,mark);

    inst = code->inst;
    for(i=0;i<code->nextinst;i++,inst++)
	if(inst->opcode == jmptab) {
	    eicstack_t * s;
	    s = inst->val.p.p;
	    xmark(s->val,mark);
	    xmark(s,mark);
	} else if(inst->opcode == assigntype)
	    EiC_marktype(inst->val.p.p,mark);
}


void EiC_marksyms(char mark)
{
    void EiC_markmacros(char);
    void EiC_markENV(char);
    
    int i;
    symentry_t * sym;

    EiC_markmacros(mark);
    
    if(EiC_ENV->AR)
	xmark(EiC_ENV->AR,mark);
    if(EiC_ENV->ARgar.n) 
	xmark(EiC_ENV->ARgar.val,mark);
    if(EiC_ENV->LAR)
	xmark(EiC_ENV->LAR,mark);
    if(EiC_ENV->CODE.nextinst)
	xmark(EiC_ENV->CODE.inst,mark);
    xmark(EiC_ENV,mark);

    EiC_markENV(mark);
    
    for(i=0;i<HSIZE;i++) {
	sym = EiC_HTAB[i];
	while(sym) {
	    /*printf("marking %s\n",sym->id);*/
	    if(strcmp(sym->id,"p") == 0)
	      sym->id = sym->id;
	    xmark(sym,mark);
	    xmark(sym->id,mark);
	    EiC_marktype(sym->type,mark);	    
	    if(sym->nspace != tag_tab)
		switch(EiC_gettype(sym->type)) {
		  case t_func: markcode(sym,mark); break;
		  case t_array:
		  case t_union:
		  case t_struct:
		    if(isconst(sym->type))
		       xmark(sym->val.p.p,mark);
		    else
			if(sym->sclass != c_typedef && sym->val.ival >= 0)
			    xmark(EiC_ENV->AR[sym->val.ival].v.p.p,mark);
		    break;
		}
	    sym = sym->next;
	}
    }
}


char * EiC_strsave(char *s)
{
    char *p;
    int n;

    for(n = 0,p =s; *p != '\0';++p,++n)
	;
    n++;
    p = xcalloc(n,sizeof(char));
    if(p) 
	while((*p++ = *s++));
    return p - n;
}

void EiC_newsymtype(symentry_t *sym, type_expr *t)
{
    if(sym) {
	if(sym->type && sym->type != t)
	    EiC_freetype(sym->type);
	sym->type = t;
    }
}

int nextstackitem(int level)
{
    if(level == 1) {		/* static variables */
	val_t v;
	if(!EiC_eicpop(&EiC_ENV->ARgar,&v))  { /* check for spare slots */
	    if(EiC_ENV->sp == EiC_ENV->ARsize) {
		if(!EiC_ENV->ARsize)
		    EiC_ENV->AR = (AR_t*)xcalloc(sizeof(AR_t),1);
		else
		    EiC_ENV->AR = (AR_t*)xrealloc(EiC_ENV->AR,
					      (EiC_ENV->sp+1)*sizeof(AR_t));
		EiC_ENV->ARsize++;
	    }
	    v.ival = EiC_ENV->sp;
	    EiC_ENV->sp++;
	}
	return v.ival;
    } else {			/* automatic variables */
	if(EiC_ENV->lsp == EiC_ENV->LARsize) {
	    if(!EiC_ENV->LARsize)
		EiC_ENV->LAR = (AR_t*)xcalloc(sizeof(AR_t),1);
	    else
		EiC_ENV->LAR = (AR_t*)xrealloc(EiC_ENV->LAR,(EiC_ENV->lsp+1)*
					   sizeof(AR_t));
	    EiC_ENV->LARsize++;
	}
	EiC_ENV->lsp++;
	return EiC_ENV->lsp - 1;
    }
}

int EiC_stackit(symentry_t * sym,int level)
{
    int i;
    AR_t * ar;
    
    i = nextstackitem(level);
    if(level == 1)		/* static variables */
	ar = EiC_ENV->AR;
    else 			/* local variable */	
	ar = EiC_ENV->LAR;

    sym->val.ival = i;

    ar[i].v.dval = 0; /* NULL it */
    ar[i].type = sym->type;
    return i;
}


/*------------------------------------------------*/
void EiC_inittoken(token_t * e1)
{
    e1->Pflag = 0;
    e1->Code.binst = e1->Code.nextinst = 0;
    e1->Code.labels = e1->Code.gotos = NULL;
    e1->Typequal = e1->Sclass = 0;
    e1->Sym = NULL;
    e1->Val.sym = NULL;
    e1->Type = NULL;
}
void EiC_freetoken(token_t * e1)
{
    EiC_freetype(e1->Type);
    e1->Type = NULL;
}
void initcode(code_t * code)
{
    code->binst = code->nextinst = 0;
}


void EiC_cleancode(code_t * code)
{
    unsigned int i;
    InsT_t *inst;

    if(!code)
	return;
    inst = code->inst;
    /* printf("Next instr: %d\n", code->nextinst); */
    /* rem free up other info also */
    for(i=0;i<code->nextinst;i++,inst++)
	if(inst->opcode == jmptab) {
	    eicstack_t *s;
	    s = inst->val.p.p;
	    xfree(s->val);
	    xfree(s);
	} else if(inst->opcode == assigntype)
	    EiC_freetype(inst->val.p.p);

}    

static void freeCodeLabels(code_t *code)
{
    void EiCp_freeLabels(Label_t *lab);
    if(code->labels) {
	EiCp_freeLabels(code->labels);
	code->labels = NULL;
    }
    if(code->gotos) {
	EiCp_freeLabels(code->gotos);
	code->gotos = NULL;
    }
}

void EiC_killcode(symentry_t *sym)
{
    code_t * code;
    code = EiC_ENV->AR[sym->val.ival].v.p.p;
    if(!code)
	return;
    EiC_cleancode(code);
    freeCodeLabels(code);
    xfree(code->inst);
    xfree(code);
}
void EiC_freecode(code_t * code)
{

    if(code && code->binst > 0) {
	xfree(code->inst);
	code->nextinst = code->binst = 0;
	freeCodeLabels(code);
    }
}

#define ModSize 5

void EiC_generate(code_t * code, int opcode,val_t *val,int ext)
{
    InsT_t * inst;
    inst = code->inst;
    if(code->nextinst == code->binst)
	if(!(code->binst%ModSize)) {
	    if(!code->binst)
		inst = (InsT_t*)xcalloc(1,sizeof(InsT_t)*ModSize);
	    else
		inst = (InsT_t*)
		    xrealloc(inst,(code->binst+ModSize)*sizeof(InsT_t));
	    code->binst += ModSize;
	}
    code->inst = inst;
    inst[code->nextinst].opcode = opcode;
    inst[code->nextinst].val = *val;
    inst[code->nextinst].ext = ext;
    inst[code->nextinst].line = CurrentLineNo();
    code->nextinst++;
}

#if 0
void copycode(code_t * c1, code_t * c2)
{
    /* this function needs to handle label and gotos */
    unsigned int i;
    InsT_t *inst;
    inst = c2->inst;
    for(i=0;i<c2->nextinst;++i,++inst) {
	EiC_generate(c1,inst->opcode,&inst->val,inst->ext);
	c1->inst[c1->nextinst-1].line = inst->line;
    }
}
#else
void copycode(code_t * c1, code_t * c2)
{
    Label_t * EiCp_addLabel(Label_t *, char *, int, int);
    InsT_t *inst;
    int h, Tsize;
    Label_t *lab;

    if(!c2->nextinst)
	return;
    /* concatenate labels*/
    if(c2->labels) {
	lab = c2->labels;
	while(lab) {
	    c1->labels = EiCp_addLabel(c1->labels,lab->name,lab->loc+c1->nextinst,1);
	    lab = lab->nxt;
	}
    }
    /* conatenate gotos */
    if(c2->gotos) {
	lab = c2->gotos;
	while(lab) {
	    c1->gotos = EiCp_addLabel(c1->gotos,lab->name,lab->loc+c1->nextinst,0);
	    lab = lab->nxt;
	}
    }

    Tsize = c1->nextinst + c2->nextinst;
    /* make memory size a multiple of ModSize */
    h = Tsize;
    if(Tsize%ModSize) 
	Tsize += ModSize - (Tsize%ModSize);
    if(c1->binst)
	c1->inst = xrealloc(c1->inst,Tsize*sizeof(InsT_t));
    else
	c1->inst = xcalloc(Tsize,sizeof(InsT_t));
    inst = c1->inst;
    memcpy(&inst[c1->nextinst], c2->inst, c2->nextinst * sizeof(InsT_t));
    c1->binst = Tsize;
    c1->nextinst = h;
}

#endif

void EiC_concode(code_t * c1, code_t * c2)
{
    copycode(c1,c2);
    EiC_freecode(c2);
}
void EiC_contoken(token_t * e1, token_t * e2)
{
    EiC_concode(&e1->Code,&e2->Code);
    e1->Type = EiC_getcontype(e1->Type,e2->Type);
    EiC_freetoken(e2);
}

void EiC_swaptokens(token_t *e1, token_t * e2)
{
    token_t e3;
    e3 = *e2;
    *e2 = *e1;
    *e1 = e3;
}
    

#if 0

typedef struct list_t {
    char * fname;
    struct list_t *nxt;
}list_t;


typdef struct llist_t {
    list_t **list;
    int n;
} llist_t;

static llist_t ** includes = NULL, ** included = NULL;

static int inllist(llist_t **list, char *fname)
{
    /* returns -1 if not in list */
    int i;
    for(i=0;i<list->n,++i) {
	if(fname == list->list[i]->fname == 0)
	    return i;
    }
    return -1;
}

static list_t * add2list(list_t *list, char *fname)
{
   list_t n = calloc(sizeof(list_t),1);
   n->fname = fname;
   n->nxt = list;
   return n;
}


static void add2includes(char *file, char * includes)
{
    int i = inlist(includes,file);

    if(i < 0) {
	i = includes->n;
	includes->list = realloc(includes->list, 
				 (includes->n + 1) * sizeof(*includes->list));
	
	includes->list = 
	includes





#endif

















?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品一区二区三区久久久久久| 国产精品乱人伦| 五月天中文字幕一区二区| 色悠久久久久综合欧美99| 国产精品国产三级国产a| 国产成人免费xxxxxxxx| 久久嫩草精品久久久精品一| 国模娜娜一区二区三区| ww亚洲ww在线观看国产| 国产一区二区伦理片| 欧美精品一区二区在线观看| 狠狠色综合播放一区二区| 日韩欧美不卡在线观看视频| 美女性感视频久久| 日韩一区二区三区在线| 久久99久久久久久久久久久| 日韩欧美色电影| 久久福利视频一区二区| 欧美精品一区二区精品网| 精品无码三级在线观看视频| 久久先锋影音av鲁色资源网| 国产精品88av| 国产精品美女久久久久aⅴ| 9色porny自拍视频一区二区| 亚洲欧美成aⅴ人在线观看| 色哦色哦哦色天天综合| 亚洲高清在线视频| 欧美一区二区三区的| 另类调教123区| 国产农村妇女毛片精品久久麻豆| 成人禁用看黄a在线| 亚洲精品国产一区二区精华液 | 九九视频精品免费| 26uuu精品一区二区| 国产黄人亚洲片| 综合自拍亚洲综合图不卡区| 欧美最猛性xxxxx直播| 蜜臀久久99精品久久久画质超高清| 精品国产在天天线2019| 成人av资源在线| 亚洲一区二区三区影院| 精品久久久久久久久久久久久久久| 国产成都精品91一区二区三| 亚洲精品欧美在线| 欧美一区二区不卡视频| 国产成人精品亚洲日本在线桃色| 亚洲同性同志一二三专区| 9191精品国产综合久久久久久| 久久成人综合网| 中文字幕在线观看不卡| 欧美日本在线播放| 黑人精品欧美一区二区蜜桃| 亚洲欧洲日韩女同| 这里只有精品99re| 成人久久视频在线观看| 亚洲国产毛片aaaaa无费看 | 欧美日韩精品综合在线| 精品在线免费视频| 亚洲色图色小说| 欧美一区二区三区在线电影 | 成a人片亚洲日本久久| 午夜精彩视频在线观看不卡| 国产亚洲精久久久久久| 91福利视频网站| 国产在线视频精品一区| 亚洲精品中文在线| 久久丝袜美腿综合| 欧美亚洲高清一区二区三区不卡| 精品影视av免费| 一区二区三区国产精品| 精品少妇一区二区三区日产乱码 | 亚洲成人久久影院| 国产片一区二区三区| 欧美性生活久久| 国产精品69毛片高清亚洲| 亚洲五月六月丁香激情| 国产欧美精品一区二区色综合| 欧美色爱综合网| 成人一道本在线| 欧美aⅴ一区二区三区视频| 国产精品萝li| 精品久久免费看| 欧美人与z0zoxxxx视频| av不卡一区二区三区| 黄色小说综合网站| 午夜精品一区二区三区电影天堂 | 精品一区二区在线免费观看| 一级日本不卡的影视| 国产欧美日韩不卡免费| 欧美一级一级性生活免费录像| 色综合天天做天天爱| 国产精品1区2区| 免费观看30秒视频久久| 亚洲伦在线观看| 国产精品女主播av| 精品999在线播放| 欧美精品日韩一区| 色乱码一区二区三区88| 国产成人精品在线看| 经典三级视频一区| 日本不卡视频在线| 亚洲电影视频在线| 亚洲美女区一区| 国产精品天干天干在线综合| 日韩免费一区二区| 欧美日韩国产a| 91国模大尺度私拍在线视频| 成人app网站| 国产一区二区三区久久久 | 免费一级欧美片在线观看| 一区二区在线免费观看| 亚洲欧洲精品成人久久奇米网| 久久这里只有精品6| 精品噜噜噜噜久久久久久久久试看| 欧美美女黄视频| 欧美日本乱大交xxxxx| 欧洲亚洲精品在线| 91麻豆国产精品久久| 不卡的av在线播放| 成人夜色视频网站在线观看| 国产大片一区二区| 国内精品视频一区二区三区八戒| 老司机精品视频一区二区三区| 日本人妖一区二区| 日韩成人一级大片| 日本亚洲最大的色成网站www| 亚洲国产精品久久久久婷婷884| 亚洲影视在线观看| 一区二区欧美国产| 一区二区三区四区激情| 亚洲女女做受ⅹxx高潮| 亚洲人吸女人奶水| 亚洲最大的成人av| 亚洲一区影音先锋| 午夜精品久久久久久久久久久 | 亚洲你懂的在线视频| 日韩一区欧美一区| 亚洲婷婷在线视频| 亚洲综合免费观看高清完整版| 亚洲成人免费视| 青青草成人在线观看| 久久国产精品无码网站| 国产永久精品大片wwwapp| 国产成人免费xxxxxxxx| proumb性欧美在线观看| 91免费看视频| 欧美日韩午夜影院| 日韩免费视频一区二区| 久久久久久亚洲综合影院红桃 | 亚洲超丰满肉感bbw| 日韩精品91亚洲二区在线观看| 老司机精品视频一区二区三区| 国模少妇一区二区三区| 国产ts人妖一区二区| 99re亚洲国产精品| 欧美色手机在线观看| 日韩欧美亚洲国产另类| 国产女人aaa级久久久级| 亚洲色图制服丝袜| 午夜婷婷国产麻豆精品| 久久国产欧美日韩精品| 成人午夜大片免费观看| 一本色道久久加勒比精品| 3d动漫精品啪啪一区二区竹菊| 欧美大片一区二区| 亚洲国产高清在线| 亚洲二区在线观看| 国产最新精品免费| 91麻豆国产福利精品| 91精品国产综合久久小美女| 久久久精品日韩欧美| 亚洲女人小视频在线观看| 日韩av网站免费在线| 国产成人aaa| 欧美三区在线视频| 久久久影视传媒| 亚洲人成网站影音先锋播放| 日本不卡在线视频| 高清不卡一区二区| 欧美日韩大陆在线| 国产亚洲一区二区三区四区| 亚洲激情网站免费观看| 狠狠色丁香婷综合久久| 色狠狠一区二区三区香蕉| 日韩欧美成人激情| 亚洲欧美激情插| 狠狠色综合播放一区二区| 91高清视频免费看| 欧美xxxx老人做受| 亚洲激情图片小说视频| 精品一区精品二区高清| 日本久久精品电影| 精品久久国产老人久久综合| 亚洲欧美日韩成人高清在线一区| 蜜桃精品视频在线| 97久久精品人人做人人爽| 日韩精品一区二区三区在线| 亚洲欧洲日韩在线| 国内成+人亚洲+欧美+综合在线| 欧美在线一二三四区|