青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

loop_in_codes

低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

kl中的錯誤處理

kl中的錯誤處理

    之前我一直說錯誤處理是kl里的軟肋,由于一直在關注一些具體功能的改進,也沒有對
這方面進行改善。

    我這里所說的錯誤處理,包括語言本身和作為庫本身兩方面。
    語言本身指的是對于腳本代碼里的各種語法錯誤、運行時錯誤等的處理。好的處理應該
不僅僅可以報告錯誤,而且還能忽視錯誤讓處理過程繼續。
    而把kl解釋器作為一個庫使用時,庫本身也應該對一些錯誤情況進行報告。

    整體上,kl簡單地通過回調函數指針來把錯誤信息傳給庫的應用層。而因為我希望整個
kl實現的幾層(詞法分析、語法分析、符號表、解釋器等)可以盡可能地獨立。例如雖然語
法分析依賴于詞法分析(依賴于詞法分析提供的接口),但是因為詞法分析并不對語法分析
依賴,所以完全可以把詞法分析模塊拿出來單獨使用。所以,在日志方面,我幾乎為每一層
都附加了個error_log函數指針。
    而用戶層在通過kllib層使用整個庫時,傳入的回調函數會被間接地傳到詞法分析層。
實際上,當kl作為一個庫時,kllib正是用于橋接庫本身和用戶層的bridge。

    另一方面,語言本身在處理錯誤的腳本代碼時,錯誤分為幾大類型層次:
    1.詞法錯誤 lex error,如掃描字符串出錯
    2.語法錯誤 syntax error,整理語法樹時出錯
    3.運行時錯誤 runtime error,在解釋執行代碼時出錯
    4.庫錯誤 lib error,發生在kllib這個bridge層的錯誤
    kl在報告錯誤信息時,會首先附加該錯誤是什么類型的錯誤。

    這里最麻煩的是語法錯誤的處理。因為語法分析時發生錯誤的可能性最大,錯誤類型也
有很多。例如你少寫了分號,少寫了括號,都會導致錯誤。這個階段發生錯誤不僅要求能準
確報告錯誤,還需要忽略錯誤讓整個過程盡量正確地下去。

    語法分析階段最根本的就是符號推導(單就kl的實現而言),所謂的符號推導是這樣一
個過程,例如有賦值語句:a = 1;語法分析時,語法分析器希望(所謂的推導)等號后面會
是一個表達式,當分析完了表達式后,又希望接下來的符號(token)是分號作為該語句的結
束。
    所以,klparser.c中的syn_match正是完成這個過程。每次你傳入你希望的符號,例如
分號,該函數就檢查詞法分析中當前符號(token)是否是分號。當然,對于正確的腳本代碼,
它是一個分號,但是如果是錯誤的代碼,syn_match就會打印諸如:
    >>syntax error->unexpected token-> ....
    即當前的符號是不被期望的。

    上面完成了錯誤的檢測。對于錯誤的忽略,或者更高級點地對錯誤的校正,kl中處理得
比較簡單,即:直接消耗掉這個不是期望中的符號。例如:
    a = 1 /* 忘加了分號 */
    b = 1;
    上面兩句代碼被處理時,在處理完a=1后,發現當前的符號(token)b(是一個ID token)不
是期望(expect)中的分號,首先報告b不是期望的符號,然后kl直接掠過b,獲取下個符號=。
然后處理a=1這個過程結束。當然,下次處理其他語句時,發現=符號,又會繼續發生錯誤。

    錯誤信息中比較重要的還有行號信息。之前kl這方面一直存在BUG,我在寫貪食蛇例子
的時候每次新加代碼都不敢加太多。因為解釋器報告的錯誤行號總是錯誤的,我只能靠有沒
有錯誤來找錯誤,而不能通過錯誤信息找錯誤。
    行號信息被保存在詞法分析狀態中(lexState:lineno),語法分析中獲取token時,會取
