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

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

?? scandoc.cpp

?? 編譯原理--詞法掃描
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// scanDoc.cpp : implementation of the CScanDoc class
//

#include "stdafx.h"
#include "scan.h"

#include "scanDoc.h"

//#include "sscan.h"  //add by user

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

//external var

extern CTraceBar g_TraceBar;
CEdit* g_pEditCtrl;             //edit control


//extern SYMTAB_NODE_PTR symtab_root;
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
#include <iostream.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>

#ifndef FALSE
#define FALSE 0
#endif

#ifndef TRUE
#define TRUE 1
#endif

#define MAXRESERVED 8

const int namelen=40;
typedef struct symtab_node           //二叉樹的結(jié)點結(jié)構(gòu)
{
  struct symtab_node *left;          //指向左孩子
  struct symtab_node *right;         //指向右孩子
  char type[namelen+1];
  char name[namelen+1];              //指向標識符的名字串
  int lineno;						//line number
}SYMTAB_NODE,*SYMTAB_NODE_PTR;

SYMTAB_NODE_PTR symtab_root=NULL; 

typedef enum 
   {_ENDFILE,_ERROR,
    IF,THEN,ELSE,END,REPEAT,UNTIL,READ,WRITE,
    ID,NUM,
    ASSIGN,EQ,LT,PLUS,MINUS,TIMES,OVER,LPAREN,RPAREN,SEMI
   } tTokenType;

FILE* source; /* source code text file */
int lineno; /* source line number for listing */

int nStartChar=-1;
int nFilePos=-1;

#define MAXCHILDREN 3
#define MAXTOKENLEN 40

/* tokenString array stores the lexeme of each token */
char tokenString[MAXTOKENLEN+1];

/* states in scanner DFA */
typedef enum
   { START,INASSIGN,INCOMMENT,INNUM,INID,DONE }
   StateType;

/* BUFLEN = length of the input buffer for
   source code lines */
#define BUFLEN 256

static char lineBuf[BUFLEN]; /* holds the current line */
static int linepos = 0; /* current position in LineBuf */
static int bufsize = 0; /* current size of buffer string */
static int EOF_flag = FALSE; /* corrects ungetNextChar behavior on EOF */

/* lookup table of reserved words */
static struct
    { char* str;
      tTokenType tok;
    } reservedWords[MAXRESERVED]
   = {{"if",IF},{"then",THEN},{"else",ELSE},{"end",END},
      {"repeat",REPEAT},{"until",UNTIL},{"read",READ},
      {"write",WRITE}};


//在由np指向的樹中查找標識符*name
SYMTAB_NODE_PTR search_symtab(char *name,SYMTAB_NODE_PTR np)
{
  int cmp;
  while(np!=NULL)
  {
    cmp=strcmp(name,np->name);
    if(cmp==0) return(np);
    np=cmp<0 ? np->left : np->right;
  }
  return(NULL);
}

void visit_symtab(const SYMTAB_NODE_PTR np)
{
	if(np)
	{
		visit_symtab(np->left);
		cout<<np->name<<endl;
		visit_symtab(np->right);
	}
}

//在由npp指向的樹中加入名為*name,值為value的標識符結(jié)點
SYMTAB_NODE_PTR enter_symtab(const char *name,const char *type , int line,SYMTAB_NODE_PTR &npp)
{
  int cmp;
  SYMTAB_NODE_PTR np1,np2;
  SYMTAB_NODE_PTR new_nodep;
  new_nodep=new symtab_node;
  strncpy(new_nodep->name,name,namelen);
  strncpy(new_nodep->type,type,namelen);
  new_nodep->lineno=line;
  new_nodep->left=new_nodep->right=NULL;
  np1=npp;
  while(np1 != NULL)
  {
    cmp=strcmp(name,np1->name);
    np2=np1;
	np1 =cmp <0 ? (np1->left) : (np1->right);
  }
  np1=new_nodep;
  if(npp==NULL)
	  npp=new_nodep;
  else cmp < 0 ? np2->left=np1 : np2->right=np1;
  return(new_nodep);
}



