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

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

?? main.pas

?? 編譯原理實驗 完整的
?? PAS
?? 第 1 頁 / 共 4 頁
字號:
    else begin
           ScanError(2);
           IValue:=maxint;
           repeat GetCh until not (ch in digits)
         end
    until not (ch in digits);
    if ch in letters then ScanError(3);
    PutSy(intconst);
  end{number};

  procedure string0;
    var ch1,ch2 :char;  MissRight:Boolean;
    procedure EnterSTab;
      var tsPlusSLength:cardinal;
    begin{EnterSTab};
      tsPlusSLength:=ts+SLength;
      if tsPlusSLength>tsmax
      then TabOverflow(stringtab,SyPos)
      else
        STab[tsPlusSLength]:=ch1
    end{EnterSTab};
  begin{string}
    OnString:=true;
    SLength:=0;
    GetCh;  ch2:=ch;
    repeat
      ch1:=ch2;
      MissRight:=ChPos.CharNumber=LastInLine;
      if not MissRight
      then begin
             GetCh; ch2:=ch;
             if(ch1<>'"')or(ch1='"')and(ch2='"')
             then begin
                    SLength:=succ(SLength);
                    EnterSTab;
                    if(ch1='"')and(ch2='"')
                  then begin ch1:=' ';  GetCh; ch2:=ch end
                  end
           end
    until (ch1='"')or MissRight;
    if MissRight
    then begin  ScanError(4);  GetCh  end
    else if SLength<=1
         then begin
                if SLength=0 then ScanError(4);
                CValue:=ord(STab[succ(ts)]);
                PutSy(charconst)
              end
         else begin
                sEntry:=succ(ts);
                PutSy(strconst);
                if not (stringtab in overflow)then ts:=ts+SLength
              end;
    OnString:=false
  end{string};


procedure comment1;
  var ch1,ch2  :char;  MissRight:Boolean;
begin{comment1}
  GetCh;  ch2:=ch;
  repeat
    ch1:=ch2;
    MissRight:=ChPos.CharNumber=LastInLine;
    if MissRight
    then ScanError(5)
    else begin  GetCh;  ch2:=ch  end;
  until(ch1='*') and (ch2=')') or MissRight;
  if not(eof(PAS)and MissRight) then Getch
end{comment1};

procedure comment2;
  var MissRight: Boolean;
begin{comment2}
  repeat
    GetCh;
    MissRight:=ChPos.CharNumber=LastInLine;
    if MissRight then ScanError(5);
  until(ch='}')or MissRight;
  if not(eof(PAS)and MissRight)then GetCh
end{comment2};

procedure scan;
  var LegalFirstChar:set of char;
begin
  LegalFirstChar:=letters+digits+[' ','"','+','-','*',
       '<','=','>','{','(',')','[',']','.',':',',',';'];
  while not EndScan do
  begin
    SyPos:=ChPos;
    if ch in LegalFirstChar
    then case ch of
  ' '   :GetCh;
  'A','B','C','D','E','F','G','H','I','J','K','L','M',
  'N','O','P','Q','R','S','T','U','V','W','X','Y','Z'
        :identifier{or reserved word};
  '1','2','3','4','5','6','7','8','9'
        :number;
  '"'   :string0;
             {2-xharacter special symbols}
  '<'   :begin
           GetCh;
           if ch='='
           then begin PutSy(leop); GetCh end
           else if ch='>'
                then begin PutSy(neop); GetCh end
                else PutSy(lsop)
         end;
  '>'   :begin
           GetCh;
           if ch='='
           then begin PutSy(geop); GetCh end
           else PutSy(gtop)
         end;
  ':'   :begin
           GetCh;
           if ch='='
           then begin PutSy(becomes); GetCh end
           else PutSy(colon)
         end;
  '.'   :begin
           GetCh;
           if ch='='
           then begin PutSy(range); GetCh end
           else PutSy(period)
         end;
  '('   :begin
           GetCh;
           if ch='*' then comment1 else PutSy(lparent)
         end;
  '{'   :comment2;
  '+'   :begin PutSy(plus);         GetCh end;
  '-'   :begin PutSy(minus);        GetCh end;
  '*'   :begin PutSy(times);        GetCh end;
  '='   :begin PutSy(eqop);         GetCh end;
  ')'   :begin PutSy(rparent);      GetCh end;
  '['   :begin PutSy(lbracket);     GetCh end;
  ']'   :begin PutSy(rbracket);     GetCh end;
  ','   :begin PutSy(comma);        GetCh end;
  ';'   :begin PutSy(semicolon);    GetCh end;
         end{case}
      else begin PutSy(other);  ScanError(1);  GetCh end
    end{while}
  end{scan};