出當前的行號,保存到語法樹樹節點中。因為包括解釋模塊都是基于樹節點的,所以詞法分
析語法分析解釋器三層都可以準確報告行號。

    但是之前解釋器報告的行號始終很詭異。癥結在于我在載入腳本代碼文件時,以rb方式
載入,即二進制形式。于是,在windows下,每行文本尾都會有\r\n兩個字符。而在詞法分
析階段對于行號的增加是:
    case '\n':
    case '\r':
        ls->lineno ++;
    不同OS對于文本文件的換行所添加的字符都不一樣,例如windows用\r\n,unix系用\n
,貌似Mac用\r。所以,詞法分析這里寫應該可以準確地處理行號。

    但是對于windows,這里就直接將行號增加了兩次,所以也就導致了行號出錯的問題。查
了下文檔,發現以文本方式打開文件("r"),調用fread函數讀入文件內容時,就會自動把
\r\n替換為\n。

    代碼改后,又出問題。這個時候,通過fseek和ftell獲取到的文件尺寸,貌似包括了
\r\n,而fread出來的內容卻因為替換\r\n為\n而沒有這么多。
    不過文件載入不屬于kl庫本身,kl只接收以字符串形式表示的腳本代碼,所以也算不了
核心問題。

    同樣,最新代碼可以從google SVN獲取。當然,我也在考慮是否換一個新的項目地址。

