作者godfat (godfat 真常)
看板Ruby
标题Re: [闲聊] 是否有 Ruby 语法的检查器?
时间Sat Nov 22 14:05:53 2008
我回文好了... 三行实在讲不了什麽 @@"
※ 引述《shelary (喵小咩)》之铭言:
: 标题: [闲聊] 是否有 Ruby 语法的检查器?
: 时间: Sat Nov 22 13:41:08 2008
: 不知道有没有什麽套件是可以检查 Ruby 语法的??
: 例如变数名称打错字, 实际执行时会出现 找不到这个变数(=nil)
: 但如果可以事先检查, 就可以减少很多除错时浪费的时间了.
: --
:
※ 发信站: 批踢踢实业坊(ptt.cc)
: ◆ From: 59.126.45.78
: 推 godfat:option -c 在 gcc 意思是 compile only, ruby 是 syntax 11/22 13
: → godfat:check. 不过如果是变数打错字,这不属於 syntax error, 11/22 13
: → godfat:恐怕还是必须等到执行时才会知道喔,这是没办法的 11/22 13
(不好意思 gcc option 说错了,实际上是:
-S Compile only; do not assemble or link
-c Compile and assemble, but do not link
)
如推文所述,ruby -c file.rb 就是只进行 syntax check.
不过像是变数打错,如把 params 打成 parama, 这不属於 syntax error,
基本上,这是符合 syntax 的。systax 说的是 term 与 term 之间的关系,
例如:
a = b
a 是合法的 variable name, b 也是合法的 variable name,
所以这句话会翻译成把 b 这个变数的值 assign 给 a, 整句话是合法的。
但是实际上执行时,会发生:
NameError: undefined local variable or method `b' for main:Object
这个不属於 syntax error, 如:
SyntaxError.ancestors
=> [SyntaxError, ScriptError, Exception, Object, Kernel]
NameError.ancestors
=> [NameError, StandardError, Exception, Object, Kernel]
前者是静态的,是 compile time 决定的。你的程式 lexical 结构,
不会因为 runtime 而改变,所以是可以进行 syntax check.
但是後者 NameError 是 runtime 才能决定,如果你在 a = b 之前
就先写了 b = 1; 则 a = b 并没有错。意思就是,compile time 无法
决定哪个 variable 是否存在,因为 ruby 的变数是不用宣告的。
反之在 static typing 的语言,如 C/C++/Java/C# 等等,
因为变数需要宣告,所以 compile 时就能决定。但其实这也不属於
syntax error, 而是 semantics 上的错误,例如 type error:
TypeError.ancestors
=> [TypeError, StandardError, Exception, Object, Kernel]
因为变数在 compile time 不存在,则无法进行 type check,
所以会在 compile time 就有错误。
如果你说,那为什麽不能在跑 a = b 时检查 b 是否存在?
其实在 ruby 里,那就完全等同於执行一次了。所以这种检查 = 正式执行。
你需要把所有的 runtime dependency 都读进记忆体,
这跟完全跑一次的意思其实是一样的...
所以 ruby 才会有一说是,compile time, link time, runtime 是没有区分的。
就像你跑 attr_reader, 这种 metaprogramming 的东西,又是在 runtime 进入
compile time, 会在这几个阶段里面不断转换...
而如果是真正的 syntax error, 那光在 require 进来时,就会出错了。
所以实际上跑 -c 的意义并没有说很大... 要求 runtime 弹性,
等於牺牲 compile time 时所获得的资讯。所以这种检查是没办法做的。
事实上这也是在说明一件事,static typing 可以讨论的事情是比
dynamic typing 要来得多很多 :s
--
#!/usr/bin/env ruby [露比] /Programming (Kn|N)ight/ 看板《Ruby》
# if a
dog nailed
extra legs that
http://webptt.com/cn.aspx?n=bbs/Ruby/index.html
#
walks like an octopus, and Welcome ~
Ruby@ptt~
#
talks like an octopus, then
◢█◣ http://www.ruby-lang.org/
# we are happy to treat it as
█ http://www.ruby-doc.org/
# if it were
an octopus.
◥ ◤ http://www.rubyforge.org/
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 220.135.28.18
1F:→ poga:所以我觉得良好的IDE辅助很重要阿... 11/22 14:14
2F:→ poga:NetBean里头同名变数会标色,看到打完名称没标色就知道有问题 11/22 14:15
3F:→ godfat:之前有用了一下 Aptana, 还是嫌慢... orz NetBean 快吗? 11/22 14:27
4F:→ poga:6.5纯Ruby版的速度我是能接受了,起码比Eclipse快上好几倍... 11/22 14:37
5F:推 shelary:另外就是如果中间少打了 END ..常常会找不到是那里少打了 11/22 15:32
6F:→ shelary:执行时出错的讯息只会说.rb的最後一行少了END @_@" 11/22 15:33
7F:→ shelary:但是完全没办法帮助我去找到到底是那里少打了 END 11/22 15:34
8F:推 poga:请善用会自己补do-end的各种工具 囧 11/22 15:36
9F:→ poga:没有工具也要习惯自己检查括号之类的才对... 11/22 15:37