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

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

?? function.c

?? Outputs messages to a 2line LCD
?? C
字號:
/* File function.c:e 2.1 (83/03/20,16:02:04) */
/*% cc -O -c %
 *
 */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "defs.h"
#include "data.h"
#include "headers.h"
 
static int getarg(char *vname, int t, int flag);


static int brkt_flag = 0;

/*
 * begin a function
 *
 * called from "parse", this routine tries to make a function out
 * of what follows
 * modified version.	 p.l. woods
 *
 */

static int argtop;
static int ptr, order;


void newfunc(void) {
	char vname[NAMESIZE];
	int k;
   int argptr[10];
	char tname[NAMESIZE];
	int _fptr, fptr;

	fexitlab = getlabel();

	if (!symname(vname) ) {
		error("illegal function or declaration");
		kill();
		return;
		}
	strcpy(tname, vname);
  	if (strcmp((char *)strupr(tname), "MAIN") == 0)
  		InMain = nflag = TRUE;
	else
   	InMain = FALSE;
   OrgFptr = 0;
   RegPntr = 0;
	if (ptr = findglb(vname)) {
   	symtab[ptr].used = 1;
		if (symtab[ptr].ident != FUNCDEF)
			multidef(vname);
		else 
			symtab[ptr].offset = symtab[ptr].ident = FUNCTION;
      OrgFptr = ptr;
		} 
	else {
		ptr = addglb(vname, FUNCTION, CINT, FUNCTION, PUBLIC, 0);
  		if (strcmp((char *)strupr(tname), "MAIN") == 0)
      	symtab[ptr].used = 1;
      }
	
	if (!match("("))
		error("missing open paren");
   if (stkchk && InMain)
   	CheckCode();
	LabPrefix();
	outstr(vname);
	col();
	nl();
   if (stkchk && InMain)
   	prologue();
	locptr = STARTLOC;
	argtop = 0;
	order = 0;
	stkp = 0;
	while (!match(")")) {
		if (amatch("register")) {
			if (amatch("char"))
				argptr[order++] = getarg(vname, CCHAR, 0);
			else
			if (amatch("int"))
				argptr[order++] = getarg(vname, CINT, 0);
			else
			if (amatch("long"))
				argptr[order++] = getarg(vname, CLONG, 0);
			else
				argptr[order++] = getarg(vname, CINT, 0);		// what else?
			} 
		else 
		if (amatch("char"))
			argptr[order++] = getarg(vname, CCHAR, 0);
		else
		if (amatch("int"))
			argptr[order++] = getarg(vname, CINT, 0);
      else
      if (amatch("unsigned")) {
      	if (amatch("int"))
				argptr[order++] = getarg(vname, UCINT, 0);
         else
         if (amatch("char"))
				argptr[order++] = getarg(vname, UCCHAR, 0);
         else {
         	error("Illegal argument type");
            junk();
            }
         }
      else
		if (amatch("long"))
			argptr[order++] = getarg(vname, CLONG, 0);
      else
      if (amatch("struct")) {
      	if (symname(vname)) {
         	fptr = findglb(vname);
      		argptr[order++] = getarg(vname, CSTRUCT, 0);
            }
       	}
      else
      if (amatch("void")) {
      	if (testmatch("("))
				argptr[order++] = getarg(vname, CINT, 0);
       	}
      else
      if (FindTypeDef()) {
      	if (symname(vname)) {
         	fptr = findglb(vname);
      		argptr[order++] = getarg(vname, CSTRUCT, 0);
            }
       	}
		else {
			error("illegal argument type");
			junk();
			}

		blanks();
		if (!streq(line + lptr, ")")) {
			if (!match(","))
				error("expected comma");
			}
		if (endst())
			break;
		}
	
   if (symtab[ptr].args != order)
   	error("Different number of arguments from definition");
	argtop = 0;
	while (order) {
     	order--;
		k = symtab[argptr[order]].offset;
      symtab[argptr[order]].offset = argtop;
      argtop += k;
		}
	
	fptr = _fptr = ptr;
   if (symtab[_fptr].storage == INTERRUPT)
   	PushState();
   JumpPending = 0;
	statement(YES);
   fptr = 0;
	if (LabelCount[fexitlab] > 0) {
		printlabel(fexitlab);
		col();
		nl();
      }
   if (symtab[_fptr].storage == INTERRUPT)
   	PopState();
   else {
		modstk(0);
		gret();
      }
	stkp = 0;
	locptr = STARTLOC;			// clear local stack
	// Uncomment this line to have register variables re-used
   // in every function:
	ResetRegBoundary();				// clear any register stack
}