/* getNextChar fetches the next non-blank character
   from lineBuf, reading in a new line if lineBuf is
   exhausted */
static int getNextChar(void)
{ 
    nFilePos ++;   //add for edit control ,start from 0;
	if (!(linepos < bufsize))
  { 
	lineno++;
    if (fgets(lineBuf,BUFLEN-1,source))
    { 
//    if (EchoSource) fprintf(listing,"%4d: %s",lineno,lineBuf);
      bufsize = strlen(lineBuf);
      linepos = 0;
      return lineBuf[linepos++];
    }
    else
    { EOF_flag = TRUE;
      return EOF;
    }
  }
	else return lineBuf[linepos++];
}

/* ungetNextChar backtracks one character
   in lineBuf */
static void ungetNextChar(void)
{ 
	if (!EOF_flag) linepos-- ;
	nFilePos--;
}


/* lookup an identifier to see if it is a reserved word */
/* uses linear search */
static tTokenType reservedLookup (char * s)
{ int i;
  for (i=0;i<MAXRESERVED;i++)
    if (!strcmp(s,reservedWords[i].str))
      return reservedWords[i].tok;
  return ID;
}

/****************************************/
/* the primary function of the scanner  */
/****************************************/
/* function getToken returns the 
 * next token in source file
 */
tTokenType getToken(void)
{  /* index for storing into tokenString */
   int tokenStringIndex = 0;
   /* holds current token to be returned */
   tTokenType currentToken;
   /* current state - always begins at START */
   StateType state = START;
   /* flag to indicate save to tokenString */
   int save;
   while (state != DONE)
   { 
    int c = getNextChar();
     save = TRUE;
     switch (state)
     { case START:
         if (isdigit(c))
           state = INNUM;
         else if (isalpha(c))
           state = INID;
         else if (c == ':')
           state = INASSIGN;
         else if ((c == ' ') || (c == '\t') || (c == '\n'))
		 {
			 save = FALSE;

		 /* in edit component ,SetSel() takes '\n' as two chars,
		  * so nFilePos must plus 2 
		  */
		 if(c=='\n')  nFilePos++;
		 }
         else if (c == '{')
         { save = FALSE;
           state = INCOMMENT;
         }
         else
         { state = DONE;
           switch (c)
           { case EOF:
               save = FALSE;
               currentToken = _ENDFILE;
               break;
             case '=':
               currentToken = EQ;
               break;
             case '<':
               currentToken = LT;
               break;
             case '+':
               currentToken = PLUS;
               break;
             case '-':
               currentToken = MINUS;
               break;
             case '*':
               currentToken = TIMES;
               break;
             case '/':
               currentToken = OVER;
               break;
             case '(':
               currentToken = LPAREN;
               break;
             case ')':
               currentToken = RPAREN;
               break;
             case ';':
               currentToken = SEMI;
               break;
             default:
               currentToken = _ERROR;
               break;
           }
         }
         break;
       case INCOMMENT:
         save = FALSE;
         if (c == EOF)
         { state = DONE;
           currentToken = _ENDFILE;
         }
		 /* in edit component ,SetSel() takes '\n' as two chars,
		  * so nFilePos must plus 2 
		  */
		 else if(c=='\n') nFilePos++;
         else if (c == '}') state = START;
         break;
       case INASSIGN:
         state = DONE;
         if (c == '=')
           currentToken = ASSIGN;
         else
         { /* backup in the input */
           ungetNextChar();
           save = FALSE;
           currentToken = _ERROR;
         }
         break;
       case INNUM:
         if (!isdigit(c))
         { /* backup in the input */
           ungetNextChar();
           save = FALSE;
           state = DONE;
           currentToken = NUM;
         }
         break;
       case INID:
         if (!isalpha(c))
         { /* backup in the input */
           ungetNextChar();
           save = FALSE;
           state = DONE;
           currentToken = ID;
         }
         break;
       case DONE:
       default: /* should never happen */
 //        fprintf(listing,"Scanner Bug: state= %d\n",state);
         state = DONE;
         currentToken = _ERROR;
         break;
     }
     if ((save) && (tokenStringIndex <= MAXTOKENLEN))
       tokenString[tokenStringIndex++] = (char) c;
     if (state == DONE)
     { tokenString[tokenStringIndex] = '\0';
       if (currentToken == ID)
         currentToken = reservedLookup(tokenString);
     }
   }
/*   if (TraceScan) {
     fprintf(listing,"\t%d: ",lineno);
     printToken(currentToken,tokenString);
   }
*/   return currentToken;
} /* end getToken */


