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

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

?? main.pas

?? 編譯原理實驗 完整的
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
program PasCompiler(input,output);

  const
    IdLength=10;
    maxint=16383;
    illeng=81;
    symnum=53;
    levmax=7;
    addrmax=4095;
    tnmax=70;
    tsmax=200;
    timax=80;
    tbmax=10;
    tcmax=1023;
    tlmax=255;

    isize=1;
    csize=1;
    bsize=1;
  type
    symbol=({ 0}ident,intconst,charconst,strconst,programsy,
            { 5}constsy,typesy,varsy,procsy,funcsy,beginsy,ifsy,
            {12}whilesy,forsy,endsy,thensy,elsesy,ofsy,dosy,
            {19}tosy,downtosy,arraysy,recordsy,notop,times,divop,
            {26}modop,andop,plus,minus,orop,lsop,leop,gtop,
            {34}geop,neop,eqop,lparent,rparent,lbracket,rbracket,
            {41}comma,semicolon,period,colon,becomes,range,
            {47}eoline,eofile,other,call,empty,boolconst,
            {53}unaryminus);
    symset=set of symbol;
    cardinal=0..maxint;
    CharPos=0..illeng;
    TextPos=record
              LineNumber:0..9999;
              CharNumber:cardinal
            end;
    LevelRange=0..levmax;
    AddrRange=0..addrmax;
    RuntimeAddress
             =record
                StaticLevel:LevelRange;
                RelativeAddress:AddrRange
              end;
    StructForm=(inv,strs,ints,chars,bools,subranges,arrays,records);
    StPtr=^Structure;
    Structure=packed record
                  order:cardinal;
                  next:StPtr;
                  size:cardinal;
                  case form:StructForm of
        inv,strs,ints,chars,bools
                       :({no field});
        subranges:(RangeType:StPtr;
                   min:integer;
                   max:integer);
        arrays:(IndexType:StPtr;
                ElementType:StPtr);
        records:(LastField:cardinal)
                     end{record};
    IdClass=(constss,typess,varss,
             fieldss,procss,funcss);
    VarKind=(noparam,valparam,varparam);
    StandFuncs=(absf,sqrf,ordf,chrf,succf,predf,oddf);
    StandProcs=(readp,readlnp,writep,writelnp);
    identifier=packed record
                   name:cardinal;
                   previous:cardinal;
                   typ:StPtr;
                   case class:IdClass of
           constss:(val:integer);
           typess:(               );
           varss:(address:RuntimeAddress;
                     kind:VarKind;
                     IsControlVar:Boolean);
           fieldss:(offset:cardinal);
           procss:(case IsStandp:Boolean of
                      true:(standp:StandProcs);
                      false:(plev:LevelRange;
                            pEntry:cardinal;
                            pindex:cardinal));
           funcss:(case IsStandf:Boolean of
                      true:(standf:StandProcs);
                      false:(flev:LevelRange;
                            fEntry:cardinal;
                            findex:cardinal));
                      end{record};
    BTabTerm=record
                    LastPar:cardinal;
                    ParSize:cardinal;
                    LastId:cardinal;
                    VarSize:cardinal;
             end;
    OperandForm=(invalid,invinv,strstr,invint,intinv,intint,
                 invbool,boolinv,boolbool,invchar,charinv,charchar,
                 invarr,arrinv,arrarr,invrec,recinv,recrec);
    ILFileType=file of cardinal;
    PTCFileType=file of integer;
    table=(nametab,stringtab,identtab,blocktab,codetab,labletab);
    alfa=packed array[1..IdLength]of char;
    pass=(pass1,pass2,pass3,pass4,pass5);
    {**********PASCAL-T Machine(PTCode)***********}
    OperatingCode=({ 0}LADR,LVAL,LINT,OPAR,CAL,ETBK,EXBK,EXPG,
                   { 8}UDSP,LBK,CPBK,IDXV,FLDV,JMP,JMPZ,ASIG,
                   {16}EFLU,EFLD,AFBU,AFBD,EFL,NEGI,ADDI,SUBI,
                   {24}MULI,DIVI,MODI,EQCP,NECP,LTCP,LECP,GTCP,
                   {32}GECP,ORB,ANDB,NOTB,FABS,FSQR,FORD,FCHR,
                   {40}FSUC,FPRE,FODD,RVAR,RLIN,WSTR,WEXP,WLIN,
                   {48}NOP);
    OpCodeSet=set of OperatingCode;
    instruction=record
                  OpCode:OperatingCode;
                  arg1,arg2,arg3:integer
                end;
    CodeLable=AddrRange;
    {********MAIN PROGRAM and UTILITY ROUTINE********}
    alfa4=packed array [1..4] of char;
    alfa6=packed array [1..6] of char;
    alfa10=packed array [1..10] of char;
  var
    sy:symbol;
    SyPos:TextPos;
    ErrCount:cardinal;
    overflow:set of table;
    operandfm:OperandForm;
    ZeroArgument,OneArgument,TwoArgument,ThreeArgument
             :OpCodeSet;{pass5}
    NTab:array[0..tnmax]of alfa;
    STab:array[0..tsmax]of char;
    ITab:array[0..timax]of identifier;
    BTab:array[0..tbmax]of BTabTerm;
    CTab:array[0..tcmax]of integer;
    LTab:array[0..tlmax]of cardinal;
    tn:cardinal;
    ts:cardinal;
    ti:cardinal;
    tb:cardinal;
    tl:cardinal;
    NIndex:cardinal;
    IdIndex:cardinal;
    IValue:cardinal;
    BValue:cardinal;
    CValue:cardinal;
    SEntry:cardinal;
    SLength:cardinal;
    signs:symset;
    mulops:symset;
    addops:symset;
    relops:symset;
    defbegsys:symset;
    constbegsys:symset;
    typebegsys:symset;
    statbegsys:symset;
    facbegsys:symset;
    termbegsys:symset;
    simexprbegsys:symset;
    exprbegsys:symset;
    invptr:StPtr;
    strptr:StPtr;
    intptr:StPtr;
    charptr:StPtr;
    boolptr:StPtr;
    {*************MAIN PROGRAM and UTILITY ROUTINE*****************}
    PAS:text;
    IL1:ILFileType;
    IL2:ILFileType;
    IL3:ILFileType;
    PTCode:PTCFileType;
    ASN:text;
    SFile:file of char;
    DSP:text;
    sym:array[0..symnum]of symbol;
    OpFm:array[0..16]of OperandForm;
    OperatCd:array[0..48]of OperatingCode;
    sp:array[symbol]of alfa10;
    OpFmSp:array[OperandForm]of alfa6;
    OpCdSp:array[OperatingCode]of alfa4;
    IdClassSp:array[IdClass]of alfa6;
    StandpSp:array[StandProcs]of alfa6;
    StandfSp:array[StandFuncs]of alfa6;
    KindSp:array[VarKind]of alfa6;
    StFormSp:array[StructForm]of alfa6;

