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

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數據加載中……

[bash源碼分析] 3 語法分析 - 入口點


語法分析 - 入口點


--- main()
    我們打開shell.c的main函數,大概300來行,其主題都是圍繞這xxx_init,做各種初始化操作。
    我們可以略過不看,等遇到問題的時候再說。把目光放到最后一句 reader_loop()。這是一個循環讀
    入并執行命令的函數。

--- reader_loop()
    位于eval.c的reader_loop()函數,其中仿佛只有調用read_command()是重點。

--- read_command()
    同樣位于eval.c的read_command()函數。一開始那一段ALARM信號的處理讓人覺得很費解,難道
    在bash輸入命令還要有時間限制嗎?無論如何,這種看似偏門的、非關鍵性的東西,在代碼分析的初期
    是不能理會的,如果太深究這些東西,沒有把握代碼的主線,則會走入死胡同,而且會失去源碼分析
    的樂趣。
    代碼主線走入parse_command()函數。

--- parse_command()
    同樣位于eval.c的parse_command()函數。它調用的yyparse()函數是語法分析的開始。
    用過yacc的人很明白這一點了。一開始我們看到文件列表中有y.tab.c這樣的文件,就能意識到bash也是
    利用yacc生成的代碼來完成語法分析的。

--- Yacc的作用
    你只要告訴yacc三樣東西:語法、每一條語法的處理函數、負責詞法分析的函數
    yacc就會為你生成y.tab.c文件,只要調用這個文件中的yyparse()函數,就可以完成編譯器的
    詞法分析和語法分析的部分了。在分析的過程中,你剛剛指定的每一條語法對應的處理函數也會
    被調用。關于yacc的具體介紹,可以在網上搜搜,很多的。

    例子:
    告訴yacc:語法和對應的處理函數。
    expr : expr '+' expr { $$ = add($1, $3) }
         | expr '*' expr { $$ = mul($1, $3) }
         | expr '-' expr { $$ = sub($1, $3) }
         | NUMBER
          ;
    調用yyparse(),輸入 1 + 2
    add(1, 2) 就會被回調了
    在處理函數中 $$ 代表著處理函數的返回值
    $1 代表著該條語法中的第一個元素(expr)
    $2 代表著該條語法中的第二個元素('+')
    $3 代表著該條語法中的第三個元素(expr)
    至于說這些元素的類型,則會在前面定義。比如 %type<char *> expr 之類。
    具體的還是找篇文章看看吧。

--- parse.y
    觀察Makefile可以發現:
    y.tab.c y.tab.h: parse.y
        $(YACC) -d $(srcdir)/parse.y
    y.tab.c是由parse.y生成的。而parse.y中包含了語法和對應的處理函數,它是語法分析的核心文件。

    首先是一個%union定義
    %union {
        WORD_DESC *word;        /* the word that we read. */
        int number;            /* the number that we read. */
        WORD_LIST *word_list;
        COMMAND *command;
        REDIRECT *redirect;
        ELEMENT element;
        PATTERN_LIST *pattern;
    }

    然后是一系列的token定義:

/* Reserved words.  Members of the first group are only recognized
   in the case that they are preceded by a list_terminator.  Members
   of the second group are for [[...]] commands.  Members of the
   third group are recognized only under special circumstances. */
%token IF THEN ELSE ELIF FI CASE ESAC FOR SELECT WHILE UNTIL DO DONE FUNCTION
%token COND_START COND_END COND_ERROR
%token IN BANG TIME TIMEOPT

/* More general tokens. yylex () knows how to make these. */
%token <word> WORD ASSIGNMENT_WORD
%token <number> NUMBER
%token <word_list> ARITH_CMD ARITH_FOR_EXPRS
%token <command> COND_CMD
%token AND_AND OR_OR GREATER_GREATER LESS_LESS LESS_AND LESS_LESS_LESS
%token GREATER_AND SEMI_SEMI LESS_LESS_MINUS AND_GREATER LESS_GREATER
%token GREATER_BAR

    讀入字符串流,返回token是詞法分析函數的責任。
    以%token定義,表明返回值是int類型
    以%token <word>定義,表明返回值是%union中對應的類型

    詞法分析函數是lex生成的,但這個工程好像把原始的
    .lex文件刪除了。我們只能看到生成后的yylex()函數。
    但有一個表,可以看出token對應的字串內容:

/* Reserved words.  These are only recognized as the first word of a
   command. */