posted on 2009-03-26 17:17 Kevin Lynx 閱讀(3187) 評論(0)  編輯 收藏 引用 所屬分類: kl腳本實現編譯原理

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99re6这里只有精品视频在线观看| 国产精品综合久久久| 久久综合一区| 欧美一区二区三区另类| 亚洲一区区二区| 亚洲综合精品| 午夜精品久久久| 欧美综合第一页| 欧美日韩伦理在线| 欧美精品xxxxbbbb| 欧美日韩在线三级| 国产美女扒开尿口久久久| 国产精品呻吟| 国内精品国产成人| 亚洲国产精品第一区二区三区| 91久久精品一区二区三区| 亚洲日韩成人| 亚洲免费在线电影| 久久久久国色av免费观看性色| 久久女同互慰一区二区三区| 欧美大秀在线观看| 夜夜嗨av一区二区三区中文字幕| 亚洲视频中文| 久久久久久久久伊人| 男人天堂欧美日韩| 国产精品免费小视频| 激情久久久久久久久久久久久久久久| 亚洲国产91色在线| 亚洲欧美国产一区二区三区| 老鸭窝毛片一区二区三区| 亚洲国产精品免费| 亚洲乱码国产乱码精品精| 亚洲欧美日韩国产一区二区| 国产一区在线播放| 麻豆精品精华液| 美国三级日本三级久久99| 欧美成人中文| 国产精品国色综合久久| 尹人成人综合网| 在线视频欧美精品| 欧美日本久久| 国产精品一区二区久久久久| 亚洲国产视频一区| 久久久国际精品| 亚洲乱码精品一二三四区日韩在线| 校园春色国产精品| 欧美色精品天天在线观看视频| 国产午夜精品一区二区三区欧美 | 欧美午夜精品久久久| 在线免费观看欧美| 欧美在线观看网址综合| 亚洲久久成人| 欧美不卡激情三级在线观看| 国产亚洲精品综合一区91| 亚洲天堂网站在线观看视频| 欧美成人一区二区三区| 欧美一区二区三区婷婷月色| 国产精品成人v| 艳妇臀荡乳欲伦亚洲一区| 欧美国产日本| 老司机亚洲精品| 伊人精品久久久久7777| 久久久久国色av免费观看性色| 亚洲欧美国产高清| 国产精品日日做人人爱| 亚洲欧美日韩视频二区| 99视频超级精品| 欧美日韩国产小视频| 亚洲麻豆国产自偷在线| 欧美国内亚洲| 欧美精品1区| 中日韩美女免费视频网址在线观看 | 欧美人妖另类| 日韩视频在线一区二区三区| 亚洲第一区在线| 久久精品亚洲国产奇米99| 一区二区精品在线观看| 国产精品久久久久久久久免费樱桃 | 亚洲天堂免费在线观看视频| 亚洲一二三级电影| 国产日韩欧美二区| 久久婷婷久久| 免费成人黄色| 日韩天堂在线观看| 夜夜夜久久久| 国产性天天综合网| 久久综合狠狠综合久久激情| 免费亚洲电影在线观看| 99视频国产精品免费观看| 在线视频精品一| 国产一区久久| 欧美韩日精品| 欧美视频精品一区| 久久久99久久精品女同性| 久久日韩粉嫩一区二区三区| 一区二区91| 亚洲国产天堂久久国产91| 欧美日韩第一区| 午夜天堂精品久久久久| 久久av免费一区| 欧美成人一二三| 亚洲专区在线| 久久精品日产第一区二区| 日韩视频免费观看高清在线视频| 99国产精品久久久久久久| 国产精品综合| 欧美激情视频网站| 国产欧美精品国产国产专区| 亚洲国产综合视频在线观看| 国产日韩精品视频一区二区三区 | 老司机凹凸av亚洲导航| 欧美成人高清视频| 国产精品美女视频网站| 欧美不卡高清| 国产伦理一区| 亚洲激情成人| 亚洲第一久久影院| 欧美一区二区| 亚洲欧美视频| 欧美日韩免费观看一区| 免费在线看一区| 国产日韩欧美在线| 一区二区三区精品视频在线观看| 亚洲国产视频一区二区| 久久精品男女| 久久久成人精品| 国产精品网红福利| 一个人看的www久久| 亚洲精选在线| 免费亚洲一区| 欧美激情视频一区二区三区不卡| 国内精品一区二区三区| 午夜在线一区二区| 欧美在线高清| 国产精品久久波多野结衣| 一本色道久久综合狠狠躁篇的优点 | 欧美三区在线视频| 欧美激情一区二区三区在线视频 | 亚洲午夜精品久久| 欧美国产丝袜视频| 欧美黑人多人双交| 亚洲国产精品日韩| 久久久噜噜噜久噜久久| 久久成人资源| 韩国精品久久久999| 欧美在线免费播放| 久久一区二区三区超碰国产精品| 国产一区二区三区成人欧美日韩在线观看 | 老巨人导航500精品| 久久久www| 免费成人网www| 在线不卡中文字幕| 久久这里有精品15一区二区三区| 蜜桃伊人久久| 亚洲人www| 欧美日韩国产va另类| 一区二区三区毛片| 性欧美办公室18xxxxhd| 国产一区二区激情| 久久综合狠狠综合久久综青草 | 欧美激情精品久久久久久黑人| 亚洲国产精品热久久| 一区二区三区成人| 国产精品午夜在线| 久久久伊人欧美| 亚洲精品综合在线| 香蕉国产精品偷在线观看不卡| 国产日韩精品在线观看| 久色成人在线| 一区二区三区四区五区精品视频| 欧美一区二区三区精品| 亚洲电影免费在线观看| 欧美日韩国产综合网| 小辣椒精品导航| 亚洲精品资源| 久色婷婷小香蕉久久| 妖精成人www高清在线观看| 国产日韩欧美一区二区三区在线观看| 久久亚洲精品伦理| 亚洲伊人久久综合| 欧美成人一区二免费视频软件| 亚洲天堂网在线观看| 有码中文亚洲精品| 国产精品久久久免费| 午夜激情久久久| 亚洲国产精品久久人人爱蜜臀| 欧美色图一区二区三区| 看片网站欧美日韩| 亚洲在线电影| 亚洲精品日韩欧美| 免费人成精品欧美精品| 香港久久久电影| 中文有码久久| 亚洲第一页在线| 国产日本欧美一区二区| 欧美日韩一区在线观看| 免费观看久久久4p| 久久本道综合色狠狠五月| 中日韩美女免费视频网址在线观看| 欧美刺激性大交免费视频|