void maint()

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看不卡一区| 久久91精品久久久久久秒播| 精品国产污污免费网站入口| 欧美亚洲丝袜传媒另类| jvid福利写真一区二区三区| 欧美吞精做爰啪啪高潮| 91看片淫黄大片一级在线观看| 亚洲一二三区不卡| 亚洲bdsm女犯bdsm网站| 亚洲日本韩国一区| 一区二区免费视频| 自拍偷拍欧美激情| 久久久噜噜噜久久中文字幕色伊伊 | 男人操女人的视频在线观看欧美| 国产人成亚洲第一网站在线播放| 久久婷婷综合激情| 久久成人久久鬼色| 国产精品视频你懂的| 精品国产一区二区三区不卡| 欧美一区二区高清| 欧美色手机在线观看| 日韩视频一区二区在线观看| 欧美一区二区三区四区高清| 欧美人与禽zozo性伦| 欧美日韩三级一区| 精品污污网站免费看| 精久久久久久久久久久| 亚洲人成网站在线| 亚洲午夜羞羞片| 亚洲激情图片qvod| 国产综合色在线| 91小视频在线免费看| 亚洲自拍欧美精品| 日韩亚洲欧美在线| 国产乱码精品一区二区三区av| 国产精品人妖ts系列视频| 欧美三级电影网站| 国产综合久久久久久鬼色 | 亚洲国产精品一区二区久久恐怖片 | 日韩欧美国产综合一区| 粉嫩av一区二区三区| 亚洲国产一区二区视频| 久久久久久一二三区| 欧美色爱综合网| 国产精品资源在线观看| 一区二区三区在线播| 久久理论电影网| 欧美日韩你懂的| 久久99国产精品麻豆| 亚洲午夜影视影院在线观看| 久久午夜羞羞影院免费观看| 精品污污网站免费看| 国产成人高清视频| 国产精品乱码一区二三区小蝌蚪| 欧美一区二区国产| 欧美自拍偷拍午夜视频| 粉嫩高潮美女一区二区三区| 秋霞影院一区二区| 亚洲在线免费播放| 亚洲视频狠狠干| 久久久91精品国产一区二区精品 | 久久午夜色播影院免费高清| 欧美日韩国产综合久久| eeuss鲁片一区二区三区在线看 | 国产精品综合av一区二区国产馆| 日韩精品亚洲一区二区三区免费| 亚洲国产精品久久久久秋霞影院| 亚洲色图在线视频| ...xxx性欧美| 国产亚洲欧洲一区高清在线观看| 精品久久久久久久人人人人传媒 | 亚洲精品视频一区| 一区在线观看免费| 中文字幕一区不卡| 国产精品免费人成网站| 国产视频一区二区三区在线观看| 精品国产乱码久久久久久老虎| 日韩一级二级三级| 日韩欧美一区二区在线视频| 欧美一区二区三区在线观看| 欧美一级专区免费大片| 日韩三级免费观看| 欧美大黄免费观看| 2017欧美狠狠色| 国产天堂亚洲国产碰碰| 国产农村妇女毛片精品久久麻豆 | 久久一二三国产| 日本一区二区三区四区在线视频 | 亚洲亚洲人成综合网络| 亚洲成av人片在线| 日韩国产在线一| 六月丁香综合在线视频| 狠狠色2019综合网| 成人午夜视频在线| 94-欧美-setu| 欧美日韩免费电影| 精品欧美乱码久久久久久1区2区| 久久五月婷婷丁香社区| 亚洲国产经典视频| 亚洲综合区在线| 蜜臀av一区二区在线免费观看 | 午夜精品久久久久影视| 日本成人超碰在线观看| 国产一区二区91| eeuss影院一区二区三区| 欧美日韩一级二级| 精品福利一二区| 亚洲视频一二三区| 男男gaygay亚洲| 成人av小说网| 欧美日韩dvd在线观看| 久久一夜天堂av一区二区三区| 《视频一区视频二区| 天堂蜜桃一区二区三区| 国产·精品毛片| 欧美日韩一区二区三区在线| 欧美精品一区二区在线播放| 中文字幕综合网| 麻豆视频观看网址久久| 99免费精品在线观看| 91精品国产综合久久婷婷香蕉 | 欧美高清一级片在线| 久久精品夜色噜噜亚洲aⅴ| 有码一区二区三区| 狠狠色丁香九九婷婷综合五月| 色播五月激情综合网| 26uuu成人网一区二区三区| 一区二区三区不卡在线观看| 国产综合一区二区| 欧美日韩dvd在线观看| 国产精品初高中害羞小美女文| 爽爽淫人综合网网站 | 欧美三级蜜桃2在线观看| 久久久久九九视频| 水蜜桃久久夜色精品一区的特点| www.日韩精品| 久久综合色之久久综合| 亚洲成人激情社区| 91蜜桃婷婷狠狠久久综合9色| 日韩欧美三级在线| 午夜一区二区三区视频| 成人福利视频网站| 久久久亚洲国产美女国产盗摄 | 欧美综合色免费| 国产精品私房写真福利视频| 免费在线成人网| 欧美精品日韩一区| 亚洲一区二区三区爽爽爽爽爽| 国产成人午夜精品5599| 欧美一区二区网站| 午夜精品影院在线观看| 在线观看欧美精品| 亚洲欧美福利一区二区| 91美女在线视频| 亚洲人午夜精品天堂一二香蕉| 国产精品亚洲成人| wwwwxxxxx欧美| 精品一区二区三区久久久| 欧美美女一区二区三区| 亚洲成人先锋电影| 欧美日韩中文字幕一区| 亚洲自拍偷拍网站| 欧美色综合天天久久综合精品| 亚洲少妇30p| 欧美性色综合网| 一区二区三区色| 欧美性做爰猛烈叫床潮| 亚洲最新视频在线播放| 欧美日韩亚洲丝袜制服| 亚洲成人av电影在线| 91麻豆精品国产91久久久久 | 韩国欧美国产一区| 久久夜色精品一区| 国产精品一二三在| 中文字幕不卡在线观看| 成人污视频在线观看| 中文字幕成人在线观看| 91啪九色porn原创视频在线观看| 国产精品白丝在线| 99久久精品久久久久久清纯| 亚洲欧美在线观看| 欧美在线播放高清精品| 图片区小说区国产精品视频| 91精品国产综合久久香蕉麻豆| 久久精品国产精品亚洲综合| 久久综合久久鬼色中文字| 国产**成人网毛片九色 | 香蕉乱码成人久久天堂爱免费| 欧美精品在线视频| 精品一区中文字幕| 久久久久久久久岛国免费| 波多野结衣91| 亚洲成av人**亚洲成av**| 日韩三级视频在线观看| 成人国产精品免费网站| 亚洲人成小说网站色在线| 91精品在线观看入口| 国产成人av自拍| 亚洲午夜在线视频| 久久亚区不卡日本|