skandhas 发表于 2013-1-26 15:55:10

Ruby1.9的隐藏参数"--dump"

前几天,我的同事老高在看Ruby1.9.2源码的时候,发现Ruby1.9有一个隐藏参数:"--dump"(注意是两个减号). 下面具体说说这个参数:
 
1. --dump 参数
--dump 可以打印出ruby及指定脚本的相关信息,具体如下:
parsetree, parsetree_with_comment, insns]
其中有几项的内容我们已经熟悉,例如:version,copyright,usage. 不过这次我们感兴趣的是parsetree和insns的内容。
 
parsetree -- 打印指定脚本的Parse Tree
insns        -- 打印指定脚本的RubyVM(YARV)指令
 
2. 具体用法举例
假设有一个已经写好的脚本1.rb,存放在C盘。我们可以如下使用"--dump"参数:
ruby --dump parsetree c:\1.rb
 
3.测试结果
测试脚本:
class Adef hello    puts 'Hello'endendA.new.hello打印RubyVM指令:ruby --dump insns c:\1.rb
输出
== disasm: <RubyVM::InstructionSequence:<main>@c:/1.rb>=================0000 trace            1                                             (   1)0002 putspecialobject 30004 putnil0005 defineclass      :A, <class:A>, 00009 pop0010 trace            1                                             (   7)0012 getinlinecache   19, <ic:0>0015 getconstant      :A0017 setinlinecache   <ic:0>0019 send             :new, 0, nil, 0, <ic:1>0025 send             :hello, 0, nil, 0, <ic:2>0031 leave== disasm: <RubyVM::InstructionSequence:<class:A>@c:/1.rb>==============0000 trace            2                                             (   1)0002 trace            1                                             (   2)0004 putspecialobject 10006 putspecialobject 20008 putobject      :hello0010 putiseq          hello0012 send             :"core#define_method", 3, nil, 0, <ic:0>0018 trace            4                                             (   5)0020 leave                                                            (   2)== disasm: <RubyVM::InstructionSequence:hello@c:/1.rb>==================0000 trace            8                                             (   2)0002 trace            1                                             (   3)0004 putnil0005 putstring      "Hello"0007 send             :puts, 1, nil, 8, <ic:0>0013 trace            16                                              (   4)0015 leave                                                            (   3)  
打印ParseTree:ruby --dump parsetree c:\1.rb
输出:
############################################################# Do NOT use this node dump for any purpose other than#### debug and research.Compatibility is not guaranteed. ############################################################## @ NODE_SCOPE (line: 7)# +- nd_tbl: (empty)# +- nd_args:# |   (null node)# +- nd_body:#   @ NODE_BLOCK (line: 1)#   +- nd_head:#   |   @ NODE_CLASS (line: 1)#   |   +- nd_cpath:#   |   |   @ NODE_COLON2 (line: 1)#   |   |   +- nd_mid: :A#   |   |   +- nd_head:#   |   |       (null node)#   |   +- nd_super:#   |   |   (null node)#   |   +- nd_body:#   |       @ NODE_SCOPE (line: 5)#   |       +- nd_tbl: (empty)#   |       +- nd_args:#   |       |   (null node)#   |       +- nd_body:#   |         @ NODE_DEFN (line: 2)#   |         +- nd_mid: :hello#   |         +- nd_defn:#   |               @ NODE_SCOPE (line: 4)#   |               +- nd_tbl: (empty)#   |               +- nd_args:#   |               |   @ NODE_ARGS (line: 2)#   |               |   +- nd_frml: 0#   |               |   +- nd_next:#   |               |   |   @ NODE_ARGS_AUX (line: 2)#   |               |   |   +- nd_rest: (null)#   |               |   |   +- nd_body: (null)#   |               |   |   +- nd_next:#   |               |   |       (null node)#   |               |   +- nd_opt:#   |               |       (null node)#   |               +- nd_body:#   |                   @ NODE_FCALL (line: 3)#   |                   +- nd_mid: :puts#   |                   +- nd_args:#   |                     @ NODE_ARRAY (line: 3)#   |                     +- nd_alen: 1#   |                     +- nd_head:#   |                     |   @ NODE_STR (line: 3)#   |                     |   +- nd_lit: "Hello"#   |                     +- nd_next:#   |                           (null node)#   +- nd_next:#         @ NODE_BLOCK (line: 7)#         +- nd_head:#         |   @ NODE_CALL (line: 7)#         |   +- nd_mid: :hello#         |   +- nd_recv:#         |   |   @ NODE_CALL (line: 7)#         |   |   +- nd_mid: :new#         |   |   +- nd_recv:#         |   |   |   @ NODE_CONST (line: 7)#         |   |   |   +- nd_vid: :A#         |   |   +- nd_args:#         |   |       (null node)#         |   +- nd_args:#         |       (null node)#         +- nd_next:#             (null node)
页: [1]
查看完整版本: Ruby1.9的隐藏参数"--dump"