void funcdef(void) {
	char vname[NAMESIZE];
	
	if (!symname(vname) ) {
		error("illegal function or declaration");
		kill();
		return;
		}
	if (ptr = findglb(vname)) {
		if (symtab[ptr].ident != FUNCDEF)
			multidef(vname);
		else 
		if (symtab[ptr].offset == FUNCTION)
			multidef(vname);
		} 
	else
		ptr = addglb(vname, FUNCDEF, CINT, FUNCDEF, PUBLIC, 0);
	
	if (!match("("))
		error("missing open paren");
	while (!match(")")) {
		if (amatch("register")) {
			if (amatch("char"))
				getarg(vname, CCHAR, 1);
			else
			if (amatch("int"))
				getarg(vname, CINT, 1);
			else
				getarg(vname, CINT, 1);		// what else?
			} 
		else 
		if (amatch("char"))
			getarg(vname, CCHAR, 1);
		else
		if (amatch("int"))
			getarg(vname, CINT, 1);
      else
      if (amatch("unsigned")) {
      	if (amatch("char"))
         	getarg(vname, UCCHAR, 1);
         else
         if (amatch("int"))
         	getarg(vname, UCINT, 1);
         else {
         	error("Illegal argument type");
            junk();
            }
         }
     	else
      if (amatch("long"))
        	getarg(vname, CLONG, 1);
		else
      if (amatch("struct")) {
         if (symname(vname))
      		getarg(vname, CSTRUCT, 1);
         }
      else
      if (amatch("void")) {
      	if (testmatch("("))
            getarg(vname, CINT, 1);
         else {
         	if (ch() == '*')
            	getarg(vname, CINT, 1);
            else
      			symtab[ptr].args = 0;
           	}
      	}
      else
      if (FindTypeDef()) {
         if (symname(vname))
      		getarg(vname, CSTRUCT, 1);
         }
      else {
			error("illegal argument type");
			junk();
			}

		blanks();
		if (!streq(line + lptr, ")")) {
			if (!match(","))
				error("expected comma");
			}
		if (endst())
			break;
		}
}

/*
 * declare argument types
 *
 * called from "newfunc", this routine adds an entry in the local
 * symbol table for each named argument
 * completely rewritten version.	 p.l. woods
 *
 */

