为了行文方便定义一下用语
名词:
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 之外好像也没什么好方法...