STRING_INT_ALIST word_token_alist[] = {
  { "if", IF },
  { "then", THEN },
  { "else", ELSE },
  { "elif", ELIF },
  { "fi", FI },
  { "case", CASE },
  { "esac", ESAC },
  { "for", FOR },
#if defined (SELECT_COMMAND)
  { "select", SELECT },
#endif
  { "while", WHILE },
  { "until", UNTIL },
  { "do", DO },
  { "done", DONE },
  { "in", IN },
  { "function", FUNCTION },
#if defined (COMMAND_TIMING)
  { "time", TIME },
#endif
  { "{", '{' },
  { "}", '}' },
  { "!", BANG },
#if defined (COND_COMMAND)
  { "[[", COND_START },
  { "]]", COND_END },
#endif
  { (char *)NULL, 0}
};

/* other tokens that can be returned by read_token() */
STRING_INT_ALIST other_token_alist[] = {
  /* Multiple-character tokens with special values */
  { "-p", TIMEOPT },
  { "&&", AND_AND },
  { "||", OR_OR },
  { ">>", GREATER_GREATER },
  { "<<", LESS_LESS },
  { "<&", LESS_AND },
  { ">&", GREATER_AND },
  { ";;", SEMI_SEMI },
  { "<<-", LESS_LESS_MINUS },
  { "<<<", LESS_LESS_LESS },
  { "&>", AND_GREATER },
  { "<>", LESS_GREATER },
  { ">|", GREATER_BAR },
  { "EOF", yacc_EOF },
  /* Tokens whose value is the character itself */
  { ">", '>' },
  { "<", '<' },
  { "-", '-' },
  { "{", '{' },
  { "}", '}' },
  { ";", ';' },
  { "(", '(' },
  { ")", ')' },
  { "|", '|' },
  { "&", '&' },
  { "newline", '\n' },
  { (char *)NULL, 0}
};

/* others not listed here:
    WORD            look at yylval.word
    ASSIGNMENT_WORD        look at yylval.word
    NUMBER            look at yylval.number
    ARITH_CMD        look at yylval.word_list
    ARITH_FOR_EXPRS        look at yylval.word_list
    COND_CMD        look at yylval.command
*/

    這些token在語法中會遇到的。

    接下來是對語法中每一項內容(編譯原理沒學好,不知道這個術語叫什么。。)的定義:

/* The types that the various syntactical units return. */

%type <command> inputunit command pipeline pipeline_command
%type <command> list list0 list1 compound_list simple_list simple_list1
%type <command> simple_command shell_command
%type <command> for_command select_command case_command group_command
%type <command> arith_command
%type <command> cond_command
%type <command> arith_for_command
%type <command> function_def function_body if_command elif_clause subshell
%type <redirect> redirection redirection_list
%type <element> simple_command_element
%type <word_list> word_list pattern
%type <pattern> pattern_list case_clause_sequence case_clause
%type <number> timespec
%type <number> list_terminator

%start inputunit

    從名字上來看,大概能知道是作什么的。
    %start 表示整個語法分析的入口是 inputunit 那一項。
    接著就是語法了,內容就比較多,不直接貼了。
    語法是我比較感興趣的地方,無論看哪本關于bash的書,都不如看代碼來的直接,呵呵。
    我們以后慢慢看。





