• <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>

            歲月流轉,往昔空明

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks

            1. Diagnostic需要提供哪些數(shù)據(jù)

            出錯處理和錯誤提示,是編譯器開發(fā)過程中重要而繁瑣的部分。

            診斷信息的格式因編譯器和IDE而不同。

            SALVIA將采用Visual Studio的格式,即 文件 + 行列 + 類別(等級) + 編號 + 出錯信息。例如:

            d:\programming\salvia\sasl\test\cgllvm_test\function_test_basic.cpp(16): error C2061: syntax error : identifier 'te'

            因此在出錯分析的時候,也需要提供如上的一些信息。


            2. 診斷信息Diagnostic Item

            在以上信息中,文件名和行列號可以在詞法分析的時候獲得,我們將它作為屬性附加在Token中。

            類別和編號,對于同一個編譯器而言是相對固定的,盡管我們可以用ID來表示,但是它并不直觀,編譯器檢查也較少。與參數(shù)匹配時,也比較容易出錯。

            SASL中的診斷信息將每個錯誤都使用一個類型來表達:

            class diagnostic_item
            {
            };
            
            
            class unrecognized_identifier: public diagnostic_item
            {
            public:
                unrecognized_identifier& token( token_t tok );
                
            private:
                static int level;
                static int id;
                static std::string description_template;
                
            private:
                std::string ident;
                size_t      row, col;
                // Other properties
            };

            這樣的好處在于可以用Combinator的風格來撰寫錯誤信息。例如這樣:

            diagnostic_chat.report<unrecognized_identifier>().token( err_tok );

            并且由于編譯器的保證也比較不容易寫錯。

             

            但是這種寫法也有一個很關鍵的問題,需要為每個錯誤都定義一個類,工作量很大。SASL對這一問題的處理,自然是傳統(tǒng)的大殺器:運用腳本進行生成。

            Clang使用了它內置的代碼生成工具td來完成生成的工作。

             

            3. 診斷信息管理器Diagnostic Chat

            Chat是診斷信息的管理工具。它主要要完成以下需求:添加和清理診斷信息,以及在診斷信息的添加清理時提供回調操作。

            后者是很有用的,尤其是在調試編譯器的時候。你得分清楚究竟是真正的程序錯誤呢,還是編譯器出了錯。

            Diagnostic Chat的原型如下:

            class diagnostic_chat
            {
            public:
                template <typename T> T& report();
                void add_report_diagnostic_handler( DiagnosticHandlerT handler );
            };

            同時,我們也將Treat Warning As Error,Error Count,Disable Warning,Stop compiling when error occurs等狀態(tài)和功能所需要的支持添加到Chat中。

            所以,Chat除了提供管理之外,也要具有相應的診斷信息的統(tǒng)計功能。

             

            4. 過濾器Diagnostic Filter

            Filter主要配合IDE使用,從Chat中取出符合條件的診斷信息。Error Count和Disable Warnings等功能也可以通過它來完成。

             

            5. Formatter

            Formatter用于將DiagnosticItems中的信息轉換成人可讀的字符串。目前SASL只打算支持Visual Studio的格式,但是相信支持GCC的格式以更好的和Eclipse等第三方IDE集成并不困難。

            在C#里面,我們可以用“We need ‘{0}’ not ‘{1}’.”這樣的方式來分離description template并延期的產(chǎn)生格式化的字符串。但是在C++中,這種做法并不容易。C的sprintf很難具有延期、漸增的綁定模板的特定,對自定義類型的字符串化的支持也不足,類型安全也比較差;而stream的話,也會面臨著將好端端的格式化字符串割裂的問題。SASL使用了boost.format,從一定程度上搞定了這兩個問題,從而像C#一樣,使用格式化字符串的功能。

            posted on 2012-03-08 21:25 空明流轉 閱讀(2052) 評論(0)  編輯 收藏 引用
            久久人人爽人人爽人人av东京热| 久久精品国产亚洲AV无码偷窥| 91久久精品国产免费直播| 91久久九九无码成人网站| 久久久久一级精品亚洲国产成人综合AV区 | 中文字幕乱码人妻无码久久 | 国内精品久久久久久99蜜桃| 国产成人精品免费久久久久| 国产激情久久久久影院小草 | 国内精品伊人久久久久| 久久久网中文字幕| 99久久精品国产一区二区| 77777亚洲午夜久久多喷| 久久免费大片| 久久精品国产91久久综合麻豆自制| 久久精品中文字幕有码| 久久久久99精品成人片直播| 久久97久久97精品免视看| 久久亚洲精品成人AV| 日韩欧美亚洲综合久久影院Ds | 久久噜噜久久久精品66| 久久99国内精品自在现线| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久中文精品无码中文字幕| 国产精品美女久久久久网| 久久精品极品盛宴观看| 精品无码人妻久久久久久| 久久亚洲精品成人av无码网站| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 亚洲国产成人久久一区久久| 久久久久一区二区三区| 91精品国产综合久久精品| 欧美黑人又粗又大久久久| 性做久久久久久久久浪潮| 中文字幕一区二区三区久久网站| 久久w5ww成w人免费| 欧美亚洲色综久久精品国产| 精品久久久无码人妻中文字幕| 亚洲七七久久精品中文国产| 亚洲国产成人乱码精品女人久久久不卡 | 偷窥少妇久久久久久久久|