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

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

?? cra.pas

?? 一個Pascal語言分析器
?? PAS
?? 第 1 頁 / 共 4 頁
字號:
    p := lista;
    WHILE p <> NIL DO BEGIN
      NEW(t); t^.theState := p^.theState; AddTarget(t, listb); p := p^.next
    END
  END;

(* NewMelted            Generate new info about a melted state
------------------------------------------------------------------------*) 

FUNCTION NewMelted (sset : CRTable.CRTSet; s : INTEGER) : Melted;
  VAR
    melt : Melted;
  BEGIN
    NEW(melt);
    melt^.sset := sset; melt^.theState := s; melt^.next := firstMelted;
    firstMelted := melt; NewMelted := melt
  END;

(* NewState             Return a new state node
------------------------------------------------------------------------*) 

FUNCTION NewState : INTEGER;
  BEGIN
    INC(lastState);
    IF lastState > maxStates THEN CRTable.Restriction(7, maxStates);
    stateArray[lastState].firstAction := NIL;
    stateArray[lastState].endOf := CRTable.noSym;
    stateArray[lastState].ctx := FALSE;
    NewState := lastState
  END;

(* NewTransition        Generate transition (gn.theState, gn.p1) --> toState
------------------------------------------------------------------------*) 

PROCEDURE NewTransition (from : INTEGER; gn : CRTable.GraphNode; toState : INTEGER);
  VAR
    a : Action;
    t : Target;
  BEGIN
    IF toState = rootState THEN SemErr(21);
    NEW(t); t^.theState := toState; t^.next := NIL;
    NEW(a); a^.typ := gn.typ; a^.sym := gn.p1; a^.tc := gn.p2; a^.target := t;
    AddAction(a, stateArray[from].firstAction)
  END;

(* NewComment           Define new comment
-------------------------------------------------------------------------*) 

PROCEDURE NewComment (start, stop : INTEGER; nested : BOOLEAN);
  VAR
    com : Comment;

  PROCEDURE MakeStr (gp : INTEGER; VAR s : STRING2);
    VAR
      i, n : INTEGER;
      gn : CRTable.GraphNode;
      sset : CRTable.CRTSet;
    BEGIN
      i := 1;
      WHILE gp <> 0 DO BEGIN
        CRTable.GetNode(gp, gn);
        IF gn.typ = CRTable.chart
          THEN
            BEGIN IF i < 3 THEN s[i] := CHR(gn.p1); INC(i) END
          ELSE IF gn.typ = CRTable.class THEN
            BEGIN
              CRTable.GetClass(gn.p1, sset);
              IF Sets.Elements(sset, n) <> 1 THEN SemErr(26);
              IF i < 3 THEN s[i] := CHR(n);
              INC(i)
            END
          ELSE SemErr(22);
        gp := gn.next
      END;
      IF (i = 1) OR (i > 3) THEN SemErr(25) ELSE s[0] := CHR(i-1)
    END;

  BEGIN
    NEW(com);
    MakeStr(start, com^.start);
    MakeStr(stop, com^.stop);
    com^.nested := nested;
    com^.next := firstComment;
    firstComment := com
  END;

(* DeleteTargetList     Delete a target list
-------------------------------------------------------------------------*) 

PROCEDURE DeleteTargetList (list : Target);
  BEGIN
    IF list <> NIL THEN BEGIN DeleteTargetList(list^.next); DISPOSE(list) END;
  END;

(* DeleteActionList     Delete an action list
-------------------------------------------------------------------------*) 

PROCEDURE DeleteActionList (anAction : Action);
  BEGIN
    IF anAction <> NIL THEN
      BEGIN
        DeleteActionList(anAction^.next);
        DeleteTargetList(anAction^.target);
        DISPOSE(anAction)
      END
  END;

(* MakeSet              Expand action symbol into symbol set
-------------------------------------------------------------------------*) 

PROCEDURE MakeSet (p : Action; VAR sset : CRTable.CRTSet);
  BEGIN
    IF p^.typ = CRTable.class
      THEN CRTable.GetClass(p^.sym, sset)
      ELSE BEGIN Sets.Clear(sset); Sets.Incl(sset, p^.sym) END
  END;

