Re: [问题] Extra option与Illegal option的差别

楼主: ypf791 (路人1号)   2012-11-17 22:41:41
为了行文方便定义一下用语
名词:
token: 命令名称后面跟的东西 用空格切开后的字串集
flag: 形如 -* 的 token
argument: 没有 flag 跟在前面的 token
option: 某些 flag 要求后面要紧跟着一个引数 令其为 option of -(flag name)
可能会图方便只写 option
形容词:
optional: 被方括号括起来的东西
essential: 被角括号括起来的东西
==============================================================================
以下要用 MTDelete (mtd) 举例 所以先分析一下它的 tokens:
Argument: 没有
-Index : essential flag 需要 option
-Random : essential flag 需要 option
-Array : optional flag 不需要 option
特殊规定: -i 和 -r 为二选一
==============================================================================
我的认知大概是这样:
Illegal:
1.如果一个 argument 或 flag 不在命令可能接受的范围内就是 Illegal
例如
mtd -a -i 2 8
经过解析的结果
-a 是 没有 option 的 flag
-i 是 有 option=2 的 flag
8 是 argument
因为 mtd 没有 argument
所以 8 是 Illegal
2.如果一个 argument 或 option (of flag) 的型态错误
例如
mtd -a -i k
因为 k 不是数字 违反 option of -i 的规定 所以是 Illegal
Extra:
1.如果一个 argument 或 flag 可能被命令接受
但数量上超过了命令的需求 则是 Extra
例如
mtd -a -i 2 -a
则 -a 就是可以被接受但是多打了一个 所以第二个 -a 是 Extra
Note: 如果是像 mtd -i 2 -r 这样 因为是二选一 所以后面那个就会视为多出来
Missing:
1.如果输入的命令经解析认为某个 flag 没有 option 但它其实需要 option 的话
就会判定为 Missing
例如
mtd -a -i
-i 需要 option 可是没给这样
2.目前来讲 好像只有在最后一个 token 是需要 option 的 flag 的时候
才会变成 Missing
==============================================================================
其实这些并不是最麻烦的
最讨厌的是复合情况 或者说多重解释
像是
mtd -i 8 -r -a
一开始到 -i 8 -r 都还好
可是 -a 可以视为 flag (Missing)
也可以把 -a 视为 -r 的 option (Illegal)
也可以先说 -r 撞了 -i (Extra)
到底优先度是怎样就很难解释 (其实是原 PO 根本没搞懂)
除了慢慢玩 ref 之外好像也没什么好方法...
作者: XDucka (Duck)   2011-01-17 23:04:00
我也是慢慢try ref... 蛮花时间的XD
作者: ric2k1 (Ric)   2011-01-17 23:06:00
谢谢精辟的解析,不过关于错误讯息只要不要把错的 parse 成对的,对的 parse 成错的,就 OK. 错误讯息有出入没有关系毕竟 parse 的顺序不同都会造成讯息的不同,大家可以不用花时间在调成跟 ref 一样 (每年好像都会有这个问题)
楼主: ypf791 (路人1号)   2011-01-17 23:14:00
但就是会想调到全都一样啊....
作者: mikechen25 (mikechen25)   2011-01-18 00:07:00
没想到今天调了好久还是少调到一个东西...>~<
作者: Phantasnix (凰响)   2011-01-18 00:32:00
推 继续慢慢玩ref
楼主: ypf791 (路人1号)   2011-01-18 09:30:00
刚刚跑了一下 发现mtn和mtd用的逻辑是不一样的(倒)
作者: pochih   2011-01-18 10:44:00
感谢ypf大与老师的解说
作者: david942j (文旋)   2011-01-18 16:39:00
mtn -a 1 a 这样是extra mtn -a 1 这样是missing 怎么都觉得不太合理= ="这种错误讯息会让使用者陷入无穷循环吧
作者: ric2k1 (Ric)   2011-01-18 17:11:00
建议已经写完了的人再来追究这个错误讯息吧! 不算分的 XD
作者: caspercat (caspercat)   2011-01-21 04:36:00
不算分推!!

Links booklink

Contact Us: admin [ a t ] ucptt.com