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

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

?? cra.pas

?? 一個Pascal語言分析器
?? PAS
?? 第 1 頁 / 共 4 頁
字號:
UNIT CRA;
(* CRA     Automaton and Scanner Generation
   ===     ================================

  (1) ConvertToStates translates a top-down graph into a NFA.
      MatchDFA tries to match literal strings against the DFA
  (2) MakeDeterministic converts the NFA into a DFA
  (3) WriteScanner generates the scanner source file

  ----------------------------------------------------------------*)

INTERFACE

CONST
  MaxSourceLineLength = 78;

TYPE
  PutSProc = PROCEDURE (S : STRING);

PROCEDURE CopyFramePart (stopStr: STRING; VAR leftMarg: INTEGER;
                         VAR framIn, framOut : TEXT);
(* "stopStr" must not contain "FileIO.EOL".
   "leftMarg" is in/out-parameter  --  it has to be set once by the
   calling program.    *)

PROCEDURE ImportSymConsts (leader: STRING; putS: PutSProc);
(* Generates the USES references for the eventually existing named constants. *)

PROCEDURE ConvertToStates (gp0, sp: INTEGER);
(* Converts top-down graph with root gp into a subautomaton that
   recognizes token sp *)

PROCEDURE MatchDFA (str: STRING; sp : INTEGER; VAR matchedSp: INTEGER);
(* Returns TRUE, if string str can be recognized by the current DFA.
   matchedSp is the token as that s can be recognized. *)

PROCEDURE MakeDeterministic (VAR correct: BOOLEAN);
(* Converts the NFA into a DFA. correct indicates if an error occurred. *)

PROCEDURE NewComment (start, stop: INTEGER; nested: BOOLEAN);
(* Defines a new comment for the scanner. The comment brackets are
   represented by the mini top-down graphs with the roots from and to. *)

PROCEDURE WriteScanner;
(* Emits the source code of the generated scanner using the frame file
   scanner.frm *)

PROCEDURE PrintStates;
(* List the automaton for tracing *)

IMPLEMENTATION

USES CRS, CRTable, FileIO, Sets;

CONST
  maxStates = 500;
  cr = #13;
TYPE
  Action = ^ ActionNode;
  Target = ^ TargetNode;
  State = 
    RECORD                     (* state of finite automaton *)
      firstAction : Action;    (* to first action of this state *)
      endOf : INTEGER;         (* nr. of recognized token if state is final *)
      ctx : BOOLEAN;           (* TRUE: state reached by contextTrans *)
    END;
  ActionNode = 
    RECORD                     (* action of finite automaton *)
      typ : INTEGER;           (* type of action symbol: char, class *)
      sym : INTEGER;           (* action symbol *)
      tc : INTEGER;            (* transition code: normTrans, contextTrans *)
      target : Target;         (* states after transition with input symbol *)
      next : Action;
    END;
  TargetNode = 
    RECORD                     (* state after transition with input symbol *)
      theState : INTEGER;      (* target state *)
      next : Target;
    END;
  Comment = ^ CommentNode;
  STRING2 = STRING[2];
  CommentNode = 
    RECORD                     (* info about a comment syntax *)
      start, stop : STRING2;
      nested : BOOLEAN;
      next : Comment;
    END;
  Melted = ^ MeltedNode;
  MeltedNode = 
    RECORD                     (* info about melted states *)
      sset : CRTable.CRTSet;   (* set of old states *)
      theState : INTEGER;      (* new state *)
      next : Melted;
    END;

VAR
  stateArray : ARRAY [0 .. maxStates] OF State;
  lastSimState : INTEGER;      (* last non melted state *)
  lastState : INTEGER;         (* last allocated state  *)
  rootState : INTEGER;         (* start state of DFA    *)
  firstMelted : Melted;        (* list of melted states *)
  firstComment : Comment;      (* list of comments      *)
  scanner,                     (* generated scanner     *)
  fram : TEXT;                 (* scanner frame         *)
  NewLine : BOOLEAN;

