作者ypf791 (路人1号)
看板EE_DSnP
标题Re: [问题] Extra option与Illegal option的差别
时间Sat Nov 17 22:41:41 2012
为了行文方便定义一下用语
名词:
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 之外好像也没什麽好方法...
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 111.248.9.157
※ 编辑: ypf791 来自: 111.248.9.157 (11/17 22:45)
1F:推 XDucka:我也是慢慢try ref... 蛮花时间的XD 11/17 23:04
2F:推 ric2k1:谢谢精辟的解析,不过关於错误讯息只要不要把错的 parse 成 11/17 23:06
3F:→ ric2k1:对的,对的 parse 成错的,就 OK. 错误讯息有出入没有关系 11/17 23:07
4F:→ ric2k1:毕竟 parse 的顺序不同都会造成讯息的不同,大家可以不用 11/17 23:08
5F:→ ric2k1:花时间在调成跟 ref 一样 (每年好像都会有这个问题) 11/17 23:08
6F:→ ypf791:但就是会想调到全都一样啊.... 11/17 23:14
7F:推 mikechen25:没想到今天调了好久还是少调到一个东西...>~< 11/18 00:07
8F:推 Phantasnix:推 继续慢慢玩ref 11/18 00:32
9F:→ ypf791:刚刚跑了一下 发现mtn和mtd用的逻辑是不一样的(倒) 11/18 09:30
10F:推 pochih:感谢ypf大与老师的解说 11/18 10:44
11F:推 david942j:mtn -a 1 a 这样是extra mtn -a 1 这样是missing 怎麽 11/18 16:39
12F:→ david942j:都觉得不太合理= =" 11/18 16:39
13F:→ david942j:这种错误讯息会让使用者陷入无穷回圈吧 11/18 16:40
14F:推 ric2k1:建议已经写完了的人再来追究这个错误讯息吧! 不算分的 XD 11/18 17:11
15F:推 caspercat:不算分推!! 11/21 04:36