posted on 2010-07-25 10:19 糯米 閱讀(1305) 評論(0)  編輯 收藏 引用 所屬分類: Misc

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            性欧美video另类hd性玩具| 亚洲电影在线播放| 欧美日韩1区2区3区| 欧美在线网站| 欧美在线免费视屏| 久久精品一区二区三区不卡牛牛| 午夜亚洲福利在线老司机| 亚洲天天影视| 亚洲视屏在线播放| 午夜精品久久久久久久久久久久久| 亚洲经典自拍| 夜夜爽99久久国产综合精品女不卡| 亚洲国产一区二区三区a毛片| 91久久夜色精品国产网站| 一本色道久久88综合日韩精品| 宅男噜噜噜66国产日韩在线观看| 欧美肥婆在线| 久久不见久久见免费视频1| 久久先锋影音| 亚洲国产精品电影在线观看| 亚洲精品综合| 欧美中文字幕久久| 亚洲免费观看视频| 欧美成人dvd在线视频| 欧美日韩播放| 国产精品在线看| 极品尤物久久久av免费看| 亚洲三级网站| 久久精品综合一区| 亚洲精品国精品久久99热一| 亚洲欧美亚洲| 免费黄网站欧美| 国产精品久久久久久久久免费| 激情一区二区| 午夜精彩视频在线观看不卡 | 激情视频一区| 9久草视频在线视频精品| 午夜老司机精品| 欧美激情aⅴ一区二区三区| 亚洲专区一区| 欧美成人中文| 禁断一区二区三区在线| 亚洲欧美日韩系列| 亚洲精品国产精品国自产在线 | 欧美激情小视频| 国产精品一区二区三区久久久 | 久久国产精品亚洲77777| 欧美第一黄网免费网站| 欧美一区二区视频网站| 欧美性做爰毛片| 在线不卡亚洲| 久久久久久网| 亚洲欧美国产毛片在线| 欧美日韩国产成人高清视频| 在线国产欧美| 欧美在线视频a| 一区二区av在线| 欧美精品二区| 99精品国产在热久久婷婷| 欧美激情视频一区二区三区在线播放| 久久高清免费观看| 国产综合在线看| 久久久久www| 欧美在线免费视屏| 极品日韩久久| 欧美大片一区| 欧美激情第3页| 99国产精品99久久久久久| 亚洲经典在线| 欧美美女操人视频| 亚洲人成欧美中文字幕| 欧美在线观看视频在线| 欧美电影在线| 亚洲欧洲精品一区二区三区| 美女精品国产| 亚洲一区二区三区三| 国产精品久久一卡二卡| 午夜精品免费视频| 小辣椒精品导航| 精久久久久久久久久久| 男女视频一区二区| 欧美精品电影在线| 香蕉久久夜色精品| 久久狠狠一本精品综合网| 极品少妇一区二区三区| 亚洲国产一区二区a毛片| 欧美日韩国产在线一区| 午夜精品一区二区三区四区| 欧美专区亚洲专区| 亚洲精品在线电影| 亚洲一区二区免费视频| 国内成人在线| 亚洲欧洲综合| 国产精品一区二区三区乱码 | 欧美一二三区在线观看| 国产午夜一区二区三区| 欧美国产精品中文字幕| 欧美日韩一区二区三区在线观看免 | 亚洲一区二区欧美日韩| 国产精品99久久99久久久二8| 亚洲欧美文学| 小处雏高清一区二区三区| 国产精品久久久久免费a∨| 亚洲精品乱码久久久久久按摩观 | 欧美一区91| 野花国产精品入口| 欧美电影美腿模特1979在线看| 午夜精品999| 国产区在线观看成人精品| 亚洲黄色av| 欧美日韩国产免费| 久久激情五月丁香伊人| 欧美黄色精品| 老色鬼精品视频在线观看播放| 久久精品欧洲| 亚洲宅男天堂在线观看无病毒| 影音先锋日韩有码| 在线视频免费在线观看一区二区| 亚洲二区在线| 欧美亚洲免费电影| 亚洲免费在线视频| 欧美美女福利视频| 欧美成人一区二免费视频软件| 欧美色另类天堂2015| 欧美激情精品久久久久| 一区在线播放视频| 亚洲在线日韩| 亚洲欧美日韩精品久久久久| 欧美噜噜久久久xxx| 亚洲国产欧美另类丝袜| 亚洲国产福利在线| 老司机aⅴ在线精品导航| 久久激情视频久久| 一本色道久久加勒比88综合 | 亚洲精品亚洲人成人网| 久久性天堂网| 欧美成人免费网站| 亚洲成人在线视频播放| 久久亚洲综合网| 欧美mv日韩mv国产网站app| 伊人成综合网伊人222| 久久久蜜桃一区二区人| 欧美成人综合| 日韩天堂av| 欧美日韩亚洲一区二区| 中日韩美女免费视频网址在线观看 | 欧美日本免费一区二区三区| 亚洲日本免费| 99热在这里有精品免费| 欧美日韩国产麻豆| 亚洲一区二区三区视频播放| 久久精品道一区二区三区| 黄色工厂这里只有精品| 美女露胸一区二区三区| 亚洲国产精品一区二区尤物区| 日韩天天综合| 国产精品久久久久久久免费软件| 亚洲一区二区精品| 久久婷婷久久| 亚洲精品资源| 国产精品你懂得| 久久精品国产一区二区三区| 欧美国产高清| 亚洲欧美日韩区| 亚洲第一精品夜夜躁人人躁 | 亚洲人成人77777线观看| 午夜在线a亚洲v天堂网2018| 亚洲第一在线综合网站| 日韩视频三区| 国产精品日韩一区二区| 久久久免费精品| 亚洲人体大胆视频| 亚洲自拍偷拍网址| 精品成人国产| 欧美性大战久久久久久久蜜臀| 午夜视频一区| 国产精品一区免费在线观看| 免费一区视频| 亚洲一级片在线看| 国产手机视频一区二区| 欧美精品1区| 久久国产精品一区二区三区四区| 亚洲激情成人| 久久免费观看视频| 亚洲一区精彩视频| 亚洲国产日韩在线| 国产日韩一区二区三区| 欧美天堂亚洲电影院在线播放| 久久亚洲综合色一区二区三区| 亚洲午夜电影在线观看| 亚洲国产经典视频| 久久综合久久综合九色| 欧美亚洲一区二区三区| 中文在线一区| 亚洲人成免费| 影音先锋日韩资源| 国产亚洲一级高清| 国产精品女人毛片| 欧美图区在线视频| 欧美激情第4页|