(* ChangeAction         Change the action symbol to set
-------------------------------------------------------------------------*) 

PROCEDURE ChangeAction (a : Action; sset : CRTable.CRTSet);
  VAR
    nr : INTEGER;

  BEGIN
    IF Sets.Elements(sset, nr) = 1
      THEN BEGIN a^.typ := CRTable.chart; a^.sym := nr END
      ELSE
        BEGIN
          nr := CRTable.ClassWithSet(sset);
          IF nr < 0 THEN nr := CRTable.NewClass('##', sset);
          a^.typ := CRTable.class; a^.sym := nr
        END
  END;

(* CombineShifts     Combine shifts with different symbols into same state
-------------------------------------------------------------------------*) 

PROCEDURE CombineShifts;
  VAR
    s : INTEGER;
    a, b, c : Action;
    seta, setb : CRTable.CRTSet;

  BEGIN
    s := rootState;
    WHILE s <= lastState DO BEGIN
      a := stateArray[s].firstAction;
      WHILE a <> NIL DO BEGIN
        b := a^.next;
        WHILE b <> NIL DO BEGIN
          IF (a^.target^.theState = b^.target^.theState) AND (a^.tc = b^.tc)
            THEN
              BEGIN
                MakeSet(a, seta); MakeSet(b, setb);
                Sets.Unite(seta, setb);
                ChangeAction(a, seta);
                c := b; b := b^.next;
                DetachAction(c, a)
              END
            ELSE b := b^.next
        END;
        a := a^.next
      END;
      INC(s)
    END
  END;

(* DeleteRedundantStates   Delete unused and equal states
-------------------------------------------------------------------------*) 

PROCEDURE DeleteRedundantStates;
  VAR
    anAction : Action;
    s, s2, next : INTEGER;
    used : Sets.BITARRAY;
    {ARRAY [0 .. maxStates DIV Sets.size] OF BITSET } (*KJG*)
    newStateNr : ARRAY [0 .. maxStates] OF INTEGER;

  PROCEDURE FindUsedStates (s : INTEGER);
    VAR
      anAction : Action;
    BEGIN
      IF Sets.IsIn(used, s) THEN EXIT;
      Sets.Incl(used, s);
      anAction := stateArray[s].firstAction;
      WHILE anAction <> NIL DO BEGIN
        FindUsedStates(anAction^.target^.theState);
        anAction := anAction^.next
      END
    END;

  BEGIN
    Sets.Clear(used);
    FindUsedStates(rootState);
    (*---------- combine equal final states ------------*) 
    s := rootState + 1;
    (*root state cannot be final*) 
    WHILE s <= lastState DO BEGIN
      IF Sets.IsIn(used, s) AND (stateArray[s].endOf <> CRTable.noSym) THEN
        IF (stateArray[s].firstAction = NIL) AND NOT stateArray[s].ctx THEN
          BEGIN
            s2 := s + 1;
            WHILE s2 <= lastState DO BEGIN
              IF Sets.IsIn(used, s2) AND (stateArray[s].endOf = stateArray[s2].endOf) THEN
                IF (stateArray[s2].firstAction = NIL) AND NOT stateArray[s2].ctx THEN
                  BEGIN Sets.Excl(used, s2); newStateNr[s2] := s END;
              INC(s2)
            END
          END;
      INC(s)
    END;
    s := rootState;
    (* + 1 ?  PDT - was rootState, but Oberon had .next ie +1
                    seems to work both ways?? *) 
    WHILE s <= lastState DO BEGIN
      IF Sets.IsIn(used, s) THEN
        BEGIN
          anAction := stateArray[s].firstAction;
          WHILE anAction <> NIL DO BEGIN
            IF NOT Sets.IsIn(used, anAction^.target^.theState) THEN
              anAction^.target^.theState := newStateNr[anAction^.target^.theState];
            anAction := anAction^.next
          END
        END;
      INC(s)
    END;
    (*-------- delete unused states --------*) 
    s := rootState + 1;
    next := s;
    WHILE s <= lastState DO BEGIN
      IF Sets.IsIn(used, s)
        THEN
          BEGIN
            IF next < s THEN stateArray[next] := stateArray[s];
            newStateNr[s] := next;
            INC(next)
          END
        ELSE DeleteActionList(stateArray[s].firstAction);
      INC(s)
    END;
    lastState := next - 1;
    s := rootState;
    WHILE s <= lastState DO BEGIN
      anAction := stateArray[s].firstAction;
      WHILE anAction <> NIL DO BEGIN
        anAction^.target^.theState := newStateNr[anAction^.target^.theState];
        anAction := anAction^.next
      END;
      INC(s)
    END
  END;