{{{*******************************************************************}
{{{                         FIRST GROUP                               }
{{{*******************************************************************}
procedure Initialization;
  procedure InitSmOdOm;
    var sy:symbol;oc:OperatingCode;od:OperandForm;
  begin
    for sy:=ident to unaryminus do sym[ord(sy)]:=sy;
    for oc:=LADR to NOP do OperatCd[ord(oc)]:=oc;
    for od:=invalid to recrec do OpFm[ord(od)]:=od
  end;
  procedure InitSp;
  begin
    sp[ident]:='ident     ';      sp[intconst]:='intconst  ';
    sp[charconst]:='charconst ';  sp[strconst]:='strconst  ';
    sp[programsy]:='programsy ';  sp[constsy]:='constsy   ';
    sp[typesy]:='typesy    ';     sp[varsy]:='varsy     ';
    sp[procsy]:='procsy    ';     sp[funcsy]:='funcsy    ';
    sp[beginsy]:='beginsy   ';    sp[ifsy]:='ifsy      ';
    sp[whilesy]:='whilesy   ';    sp[forsy]:='forsy     ';
    sp[endsy]:='endsy     ';      sp[thensy]:='thensy    ';
    sp[elsesy]:='elsesy    ';     sp[ofsy]:='ofsy      ';
    sp[dosy]:='dosy      ';       sp[tosy]:='tosy      ';
    sp[downtosy]:='downtosy  ';   sp[arraysy]:='arraysy   ';
    sp[recordsy]:='recordsy  ';   sp[notop]:='notsy     ';
    sp[times]:='times     ';      sp[divop]:='divop     ';
    sp[modop]:='modop     ';      sp[andop]:='andop     ';
    sp[plus]:='plus      ';       sp[minus]:='minus     ';
    sp[orop]:='orop      ';       sp[lsop]:='lsop      ';
    sp[leop]:='leop      ';       sp[gtop]:='gtop      ';
    sp[geop]:='geop      ';       sp[neop]:='neop      ';
    sp[eqop]:='eqop      ';       sp[lparent]:='lparent   ';
    sp[rparent]:='rparent   ';    sp[lbracket]:='lbracket  ';
    sp[rbracket]:='rbracket  ';   sp[comma]:='comma     ';
    sp[semicolon]:='semicolon ';  sp[period]:='period    ';
    sp[colon]:='colon     ';      sp[becomes]:='becomes   ';
    sp[range]:='range     ';      sp[eoline]:='eoline    ';
    sp[eofile]:='edfile    ';     sp[other]:='other     ';
    sp[call]:='call      ';       sp[empty]:='empty     ';
    sp[boolconst]:='boolconst ';  sp[unaryminus]:='unaryminus';
    {}
    IdClassSp[constss]:='consts';
    IdClassSp[typess]:='types ';
    IdClassSp[varss]:='vars  ';
    IdClassSp[fieldss]:='fields';
    IdClassSp[procss]:='procss';
    IdClassSp[funcss]:='funcs ';
    {}
    StandpSp[readp]:='read  ';  StandpSp[readlnp]:='readln';
    StandpSp[writep]:='write '; StandpSp[writelnp]:='writln';
    {}
    StandfSp[absf]:='abs   ';       StandfSp[sqrf]:='sqr   ';
    StandfSp[ordf]:='ord   ';       StandfSp[chrf]:='chr   ';
    StandfSp[succf]:='succ  ';      StandfSp[predf]:='pred  ';
    StandfSp[oddf]:='odd   ';
    {}
    KindSp[noparam]:='nopar ';    KindSp[valparam]:='valpar';
    KindSp[varparam]:='varpar';
    {}
    StFormSp[inv]:='inv   ';           StFormSp[strs]:='strs  ';
    StFormSp[ints]:='ints  ';          StFormSp[chars]:='chars ';
    StFormSp[bools]:='bools ';         StFormSp[subranges]:='subran';
    StFormSp[arrays]:='arrays';       StFormSp[records]:='record';
    {}
    OpFmSp[invalid]:='invald';       OpFmSp[invinv]:='invinv';
    OpFmSp[strstr]:='strstr';        OpFmSp[invint]:='invint';
    OpFmSp[intinv]:='intinv';       OpFmSp[intint]:='intint';
    OpFmSp[invbool]:='invbol';       OpFmSp[boolinv]:='bolinv';
    OpFmSp[boolbool]:='bolbol';      OpFmSp[invchar]:='invchr';
    OpFmSp[charinv]:='chrinv';      OpFmSp[charchar]:='chrchr';
    OpFmSp[invarr]:='invarr';        OpFmSp[arrinv]:='arrinv';
    OpFmSp[arrarr]:='arrarr';        OpFmSp[invrec]:='invrec';
    OpFmSp[recinv]:='recinv';        OpFmSp[recrec]:='recrec';
    {}
    OpCdSp[LADR]:='LADR';    OpCdSp[LVAL]:='LVAL';    OpCdSp[LINT]:='LINT';
    OpCdSp[OPAR]:='OPAR';    OpCdSp[CAL]:='CAL ';     OpCdSp[ETBK]:='ETBK';
    OpCdSp[EXBK]:='EXBK';    OpCdSp[EXPG]:='EXPG';    OpCdSp[UDSP]:='UDSP';
    OpCdSp[LBK]:='LBK ';     OpCdSp[CPBK]:='CPBK';    OpCdSp[IDXV]:='IDXV';
    OpCdSp[FLDV]:='FLDV';    OpCdSp[JMP]:='JMP ';     OpCdSp[JMPZ]:='JMPZ';
    OpCdSp[ASIG]:='ASIG';    OpCdSp[EFLU]:='EFLU';    OpCdSp[EFLD]:='EFLD';
    OpCdSp[AFBU]:='AFBU';    OpCdSp[AFBD]:='AFBD';    OpCdSp[EFL]:='EFL ';
    OpCdSp[NEGI]:='NEGI';    OpCdSp[ADDI]:='ADDI';    OpCdSp[SUBI]:='SUBI';
    OpCdSp[MULI]:='MULI';    OpCdSp[DIVI]:='DIVI';    OpCdSp[MODI]:='MODI';
    OpCdSp[EQCP]:='EQCP';    OpCdSp[NECP]:='NECP';    OpCdSp[LTCP]:='LTCP';
    OpCdSp[LECP]:='LECP';    OpCdSp[GTCP]:='GTCP';    OpCdSp[GECP]:='GECP';
    OpCdSp[ORB]:='ORB ';     OpCdSp[ANDB]:='ANDB';    OpCdSp[NOTB]:='NOTB';
    OpCdSp[FABS]:='FABS';    OpCdSp[FSQR]:='FSQR';    OpCdSp[FORD]:='FORD';
    OpCdSp[FCHR]:='FCHR';    OpCdSp[FSUC]:='FSUC';    OpCdSp[FPRE]:='FPRE';
    OpCdSp[FODD]:='FODD';    OpCdSp[RVAR]:='RVAR';    OpCdSp[RLIN]:='RLIN';
    OpCdSp[WSTR]:='WSTR';    OpCdSp[WEXP]:='WEXP';    OpCdSp[WLIN]:='WLIN';
    OpCdSp[NOP]:='NOP ';
  end{InitSp};
  procedure InitSets;
  begin
    defbegsys:=[constsy..funcsy];
    constbegsys:=[ident,intconst,charconst,plus,minus];
    typebegsys:=constbegsys+[arraysy,recordsy];
    statbegsys:=[ident,beginsy..forsy];
    facbegsys:=[ident,intconst,charconst,strconst,lparent,notop];
    termbegsys:=facbegsys;
    simexprbegsys:=[plus,minus]+termbegsys;
    exprbegsys:=simexprbegsys;
    signs:=[plus,minus];
    addops:=[plus..orop];
    mulops:=[times..andop];
    relops:=[lsop..eqop];
    {              main  pass5}
    ZeroArgument:=[LVAL,EXPG,ASIG,EFL,NEGI..NOTB,
                   FABS,FSQR,FORD,FCHR,FODD,RLIN,WLIN];
    OneArgument:=[LINT,OPAR,CAL,EXBK,LBK,CPBK,CPBK,FLDV,JMP,
                  JMPZ,FSUC,FPRE,RVAR,WEXP];
    TwoArgument:=[LADR,ETBK,UDSP,EFLU,EFLD,AFBU,AFBD,NOP,WSTR];
    ThreeArgument:=[IDXV]
  end;
begin
  overflow:=[];ErrCount:=0;
  InitSmOdOm;InitSp;InitSets
end;



procedure OpenFiles;
  type alfa8=packed array[1..8] of char;
       alfa3=packed array[1..3] of char;
       alfa12=packed array[1..12] of char;
  var SourceName:alfa8;
        FileFullName:alfa12;
  procedure ReadFileName(var FileName:alfa8);
    var i:integer; ch:char;
  begin
    write('Name of source file:');
    repeat read(ch) until ch<>'';
    FileName:='        ';i:=1;
    while((ch<>'.')and(i<=8)) do
    begin
      FileName[i]:=ch;
      if not eoln then begin i:=succ(i);read(ch) end else ch:='.'
    end;
    readln;
  end;
  procedure LinkExtName(var FileFullName:alfa12;
                          FileName:alfa8;ExtName:alfa3);
    var i,j:integer;
  begin
    FileFullName:='            ';i:=1;
    while(FileName[i]<>'')and(i<=8) do

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本91福利区| 91国产视频在线观看| 99久久精品费精品国产一区二区| 欧美日韩国产精品成人| 欧美激情一区二区三区蜜桃视频| 日本视频中文字幕一区二区三区| jlzzjlzz亚洲女人18| 精品国产区一区| 日韩精品一二区| 欧美色综合网站| 国产精品久久久久久亚洲毛片 | 欧美亚洲国产一卡| 国产精品免费av| 国产一区二区免费在线| 欧美一区二区播放| 亚洲一区二区四区蜜桃| 91麻豆自制传媒国产之光| 国产三级精品三级在线专区| 久久超级碰视频| 欧美一级高清片| 亚洲国产成人精品视频| 日本精品免费观看高清观看| 国产精品欧美一区喷水| 国产91精品久久久久久久网曝门| xf在线a精品一区二区视频网站| 午夜视频一区二区三区| 欧美日本韩国一区二区三区视频| 亚洲精品国产品国语在线app| 成人sese在线| 亚洲欧美激情视频在线观看一区二区三区| 国产风韵犹存在线视精品| 精品国产乱码久久| 国产一区二区h| 国产亚洲精品bt天堂精选| 国产a精品视频| 国产精品天干天干在线综合| 99久免费精品视频在线观看| 亚洲欧美日韩中文播放| 色婷婷综合中文久久一本| 亚洲一线二线三线视频| 欧美日韩一区久久| 久久精品免费观看| 久久久久99精品一区| 国产成人av福利| 日韩一区在线看| 欧美色涩在线第一页| 日本中文字幕一区二区有限公司| 日韩欧美在线网站| 国产黄色91视频| 亚洲乱码国产乱码精品精98午夜| 在线观看www91| 美女看a上一区| 日韩精品最新网址| 国产成人免费在线观看不卡| 日韩理论电影院| 欧美日本国产视频| 国内精品在线播放| 亚洲私人影院在线观看| 欧美日韩国产一二三| 国产一区二区三区久久悠悠色av | 日韩毛片高清在线播放| 欧美日韩精品欧美日韩精品| 麻豆精品一区二区综合av| 中文字幕av资源一区| 欧美亚一区二区| 欧美三级日韩三级| 狂野欧美性猛交blacked| 亚洲国产精品av| 91麻豆精品久久久久蜜臀| 国产精品123| 午夜精品久久久久久久蜜桃app| 2017欧美狠狠色| 在线观看一区日韩| 经典三级一区二区| 亚洲蜜桃精久久久久久久| 日韩三级视频在线观看| 91蝌蚪porny| 国产一区二区三区免费观看| 亚洲成人免费视频| 国产精品狼人久久影院观看方式| 91麻豆精品91久久久久同性| 国产乱妇无码大片在线观看| 亚洲成人av一区二区三区| 国产欧美视频一区二区三区| 欧美一区二区三区婷婷月色 | 日韩欧美的一区| 在线亚洲高清视频| 高清免费成人av| 另类小说综合欧美亚洲| 亚洲综合在线视频| 国产丝袜美腿一区二区三区| 日韩精品一区二区在线| 在线观看国产日韩| 色综合视频在线观看| 国产成人在线看| 国产在线观看一区二区| 免费在线观看成人| 亚洲成年人影院| 亚洲伊人色欲综合网| 亚洲日本在线a| **网站欧美大片在线观看| 国产校园另类小说区| 久久一区二区三区四区| 欧美videofree性高清杂交| 欧美精品在欧美一区二区少妇| 日本精品一区二区三区高清| 色中色一区二区| 99国产精品国产精品毛片| 国产精品亚洲第一| 国产麻豆精品视频| 国产精品影音先锋| 国产成人在线影院| 国产suv精品一区二区883| 国产不卡视频在线观看| 高清shemale亚洲人妖| 岛国av在线一区| 成人精品鲁一区一区二区| aaa亚洲精品一二三区| av亚洲精华国产精华| 91蝌蚪porny| 欧美视频精品在线观看| 欧美视频自拍偷拍| 欧美一级免费大片| 日韩欧美www| 国产亚洲女人久久久久毛片| 久久久久国产精品麻豆ai换脸 | 在线看国产一区| 欧美狂野另类xxxxoooo| 日韩一区二区免费在线观看| 精品国产伦一区二区三区观看方式 | 亚洲一区视频在线| 偷窥少妇高潮呻吟av久久免费| 无码av免费一区二区三区试看| 午夜视频在线观看一区| 麻豆国产一区二区| 成人高清免费在线播放| 色综合久久综合网欧美综合网| 欧美亚洲一区三区| 日韩精品一区二区三区中文精品| 久久精品视频在线看| 日韩久久一区二区| 秋霞午夜av一区二区三区| 国产精品一区二区男女羞羞无遮挡| 99v久久综合狠狠综合久久| 在线免费观看日韩欧美| 久久综合色综合88| 亚洲日穴在线视频| 久久99精品久久久久久动态图| 国产成人av电影在线| 欧美优质美女网站| 26uuu精品一区二区在线观看| 亚洲青青青在线视频| 喷白浆一区二区| 一本色道久久加勒比精品| 日韩女优毛片在线| 亚洲精品亚洲人成人网| 国内久久精品视频| 欧美年轻男男videosbes| 欧美激情一区在线| 美国一区二区三区在线播放| 色婷婷久久久综合中文字幕| 久久综合久久综合九色| 亚洲一区二区三区小说| 国产91精品精华液一区二区三区 | 99久久久国产精品免费蜜臀| 91精品国产综合久久蜜臀| 亚洲欧洲色图综合| 经典三级一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 9久草视频在线视频精品| 制服丝袜日韩国产| 亚洲欧美区自拍先锋| 国产精品羞羞答答xxdd| 日韩一二在线观看| 亚洲成人久久影院| 91麻豆国产精品久久| 国产精品女上位| 国产老肥熟一区二区三区| 日韩欧美专区在线| 丝袜诱惑亚洲看片| 欧美日韩免费电影| 一区二区三区在线免费视频| 成人免费视频免费观看| 精品久久久久99| 久久er精品视频| 777a∨成人精品桃花网| 香蕉加勒比综合久久| 欧美无砖砖区免费| 亚洲精品视频免费看| 99精品久久99久久久久| 国产精品久久久久久久久免费丝袜| 国内精品不卡在线| 久久欧美一区二区| 国产在线精品视频| 久久这里只有精品首页| 精品制服美女丁香| 久久亚洲春色中文字幕久久久| 久久精品99久久久| 欧美大片免费久久精品三p| 久久精品国产成人一区二区三区|