static int getarg(char *vname, int type, int flag) {
	int ident;
	int argptr, offset, pp;

   if (match("(")) {
   	brkt_flag = 1;
      getarg(vname, type, flag);
   	brkt_flag = 0;
      return 0;
      }
   match("far");				// ignore any fars
   pp = findglb(vname);
	if (match("*")) {
   	if (match("*"))
      	ident = POINTERARRAY;
      else
			ident = POINTER;
      }
	else
		ident = VARIABLE;

	symname(vname);
	if (match("[")) {
		while (inbyte() != ']') {
			if (endst())
				break;
     		}
		ident = POINTER;
		}
   if (brkt_flag) {
  		if (!match(")"))
  			error("No closing bracket");
  		if (ch() == '(' && nch() == ')') {
        	ident = FUNCPTR;
         match("(");
         match(")");
         }
      }
   if (flag) {
     	// we are only defining these variables
     	order = symtab[ptr].args;
     	symtab[ptr].argtype[order].ident = ident;
      symtab[ptr].argtype[order].type = type;
      symtab[ptr].args++;
      }
   else {
		if (symtab[ptr].argtype[order].ident == ident && symtab[ptr].argtype[order].type == type) {
         if (ident == POINTER || ident == FUNCPTR)
           	offset = 2;
         else
        	if (type == CLONG)
           	offset = 4;
//         else
//         if (type == CCHAR || type == UCCHAR)
//           	offset = 1;
         else
				offset = intsize();

			if (argptr = addloc(vname, 0, 0, offset, AUTO, 0)) {
				symtab[argptr].ident = ident;
				symtab[argptr].type = type;
				if (ident != POINTER && (type == CCHAR || type == UCCHAR))
            	symtab[argptr].funcpar = 1;
        		if (type == CSTRUCT)
        			symtab[argptr].pntrpntr = pp;
				return argptr;
            }
         }
		else
        	error("Argument does not match definition or definition missing");
      }

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产喂奶挤奶一区二区三区| 国产精品久久久久精k8| 久久精品一区二区| 亚洲国产一区二区三区| 国产一区二区免费看| 欧美日韩国产首页| 国产精品乱码一区二三区小蝌蚪| 日韩中文字幕区一区有砖一区| 成人晚上爱看视频| 日韩欧美国产电影| 亚洲电影中文字幕在线观看| 成人精品在线视频观看| 欧美变态凌虐bdsm| 亚洲动漫第一页| 色综合色狠狠综合色| 国产精品沙发午睡系列990531| 麻豆视频观看网址久久| 欧美日韩国产不卡| 亚洲在线观看免费| 91福利在线免费观看| 国产精品妹子av| 国产丶欧美丶日本不卡视频| 欧美成va人片在线观看| 日韩在线一二三区| 在线成人午夜影院| 午夜电影一区二区三区| 欧美综合亚洲图片综合区| 国产精品麻豆99久久久久久| 国产成人免费网站| 国产夜色精品一区二区av| 美国毛片一区二区| 日韩免费电影一区| 另类人妖一区二区av| 日韩一级完整毛片| 一区二区三区电影在线播| 91在线国产福利| 国产精品白丝在线| 色综合中文字幕| 亚洲精品ww久久久久久p站| 色诱视频网站一区| 亚洲国产视频一区二区| 欧美三级电影网站| 婷婷中文字幕一区三区| 日韩一区二区免费电影| 精品一区二区三区在线播放| 精品蜜桃在线看| 国产91精品在线观看| 国产精品国产自产拍高清av王其 | 美国毛片一区二区三区| 精品粉嫩超白一线天av| 国产美女精品人人做人人爽| 欧美国产国产综合| 成人av免费在线观看| 亚洲一区二区在线免费看| 欧美高清一级片在线| 国产一区二区三区四| 中文在线一区二区| 色婷婷综合激情| 免费看欧美女人艹b| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 日韩成人免费在线| 26uuuu精品一区二区| 成人av网址在线| 亚洲一区二区欧美| 日韩精品专区在线影院观看| 国产成人免费视频网站高清观看视频| 国产精品黄色在线观看| 欧美一区二区精品久久911| 国产在线精品免费av| 日韩美女视频一区| 日韩免费成人网| 日本道免费精品一区二区三区| 激情综合网最新| 亚洲国产精华液网站w| 99久久免费国产| 日本成人在线一区| 国产精品丝袜在线| 欧美一个色资源| 日本久久一区二区| 国产精品一品视频| 三级精品在线观看| 亚洲女人的天堂| 久久久精品中文字幕麻豆发布| 欧美日韩在线电影| 成人av高清在线| 狠狠色伊人亚洲综合成人| 亚洲黄色性网站| 国产精品色哟哟| 精品国产伦一区二区三区免费| 一本高清dvd不卡在线观看| 狠狠色丁香婷婷综合| 视频一区国产视频| 一区二区三区加勒比av| 国产精品每日更新在线播放网址| 91精品中文字幕一区二区三区| 成人爱爱电影网址| 国产成人精品亚洲午夜麻豆| 日精品一区二区| 亚洲第一激情av| 亚洲天堂中文字幕| 久久先锋影音av鲁色资源网| 豆国产96在线|亚洲| 久久成人免费日本黄色| 一区二区三区中文字幕电影 | 精品三级av在线| 欧美剧情电影在线观看完整版免费励志电影| 国产精品一区二区免费不卡| 日韩不卡一二三区| 亚洲成a人v欧美综合天堂| 亚洲精选视频免费看| 国产精品国产三级国产普通话蜜臀 | 日韩一区和二区| 91精品久久久久久久99蜜桃| 欧美视频一区二区三区四区 | 高清不卡在线观看| 国产美女视频一区| 国产精品系列在线播放| 国内成人免费视频| 国产麻豆视频一区| 国产成人免费在线观看不卡| 国产成人精品免费看| 大胆亚洲人体视频| 99国产精品国产精品毛片| 97se亚洲国产综合自在线不卡| 99热精品一区二区| 欧美午夜精品久久久久久孕妇| 精品视频在线看| 欧美一级淫片007| 久久一区二区视频| 国产日韩欧美精品综合| 国产精品久久国产精麻豆99网站| 欧美高清在线视频| 亚洲三级免费电影| 亚洲成人资源在线| 国产在线乱码一区二区三区| 国产成人高清在线| 91免费在线看| 欧美久久免费观看| 综合自拍亚洲综合图不卡区| 久久久精品人体av艺术| 久久久www成人免费毛片麻豆| 26uuu国产一区二区三区| 在线免费不卡电影| 91国在线观看| 欧美无砖专区一中文字| 久久一日本道色综合| 欧美成人a∨高清免费观看| 久久精品一区八戒影视| 成人免费在线视频| 欧美日韩国产综合久久| 狠狠色狠狠色合久久伊人| 欧美日韩一区三区| 91.麻豆视频| 国产偷国产偷亚洲高清人白洁| 亚洲欧洲在线观看av| 青椒成人免费视频| 成人免费观看av| 欧美一区二区在线免费观看| 欧美国产日本视频| 亚洲v精品v日韩v欧美v专区| 国产福利一区二区| 欧美视频日韩视频| 国产精品你懂的在线欣赏| 日韩综合在线视频| 99视频在线精品| 精品欧美一区二区久久| 一区二区三区国产| 国产99久久久国产精品| 91精品久久久久久久91蜜桃| 亚洲免费看黄网站| 久久www免费人成看片高清| 欧美性受xxxx黑人xyx性爽| 久久久99免费| 日本不卡视频在线观看| 在线视频一区二区三| 国产精品免费视频观看| 男女男精品视频| 欧美主播一区二区三区| 国产精品免费观看视频| 黄网站免费久久| 91精品国产综合久久久久| 一区二区理论电影在线观看| 国产成人鲁色资源国产91色综| 欧美大尺度电影在线| 午夜精品国产更新| 97久久精品人人做人人爽| 欧美激情在线一区二区| 国内精品自线一区二区三区视频| 欧美夫妻性生活| 日本亚洲三级在线| 欧美伦理影视网| 亚洲成人av资源| 欧美二区乱c少妇| 午夜精品久久久久久久久| 欧美综合亚洲图片综合区| 亚洲综合在线免费观看| 色婷婷综合久久久中文字幕| 亚洲女厕所小便bbb| 91官网在线观看| 亚洲成人三级小说|