(* ConvertToStates    Convert the TDG in gp into a subautomaton of the DFA
------------------------------------------------------------------------*) 

PROCEDURE ConvertToStates (gp0, sp : INTEGER);
(*note: gn.line is abused as a state number!*) 

  VAR
    visited: CRTable.MarkList;

  PROCEDURE NumberNodes (gp, snr : INTEGER);
    VAR
      gn : CRTable.GraphNode;
    BEGIN
      IF gp = 0 THEN EXIT; (*end of graph*)
      CRTable.GetNode(gp, gn);
      IF gn.line >= 0 THEN EXIT; (*already visited*)
      IF snr < rootState THEN snr := NewState;
      gn.line := snr; CRTable.PutNode(gp, gn);
      IF CRTable.DelGraph(gp) THEN stateArray[snr].endOf := sp;
      (*snr is end state*) 
      CASE gn.typ OF
        CRTable.class, CRTable.chart :
          BEGIN NumberNodes(ABS(gn.next), rootState - 1) END;
        CRTable.opt :
          BEGIN NumberNodes(ABS(gn.next), rootState - 1); NumberNodes(gn.p1, snr) END;
        CRTable.iter :
          BEGIN NumberNodes(ABS(gn.next), snr); NumberNodes(gn.p1, snr) END;
        CRTable.alt :
          BEGIN NumberNodes(gn.p1, snr); NumberNodes(gn.p2, snr) END;
      END;
    END;

  FUNCTION TheState (gp : INTEGER) : INTEGER;
    VAR
      s : INTEGER;
      gn : CRTable.GraphNode;
    BEGIN
      IF gp = 0
        THEN BEGIN s := NewState; stateArray[s].endOf := sp; TheState := s END
        ELSE BEGIN CRTable.GetNode(gp, gn); TheState := gn.line END
    END;

  PROCEDURE Step (from, gp : INTEGER);
    VAR
      gn : CRTable.GraphNode;
    BEGIN
      IF gp = 0 THEN EXIT;
      CRTable.GetNode(gp, gn);
      CASE gn.typ OF
        CRTable.class, CRTable.chart :
          BEGIN NewTransition(from, gn, TheState(ABS(gn.next))) END;
        CRTable.alt :
          BEGIN Step(from, gn.p1); Step(from, gn.p2) END;
        CRTable.opt, CRTable.iter :
          BEGIN Step(from, ABS(gn.next)); Step(from, gn.p1) END;
      END
    END;

  PROCEDURE FindTrans (gp : INTEGER; start : BOOLEAN);
    VAR
      gn : CRTable.GraphNode;
    BEGIN
      IF (gp = 0) OR CRTable.IsInMarkList(visited, gp) THEN EXIT;
      CRTable.InclMarkList(visited, gp); CRTable.GetNode(gp, gn);
      IF start THEN Step(gn.line, gp); (* start of group of equally numbered nodes *)
      CASE gn.typ OF
        CRTable.class, CRTable.chart :
          BEGIN FindTrans(ABS(gn.next), TRUE) END;
        CRTable.opt :
          BEGIN FindTrans(ABS(gn.next), TRUE); FindTrans(gn.p1, FALSE) END;
        CRTable.iter :
          BEGIN FindTrans(ABS(gn.next), FALSE); FindTrans(gn.p1, FALSE) END;
        CRTable.alt :
          BEGIN FindTrans(gn.p1, FALSE); FindTrans(gn.p2, FALSE) END;
      END;
    END;

  VAR
    gn : CRTable.GraphNode;
    i : INTEGER;

  BEGIN
    IF CRTable.DelGraph(gp0) THEN SemErr(20);
    FOR i := 0 TO CRTable.nNodes DO BEGIN
      CRTable.GetNode(i, gn); gn.line :=  -1; CRTable.PutNode(i, gn)
    END;
    NumberNodes(gp0, rootState);
    CRTable.ClearMarkList(visited);
    FindTrans(gp0, TRUE)
  END;