PROCEDURE SemErr (nr : INTEGER);
  BEGIN
    CRS.Error(nr + 100, CRS.line, CRS.col, CRS.pos)
  END;

PROCEDURE Put (ch : CHAR);
  BEGIN
    Write(scanner, ch)
  END;

PROCEDURE PutLn;
  BEGIN
    WriteLn(scanner)
  END;

PROCEDURE PutB (n : INTEGER);
  BEGIN
    Write(scanner, ' ':n);
  END;

PROCEDURE Indent (n : INTEGER);
  BEGIN
    IF NewLine THEN PutB(n) ELSE NewLine := TRUE
  END;

PROCEDURE PutS (s : STRING); FAR;
  VAR
    i : INTEGER;
  BEGIN
    FOR i := 1 TO Length(s) DO
      IF s[i] = '$' THEN WriteLn(scanner) ELSE Write(scanner, s[i]);
  END;

PROCEDURE PutS1 (s : STRING);
  BEGIN
    IF s[1] = '"' THEN BEGIN s[1] := ''''; s[Length(s)] := '''' END; PutS(s);
  END;

PROCEDURE PutI (i : INTEGER);
  BEGIN
    Write(scanner, i:1)
  END;

PROCEDURE PutI2 (i, n : INTEGER);
  BEGIN
    Write(scanner, i:n)
  END;