begin{LexicalAnalysis}
  InitResWords;
  InitSets;
  InitNTab;
  ts  :=0;
  tn  :=17;
  Chartotal:=0;   SymTotal:=0;
  EndScan:=false; OnString:=false;
  with ChPos do begin LineNumber:=0;  CharNumber :=0 end;
  with SyPos do begin LineNumber:=0;  CharNumber :=0 end;
  LastInLine:=0;
  GetCh;
  scan;
   PutSy(eofile);
  writeln(DSP);
  writeln(DSP,'    line total     =',ChPos.LineNumber : 1);
  writeln(DSP,'    character total=',CharTotal: 1);
  writeln(DSP,'    symbol total   =',SymTotal : 1);
end;



{{{******************************************************}
{{{*****************SyntaxAnalysis***********************}
{{{******************************************************}

procedure SyntaxAnalysis(var IL1,IL2:ILFileType;var DSP:text);
  procedure SyntaxError(n:cardinal);
  begin{SyntaxError}
    error(DSP,SyPos,n,ErrCount,pass2);
  end{SyntaxError};

  procedure GetSy;
  begin{GetSy};
    GetSymbol(IL1,sy,pass2);
    while sy=eoline do
    begin
      PutSymbol(IL2,DSP,sy,pass2);
      SyPos.LineNumber:=SyPos.LineNumber+1;
      GetSymbol(IL1,    sy,pass2)
    end
  end{GetSy};

  procedure PutSy(sy:symbol);
  begin
    PutSymbol(IL2,DSP,sy,pass2);
  end;

  procedure PutGet(sy:symbol);
  begin
    PutSy(sy);  GetSy
  end;

  procedure CheGet(CheckedSy:symbol);
  begin
    if sy=CheckedSy
    then GetSy
    else SyntaxError(ord(CheckedSy))
  end;

  procedure ChePut(CheckedSy:symbol);
  begin
    if sy=CheckedSy
    then PutSy(sy)
    else SyntaxError(ord(CheckedSy))
  end;

  procedure ChePutGet(CheckedSy:symbol);
  begin
    if sy=checkedSy
    then begin PutSy(sy);  GetSy end
    else SyntaxError(ord(CheckedSy))
  end;

  procedure SkipTo(RelevantSy:symset);
  begin
    while not(sy in RelevantSy) do GetSy
  end;

  procedure CheckFirst(var firsts,follows : symset; n : cardinal);
  begin
    if not(sy in firsts)
    then begin SyntaxError(n);  SkipTo(firsts+follows) end;
  end;

  procedure CheckFollow(var follows:symset;n:cardinal);
  begin
    if not (sy in follows) then begin SyntaxError(n);  SkipTo(follows) end
  end;

  procedure block(firsts,follows:symset;BlockClass:symbol);
    var IdIndex1:cardinal;  Sy1Pos:TextPos;
    procedure save;
    begin{save}
      IdIndex1:=IdIndex;  Sy1Pos:=SyPos
    end{save};

    procedure PutSave;
      procedure swap;
        var i:cardinal;  p:TextPos;
      begin
        i:=IdIndex;  IdIndex:=IdIndex1;  IdIndex1:=i;
        p:=SyPos;    SyPos  :=Sy1Pos;    Sy1Pos:=p
      end;
    begin
      swap;  PutSy(ident);  swap
    end;

    procedure NameList(firsts,follows:symset);
    begin
      CheckFirst(firsts,follows,ord(ident));
      if sy in firsts
      then begin
             ChePutGet(ident);
             while sy=comma do begin GetSy;  ChePutGet(ident) end;
             CheckFollow(follows,80)
           end
    end;

    procedure FormalParamList(firsts,follows:symset);
      procedure FormalParamDef(firsts,follows:symset);
      begin
        CheckFirst(firsts,follows,67);
        if sy in firsts
        then begin
               if sy=varsy then PutGet(varsy);
               NameList([ident],follows+[colon]);
               ChePutGet(colon);
               ChePutGet(ident);
               CheckFollow(follows,86)
             end
     end;
   begin
     CheckFirst(firsts,follows,ord(lparent));
     if sy in firsts
     then begin
            FormalParamDef([varsy,ident],follows+[semicolon,rparent]);
            while sy=semicolon do
            begin
              PutGet(semicolon);
              FormalParamDef([varsy,ident],follows+[semicolon,rparent])
            end;
            CheckFollow(follows,ord(rparent))
          end
   end;

   procedure constant(firsts,follows:symset);
   begin
     CheckFirst(firsts,follows,60);
     if sy in firsts
     then begin
            if sy in signs
            then begin
                   PutGet(sy);
                   if sy in [intconst,ident]
                   then PutGet(sy)
                   else SyntaxError(69)
                 end
            else PutGet(sy);
            CheckFollow(follows,81)
          end
   end;

   procedure TypeDenoter(firsts,follows:symset);
     procedure NewArrayType;
     begin
       PutGet(arraysy);
       CheGet(lbracket);
       TypeDenoter(typebegsys,follows+[comma,rbracket]);
       while sy=comma do
       begin
         PutGet(arraysy);
         TypeDenoter(typebegsys,follows+[comma,rbracket])
       end;
       CheGet(rbracket);
       ChePutGet(ofsy);
       TypeDenoter(typebegsys,follows)
     end;
     procedure NewRecordType;
     begin
       PutGet(recordsy);
       while sy=ident do
       begin
         NameList([ident],follows+[colon]);
         ChePutGet(colon);
         TypeDenoter(typebegsys,follows+[semicolon,endsy]);
         if sy=semicolon
         then GetSy
         else if sy<>endsy then SyntaxError(ord(semicolon));
       end;
       ChePutGet(endsy)
     end;
   begin{TypeDenoter}
     CheckFirst(firsts,follows,61);
     if sy in firsts
     then begin
            case sy of
   ident    :{type Name or subrange type}
             begin
               save;
               GetSy;
               if sy=range
               then begin
                      PutGet(sy);  PutSave;
                      constant(constbegsys,follows)
                    end
               else PutSave
             end;
   intconst,charconst,plus,minus
            :{subrange type}
             begin
               PutSy(range);
               if sy in signs
               then begin
                      PutGet(sy);
                      if sy in [intconst,ident]
                      then PutGet(sy)
                      else SyntaxError(69)
                    end
               else PutGet(range);
               constant(constbegsys,follows)
             end;
   arraysy  :{New array Type}
             NewArrayType;
   recordsy :
             NewRecordType
            end{case};
            CheckFollow(follows,82)
          end{if}
   end{TypeDenoter};
  Procedure ConstDefPart(firsts,follows:symset);
    procedure ConstDefinition(firsts,follows:symset);
    begin
      CheckFirst(firsts,follows,ord(ident));
      if sy in firsts
      then begin
             ChePutget(ident);
             CheGet(eqop);
             constant(constbegsys,follows+[semicolon]);
             CheckFollow(follows,ord(semicolon))
           end
    end;
  begin
    if sy in firsts
    then begin
           ChePutGet(constsy);
           repeat
             ConstDefinition([ident],follows+[semicolon]);
             ChePutGet(semicolon)
           until sy<>ident;
           CheckFollow(follows,83)
         end
  end;

  procedure TypeDefPart(firsts,follows:symset);
    procedure TypeDefinition(firsts,follows:symset);
    begin
      CheckFirst(firsts,follows,ord(ident));
      if sy in firsts
      then begin
             ChePutGet(ident);
             CheGet(eqop);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩电影在线播放| 欧美精品高清视频| 舔着乳尖日韩一区| 国产亲近乱来精品视频| 欧美日韩免费观看一区三区| 成人a免费在线看| 久久电影网电视剧免费观看| 亚洲一区视频在线观看视频| 国产精品免费久久久久| 日韩精品中文字幕一区二区三区| 91精品1区2区| 国产精品66部| 久久成人羞羞网站| 亚洲成人第一页| 国产精品久99| 久久精品人人做人人综合| 538在线一区二区精品国产| 91原创在线视频| 成人午夜电影久久影院| 国产在线精品视频| 麻豆成人av在线| 日本午夜一区二区| 五月婷婷激情综合| 一区二区三区在线观看网站| 国产精品久久久久天堂| 久久久久高清精品| 2024国产精品| 精品剧情在线观看| 精品国精品自拍自在线| 欧美一区二区三区公司| 欧美日韩国产美女| 欧美三级午夜理伦三级中视频| 99久久99久久精品免费看蜜桃| 粉嫩久久99精品久久久久久夜| 国产精品一品二品| 国产成人亚洲综合色影视| 国产在线国偷精品产拍免费yy| 另类小说色综合网站| 青青草国产成人av片免费| 亚洲成人av一区二区| 亚洲综合一二区| 亚洲国产中文字幕在线视频综合 | 91精品1区2区| 色999日韩国产欧美一区二区| 99国产精品国产精品久久| 色综合一区二区| 欧美性生活大片视频| 欧美一区二区三区日韩| 欧美本精品男人aⅴ天堂| 欧美r级电影在线观看| 久久精品亚洲精品国产欧美kt∨ | 91精品国产免费| 精品国产精品网麻豆系列| 日韩午夜电影av| 久久一夜天堂av一区二区三区| 久久众筹精品私拍模特| 中文字幕巨乱亚洲| 亚洲美女视频在线观看| 亚洲h在线观看| 久久99久久99| 成人av动漫网站| 在线观看不卡一区| 欧美一级日韩一级| 国产日韩精品一区| 亚洲欧美激情一区二区| 日韩激情一区二区| 国产精品亚洲成人| 91亚洲午夜精品久久久久久| 欧美人动与zoxxxx乱| 精品国产凹凸成av人导航| 国产精品欧美一级免费| 亚洲在线免费播放| 久久疯狂做爰流白浆xx| av动漫一区二区| 欧美精品久久一区| 国产欧美一区二区在线观看| 一区二区视频免费在线观看| 免费成人在线网站| 99久久99久久久精品齐齐| 91精品国产免费| 国产精品护士白丝一区av| 丝袜国产日韩另类美女| 国产白丝精品91爽爽久久 | 日本一区二区成人| 亚洲福利一二三区| 国产精品一级二级三级| 在线观看91精品国产入口| 欧美mv和日韩mv的网站| 亚洲精品综合在线| 狠狠久久亚洲欧美| 欧美猛男男办公室激情| 国产欧美日韩卡一| 五月天欧美精品| 色综合天天综合在线视频| 欧美刺激脚交jootjob| 一区二区三区在线视频播放| 精品影院一区二区久久久| 在线观看日韩精品| 亚洲国产精品av| 蜜臀av性久久久久蜜臀aⅴ| 色欧美片视频在线观看| 欧美经典一区二区| 毛片av一区二区| 欧美精品自拍偷拍| 亚洲情趣在线观看| 成人精品视频网站| 精品成人一区二区三区四区| 豆国产96在线|亚洲| 欧美一区二区三区思思人| 亚洲人成网站色在线观看| 国产成人综合亚洲91猫咪| 日韩美女天天操| 日韩 欧美一区二区三区| 色噜噜偷拍精品综合在线| 国产嫩草影院久久久久| 韩国精品一区二区| 欧美videossexotv100| 日韩高清在线不卡| 在线欧美日韩精品| 亚洲免费av高清| 91丨porny丨国产| 国产精品国产三级国产aⅴ入口| 国产美女娇喘av呻吟久久| 日韩美一区二区三区| 免费在线观看成人| 日韩午夜激情av| 麻豆91在线观看| 日韩欧美www| 国内精品久久久久影院色| 精品入口麻豆88视频| 精品一区二区三区在线视频| 日韩一区二区三区在线| 日本中文字幕一区二区有限公司| 欧美日韩国产精品成人| 天天操天天色综合| 91精品蜜臀在线一区尤物| 天堂一区二区在线免费观看| 欧美日韩在线不卡| 亚洲国产综合色| 欧美日韩一区小说| 日本三级亚洲精品| 日韩欧美国产小视频| 国产资源精品在线观看| 欧美v国产在线一区二区三区| 麻豆91精品91久久久的内涵| 日韩美女视频一区二区在线观看| 精品亚洲免费视频| 久久久欧美精品sm网站| 国产成人免费9x9x人网站视频| 欧美激情中文不卡| 波多野结衣中文字幕一区| 亚洲自拍偷拍图区| 日韩一区二区影院| 国产精品系列在线播放| 国产精品麻豆一区二区| 欧美综合色免费| 午夜精彩视频在线观看不卡| 日韩一级精品视频在线观看| 国产在线精品免费av| 亚洲欧美在线高清| 精品视频全国免费看| 久久国产视频网| 久久久国产午夜精品| 91网址在线看| 日韩av一二三| 中文字幕乱码一区二区免费| 色av一区二区| 精品中文字幕一区二区| 国产精品毛片大码女人| 欧美日韩国产影片| 国产精品亚洲综合一区在线观看| 1000精品久久久久久久久| 欧美三级电影网站| 国内精品第一页| 亚洲精品欧美激情| 亚洲精品一区二区在线观看| 白白色亚洲国产精品| 亚洲第一主播视频| 精品国产乱码久久久久久浪潮| 色综合天天综合网天天看片| 蜜桃在线一区二区三区| 亚洲人成网站在线| 欧美成人一区二区三区| 色偷偷一区二区三区| 精品亚洲aⅴ乱码一区二区三区| 中文字幕亚洲一区二区av在线 | 日韩美女一区二区三区四区| 99re热视频精品| 男女性色大片免费观看一区二区| 国产精品一二三在| 洋洋av久久久久久久一区| 2020国产精品自拍| 欧洲精品一区二区三区在线观看| 国产美女久久久久| 热久久久久久久| 亚洲一区二区三区四区在线观看 | 日韩欧美一二三| 欧美综合久久久| 国产69精品久久99不卡| 日本亚洲视频在线|