(* MatchesDFA         TRUE, if the string str can be recognized by the DFA
------------------------------------------------------------------------*)
{ fossil from modula - maybe we should delete
PROCEDURE MatchesDFA (str: STRING; VAR matchedSp: INTEGER): BOOLEAN;
  VAR
    len: INTEGER;

  PROCEDURE Match (p: INTEGER; s: INTEGER): BOOLEAN;
    VAR
      ch:    CHAR;
      a:     Action;
      equal: BOOLEAN;
      sset:   CRTable.CRTSet;
    BEGIN
      IF p >= len THEN
        IF stateArray[s].endOf # CRTable.noSym
          THEN matchedSp := stateArray[s].endOf; RETURN TRUE
          ELSE RETURN FALSE
        END
      END;
      a := stateArray[s].firstAction; ch := str[p];
      WHILE a # NIL DO
        CASE a^.typ OF
          CRTable.char:
            equal := VAL(INTEGER, ORD(ch)) = a^.sym
        | CRTable.class:
            CRTable.GetClass(a^.sym, sset); equal := Sets.IsIn(sset, ORD(ch))
        END;
        IF equal THEN RETURN Match(p + 1, a^.target^.theState) END;
        a := a^.next

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费观看日韩电影| 欧美日韩午夜影院| 日本美女一区二区| 日韩精品亚洲专区| 亚洲国产你懂的| 亚洲影院理伦片| 亚洲一区二区黄色| 日韩在线观看一区二区| 亚洲在线观看免费| 午夜国产精品影院在线观看| 一区二区三区四区av| 最新国产精品久久精品| 亚洲日本va午夜在线影院| 国产精品久久久久aaaa樱花| 亚洲图片激情小说| 亚洲国产日日夜夜| 天堂在线一区二区| 国产二区国产一区在线观看| 国产不卡在线一区| 色94色欧美sute亚洲线路二| 欧美日韩在线播放| 欧美成人伊人久久综合网| 国产欧美一区二区三区鸳鸯浴 | 一区二区三区美女| 亚洲aⅴ怡春院| 久久超碰97中文字幕| 91香蕉视频mp4| 7777精品伊人久久久大香线蕉的| 日韩美女一区二区三区四区| 国产欧美日韩三区| 一卡二卡欧美日韩| 国内精品久久久久影院色| 成人av资源在线观看| 欧美日韩国产精选| 久久久久久一二三区| 一区二区欧美国产| 国产在线精品免费av| 色综合天天综合在线视频| 在线播放中文字幕一区| 国产精品成人网| 水蜜桃久久夜色精品一区的特点 | 懂色av噜噜一区二区三区av| 91国内精品野花午夜精品| 日韩免费福利电影在线观看| 国产精品免费久久| 婷婷丁香久久五月婷婷| 99在线视频精品| 欧美又粗又大又爽| 国产欧美一区二区精品性色| 亚洲成a人片在线观看中文| 美女mm1313爽爽久久久蜜臀| 国产成人精品影视| 精品久久久久av影院| 有码一区二区三区| 成人h动漫精品一区二| 欧美成人精品福利| 亚洲图片你懂的| 成人午夜激情视频| 久久久久久久国产精品影院| 麻豆国产91在线播放| 69久久夜色精品国产69蝌蚪网| 亚洲免费观看高清完整版在线 | 亚洲欧洲日韩一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 色狠狠桃花综合| 国产精品福利一区二区三区| 国产成人亚洲综合a∨猫咪| 精品国产自在久精品国产| 日本免费新一区视频| 欧美一区欧美二区| 亚洲人妖av一区二区| 精品少妇一区二区三区日产乱码 | 9191久久久久久久久久久| 日韩免费观看高清完整版在线观看| 久久久亚洲欧洲日产国码αv| 综合色中文字幕| 久久超级碰视频| 欧美在线免费视屏| 精品国产不卡一区二区三区| 亚洲综合一区二区| 懂色av一区二区在线播放| 欧美电影在线免费观看| 国产精品久久久久久久久快鸭| 天天色综合天天| 99r国产精品| 精品日韩在线观看| 午夜精品福利在线| 色综合天天综合在线视频| 国产欧美视频一区二区三区| 亚洲大片一区二区三区| 99re在线视频这里只有精品| 久久女同互慰一区二区三区| 日本aⅴ精品一区二区三区| 亚洲成在线观看| 丰满亚洲少妇av| 欧美性生活影院| 一区二区三区四区在线播放| 99久久夜色精品国产网站| 久久久久久久久久久久久久久99| 天堂在线亚洲视频| 3d动漫精品啪啪一区二区竹菊| 一区二区视频免费在线观看| 91美女视频网站| 中文字幕亚洲电影| 色88888久久久久久影院野外| 国产精品日韩精品欧美在线| 成人免费观看av| 欧美精彩视频一区二区三区| 国产v综合v亚洲欧| 国产日韩欧美麻豆| 青草国产精品久久久久久| 一本色道**综合亚洲精品蜜桃冫| 中文字幕欧美区| 欧美体内she精高潮| 亚洲第一久久影院| 欧美一区二区三区婷婷月色| 青青国产91久久久久久| 精品国产制服丝袜高跟| 国产黄人亚洲片| 国产精品久久久久影院| 91麻豆国产香蕉久久精品| 樱桃视频在线观看一区| 欧洲一区二区三区在线| 免费人成在线不卡| 久久亚洲影视婷婷| 91女人视频在线观看| 亚洲综合一区二区三区| 久久精品国产免费| 亚洲综合成人网| 欧美一级一区二区| 高清在线成人网| 一区二区三区在线观看欧美| 欧美精品欧美精品系列| 看电视剧不卡顿的网站| 国产亚洲va综合人人澡精品| 97se亚洲国产综合自在线不卡| 亚洲一区视频在线| 26uuu亚洲综合色欧美| 99久免费精品视频在线观看| 亚洲电影在线免费观看| 国产日韩亚洲欧美综合| 欧美精品免费视频| 高清免费成人av| 偷拍与自拍一区| 欧美激情在线一区二区三区| 91原创在线视频| 国产在线一区观看| 国产丝袜在线精品| 欧美日韩一区在线观看| 成人福利视频在线看| 日韩精品成人一区二区在线| 在线观看免费成人| 亚洲成av人片一区二区梦乃| 中文一区二区在线观看| 日韩一区二区电影网| 99这里只有久久精品视频| 免费高清不卡av| 亚洲一区二区av电影| 在线播放/欧美激情| 国产一区视频在线看| 亚洲图片一区二区| 国产精品久久久久婷婷| 精品免费一区二区三区| 精品视频一区三区九区| 国产成人在线视频免费播放| 天天做天天摸天天爽国产一区| 中文字幕一区日韩精品欧美| 精品国产一区二区三区av性色| 欧美怡红院视频| 高清不卡在线观看| 一本色道a无线码一区v| 成人午夜视频在线观看| 麻豆一区二区三| 视频一区二区中文字幕| 亚洲妇女屁股眼交7| 亚洲美女区一区| 夜夜嗨av一区二区三区网页| 国产精品麻豆欧美日韩ww| 精品免费国产二区三区| 91精品久久久久久久91蜜桃| 国产清纯在线一区二区www| 精品捆绑美女sm三区| 久久众筹精品私拍模特| 欧美成人video| 精品美女一区二区| 久久久久久久久免费| 精品国产乱码久久久久久图片| 精品日产卡一卡二卡麻豆| 久久青草国产手机看片福利盒子| 欧美不卡一区二区| 欧美tickling网站挠脚心| 日韩一区二区电影网| 欧美岛国在线观看| 欧美成人精精品一区二区频| 久久久国产精品麻豆| 精品剧情在线观看| 337p粉嫩大胆噜噜噜噜噜91av | 日韩女优av电影| 欧美大片在线观看一区二区| 日韩一级精品视频在线观看|