PROCEDURE PutC (ch : CHAR);
  BEGIN
    CASE ch OF
      #0 .. #31, #127 .. #255, '''' : BEGIN  PutS('CHR('); PutI(ORD(ch)); Put(')') END;
      ELSE BEGIN Put(''''); Put(ch); Put('''') END
    END
  END;

PROCEDURE PutSN (i : INTEGER);
  VAR
    sn : CRTable.SymbolNode;
  BEGIN
    CRTable.GetSym(i, sn);
    IF Length(sn.constant) > 0 THEN PutS(sn.constant) ELSE PutI(i);
  END;

PROCEDURE PutSE (i : INTEGER);
  BEGIN
    PutS('BEGIN sym := '); PutSN(i); PutS('; ');
  END;

PROCEDURE PutRange (s : CRTable.CRTSet; indent : INTEGER);
  VAR
    lo, hi : ARRAY [0 .. 31] OF CHAR;
    top, i : INTEGER;
    s1 : CRTable.CRTSet;

  BEGIN
  (*----- fill lo and hi *) 
    top :=  -1;
    i := 0;
    WHILE i < 256 (*PDT*)  DO BEGIN
      IF Sets.IsIn(s, i)
        THEN
          BEGIN
            INC(top); lo[top] := CHR(i); INC(i);
            WHILE (i < 256 (*PDT*) ) AND Sets.IsIn(s, i) DO INC(i);
            hi[top] := CHR(i - 1)
          END
        ELSE INC(i)
    END;
    (*----- print ranges *) 
    IF (top = 1) AND (lo[0] = #0) AND (hi[1] = #255
    (*PDT*) ) AND (CHR(ORD(hi[0]) + 2) = lo[1])
      THEN
        BEGIN
          Sets.Fill(s1); Sets.Differ(s1, s);
          PutS('NOT ('); PutRange(s1, indent); Put(')')
        END
      ELSE
        BEGIN
          i := 0;
          WHILE i <= top DO BEGIN
            IF hi[i] = lo[i]
              THEN BEGIN PutS('(ch = '); PutC(lo[i]) END
              ELSE IF lo[i] = #0 THEN
                BEGIN PutS('(ch <= '); PutC(hi[i]) END
              ELSE IF hi[i] = #255 (*PDT*)  THEN
                BEGIN PutS('(ch >= '); PutC(lo[i]) END
              ELSE
                BEGIN
                  PutS('(ch >= '); PutC(lo[i]); PutS(') AND (ch <= ');
                  PutC(hi[i])
                END;
            Put(')');
            IF i < top THEN BEGIN PutS(' OR$'); PutB(indent) END;
            INC(i)
          END
        END
  END;

PROCEDURE PutChCond (ch : CHAR);
  BEGIN
    PutS('(ch = '); PutC(ch); Put(')')
  END;

(* PrintStates          List the automaton for tracing
-------------------------------------------------------------------------*) 

PROCEDURE PrintStates;

  PROCEDURE PrintSymbol (typ, val, width : INTEGER);
    VAR
      name : CRTable.Name;
      len : INTEGER;
    BEGIN
      IF typ = CRTable.class
        THEN
          BEGIN
            CRTable.GetClassName(val, name);
            Write(CRS.lst, name); len := Length(name)
          END
        ELSE IF (val >= ORD(' ')) AND (val < 127) AND (val <> 34) THEN
          BEGIN Write(CRS.lst, '"', CHR(val), '"'); len := 3 END
        ELSE
          BEGIN Write(CRS.lst, 'CHR(', val:2, ')'); len := 7 END;
      WHILE len < width DO BEGIN Write(CRS.lst, ' '); INC(len) END
    END;

  VAR
    anAction : Action;
    first : BOOLEAN;
    s, i : INTEGER;
    targ : Target;
    sset : CRTable.CRTSet;
    name : CRTable.Name;
  BEGIN
    WriteLn(CRS.lst); WriteLn(CRS.lst, '-------- states ---------');
    s := rootState;
    WHILE s <= lastState DO BEGIN
      anAction := stateArray[s].firstAction;
      first := TRUE;
      IF stateArray[s].endOf = CRTable.noSym
        THEN Write(CRS.lst, '     ')
        ELSE Write(CRS.lst, 'E(', stateArray[s].endOf:2, ')');
      Write(CRS.lst, s:3, ':');
      IF anAction = NIL THEN WriteLn(CRS.lst);
      WHILE anAction <> NIL DO BEGIN
        IF first
          THEN BEGIN Write(CRS.lst, ' '); first := FALSE END
          ELSE BEGIN Write(CRS.lst, '          ') END;
        PrintSymbol(anAction^.typ, anAction^.sym, 0);
        Write(CRS.lst, ' ');
        targ := anAction^.target;
        WHILE targ <> NIL DO BEGIN
          Write(CRS.lst, targ^.theState:1, ' '); targ := targ^.next;
        END;
        IF anAction^.tc = CRTable.contextTrans
          THEN WriteLn(CRS.lst, ' context')
          ELSE WriteLn(CRS.lst);
        anAction := anAction^.next
      END;
      INC(s)
    END;
    WriteLn(CRS.lst); WriteLn(CRS.lst, '-------- character classes ---------');
    i := 0;
    WHILE i <= CRTable.maxC DO BEGIN
      CRTable.GetClass(i, sset); CRTable.GetClassName(i, name);
      Write(CRS.lst, name:10, ': ');
      Sets.Print(CRS.lst, sset, 80, 13);
      WriteLn(CRS.lst);
      INC(i)
    END
  END;

(* AddAction            Add a action to the action list of a state
------------------------------------------------------------------------*) 

PROCEDURE AddAction (act : Action; VAR head : Action);
  VAR
    a, lasta : Action;
  BEGIN
    a := head;
    lasta := NIL;
    WHILE TRUE DO BEGIN
      IF (a = NIL) OR (act^.typ < a^.typ) THEN
        (*collecting classes at the front improves performance*) 
        BEGIN
          act^.next := a;
          IF lasta = NIL THEN head := act ELSE lasta^.next := act;
          EXIT;
        END;
      lasta := a;
      a := a^.next;
    END;
  END;

(* DetachAction         Detach action a from list L
------------------------------------------------------------------------*) 

PROCEDURE DetachAction (a : Action; VAR L : Action);
  BEGIN
    IF L = a THEN L := a^.next ELSE IF L <> NIL THEN DetachAction(a, L^.next)
  END;

FUNCTION TheAction (theState : State; ch : CHAR) : Action;
  VAR
    a : Action;
    sset : CRTable.CRTSet;
  BEGIN
    a := theState.firstAction;
    WHILE a <> NIL DO BEGIN
      IF a^.typ = CRTable.chart
        THEN
          BEGIN
            IF ORD(ch) = a^.sym THEN BEGIN TheAction := a; EXIT END
          END
        ELSE IF a^.typ = CRTable.class THEN
          BEGIN
            CRTable.GetClass(a^.sym, sset);
            IF Sets.IsIn(sset, ORD(ch)) THEN BEGIN TheAction := a; EXIT END
          END;
      a := a^.next
    END;
    TheAction := NIL
  END;

PROCEDURE AddTargetList (VAR lista, listb : Target);
  VAR
    p, t : Target;

  PROCEDURE AddTarget (t : Target; VAR list : Target);
    LABEL
      999;
    VAR
      p, lastp : Target;
    BEGIN
      p := list;
      lastp := NIL;
      WHILE TRUE DO BEGIN
        IF (p = NIL) OR (t^.theState < p^.theState) THEN GOTO 999;
        IF p^.theState = t^.theState THEN BEGIN DISPOSE(t); EXIT END;
        lastp := p; p := p^.next
      END;
      999:
      t^.next := p;
      IF lastp = NIL THEN list := t ELSE lastp^.next := t
    END;

  BEGIN

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区四区在线观看| 亚洲国产一区二区视频| 日韩精品一区二区三区老鸭窝| 一本到高清视频免费精品| 成人精品免费看| 国产v日产∨综合v精品视频| 国产不卡视频在线观看| a级高清视频欧美日韩| thepron国产精品| 91视频一区二区| 欧美色中文字幕| 欧美精品三级日韩久久| 精品福利视频一区二区三区| 久久久久久久国产精品影院| www久久精品| 中文字幕日韩一区| 一区二区三区国产豹纹内裤在线| 亚洲欧美一区二区三区极速播放| 一区二区在线观看视频| 美女一区二区在线观看| 大桥未久av一区二区三区中文| 99国产精品久久久久久久久久久| 色综合久久中文字幕综合网| 4438x亚洲最大成人网| 精品久久久久久最新网址| 欧美韩日一区二区三区四区| 亚洲裸体xxx| 久久国产精品一区二区| jiyouzz国产精品久久| 欧美日韩免费一区二区三区视频| 日韩精品中文字幕在线不卡尤物| 亚洲国产精品av| 亚洲香蕉伊在人在线观| 国产老妇另类xxxxx| 欧美亚洲国产一区二区三区va| 日韩欧美国产1| 伊人一区二区三区| 国产一区二区毛片| 欧美日韩一二三区| 欧美国产日产图区| 美国一区二区三区在线播放| 91亚洲永久精品| 久久夜色精品一区| 午夜精品福利在线| 国产成人精品亚洲777人妖| 欧美视频精品在线观看| 国产精品久久久久久久午夜片| 日韩成人免费看| 在线观看日韩av先锋影音电影院| xvideos.蜜桃一区二区| 视频一区在线播放| 色综合久久久网| 亚洲国产精品v| 国产乱一区二区| 欧美一级一级性生活免费录像| 亚洲激情在线播放| 99久久久精品| 国产亚洲一区字幕| 精品在线播放免费| 欧美日韩激情一区| 亚洲午夜精品在线| 成人h动漫精品一区二区| 久久亚洲综合av| 狠狠色丁香久久婷婷综合_中| 欧美日韩不卡视频| 亚洲一区二区三区四区在线免费观看 | 91久久精品午夜一区二区| 久久久久久久久久美女| 九九九精品视频| 亚洲精品一区二区精华| 久99久精品视频免费观看| 日韩欧美久久一区| 久久99精品久久久久久动态图| 欧美午夜精品久久久久久孕妇| 亚洲免费观看在线观看| 95精品视频在线| 一区二区三区四区视频精品免费 | 最近日韩中文字幕| 91色视频在线| 亚洲一区二区三区四区五区黄 | 欧美一区二区在线看| 午夜精品一区二区三区电影天堂 | 国产精品亚洲成人| 中文在线免费一区三区高中清不卡| 国产在线国偷精品免费看| 日韩免费高清电影| 国产成人午夜电影网| 中文字幕精品三区| 91美女视频网站| 亚洲国产日韩av| 欧美va亚洲va国产综合| 国产福利一区二区三区| 亚洲少妇最新在线视频| 在线观看中文字幕不卡| 亚洲大尺度视频在线观看| 91精品国产91久久久久久最新毛片| 丝袜美腿亚洲一区二区图片| 日韩精品一区二区三区在线 | 色婷婷av久久久久久久| 无吗不卡中文字幕| 久久九九影视网| 91麻豆福利精品推荐| 午夜精品福利久久久| 久久嫩草精品久久久精品一| 色悠久久久久综合欧美99| 丝袜美腿亚洲一区| 国产免费久久精品| 欧美性大战久久久久久久蜜臀| 免费在线观看日韩欧美| 亚洲欧洲美洲综合色网| 日韩一级欧美一级| 色天使色偷偷av一区二区| 免费成人在线观看视频| 亚洲男人的天堂av| 日韩一级视频免费观看在线| 91色乱码一区二区三区| 另类成人小视频在线| 亚洲激情中文1区| 国产片一区二区| 在线成人免费观看| 91视频在线看| 国产福利精品一区二区| 石原莉奈在线亚洲三区| 国产精品久久久久久亚洲伦| 日韩三级免费观看| 在线精品视频一区二区三四| 粗大黑人巨茎大战欧美成人| 免费成人在线视频观看| 亚洲成人资源在线| 最新成人av在线| 中文字幕的久久| 精品国产欧美一区二区| 欧美体内she精高潮| 99热99精品| 不卡影院免费观看| 国产高清不卡二三区| 国产真实乱子伦精品视频| 日韩国产欧美在线播放| 一级特黄大欧美久久久| 国产精品家庭影院| 久久精品一区二区| 久久蜜桃av一区精品变态类天堂| 欧美电影在线免费观看| 欧美日韩精品一区二区| 欧美亚洲图片小说| 欧美日韩在线三级| 欧美系列在线观看| 欧美亚洲动漫另类| 欧洲精品在线观看| 欧美性做爰猛烈叫床潮| 色综合天天综合| 色婷婷亚洲一区二区三区| 91美女片黄在线| 欧美亚洲高清一区| 欧美精品三级在线观看| 在线综合+亚洲+欧美中文字幕| 欧美日本乱大交xxxxx| 7777女厕盗摄久久久| 337p亚洲精品色噜噜狠狠| 欧美一区二区三区的| 日韩欧美国产综合在线一区二区三区 | 亚洲精品国产精华液| 亚洲精品国产高清久久伦理二区| 亚洲精品欧美激情| 亚洲bt欧美bt精品777| 日本欧美在线观看| 激情成人综合网| 成人永久免费视频| 色综合天天综合| 欧美精品自拍偷拍| 久久视频一区二区| 中文字幕一区二区三区不卡 | 一区二区三区资源| 五月激情综合色| 国产99久久久国产精品| 91免费在线视频观看| 欧美日韩国产一区二区三区地区| 717成人午夜免费福利电影| 精品剧情v国产在线观看在线| 中文字幕精品一区二区精品绿巨人 | 国产欧美精品一区二区三区四区 | 欧美在线|欧美| 精品国免费一区二区三区| 日本一区二区三区电影| 伊人婷婷欧美激情| 久久精品久久99精品久久| 国产999精品久久久久久绿帽| 在线免费精品视频| 精品久久久久久久一区二区蜜臀| 中文字幕亚洲电影| 美女一区二区视频| 欧美丝袜自拍制服另类| 日韩免费视频一区二区| 中文字幕在线播放不卡一区| 性久久久久久久久| a在线播放不卡| 日韩精品一区在线| 亚洲成a人片在线观看中文| 国产电影精品久久禁18| 678五月天丁香亚洲综合网|