Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
vnotepad
Exa
提交
c41005a1
E
Exa
项目概览
vnotepad
/
Exa
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
E
Exa
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c41005a1
编写于
7月 12, 2017
作者:
B
Benjamin Sago
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Change a bunch of variable names
上级
9bbe2d98
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
13 addition
and
14 deletion
+13
-14
src/options/parser.rs
src/options/parser.rs
+13
-14
未找到文件。
src/options/parser.rs
浏览文件 @
c41005a1
...
...
@@ -81,7 +81,6 @@ fn parse<'a>(args: Args, inputs: &'a [OsString]) -> Result<Matches<'a>, ParseErr
};
let
mut
iter
=
inputs
.iter
();
while
let
Some
(
arg
)
=
iter
.next
()
{
let
bytes
=
arg
.as_bytes
();
...
...
@@ -92,20 +91,20 @@ fn parse<'a>(args: Args, inputs: &'a [OsString]) -> Result<Matches<'a>, ParseErr
parsing
=
false
;
}
else
if
bytes
.starts_with
(
b
"--"
)
{
let
long_arg
=
OsStr
::
from_bytes
(
&
bytes
[
2
..
]);
let
long_arg
_name
=
OsStr
::
from_bytes
(
&
bytes
[
2
..
]);
if
let
Some
((
before
,
after
))
=
split_on_equals
(
long_arg
)
{
let
&
Arg
{
short
:
_
,
long
:
long_arg_name
,
takes_value
}
=
args
.lookup_long
(
before
)
?
;
let
flag
=
Flag
::
Long
(
long_arg_name
);
match
takes_value
{
if
let
Some
((
before
,
after
))
=
split_on_equals
(
long_arg
_name
)
{
let
arg
=
args
.lookup_long
(
before
)
?
;
let
flag
=
Flag
::
Long
(
arg
.long
);
match
arg
.
takes_value
{
Necessary
=>
results
.flags
.push
((
flag
,
Some
(
after
))),
Forbidden
=>
return
Err
(
ParseError
::
ForbiddenValue
{
flag
})
}
}
else
{
let
&
Arg
{
short
:
_
,
long
:
long_arg_name
,
takes_value
}
=
args
.lookup_long
(
long_arg
)
?
;
let
flag
=
Flag
::
Long
(
long_arg_name
);
match
takes_value
{
let
arg
=
args
.lookup_long
(
long_arg_name
)
?
;
let
flag
=
Flag
::
Long
(
arg
.long
);
match
arg
.
takes_value
{
Forbidden
=>
results
.flags
.push
((
flag
,
None
)),
Necessary
=>
{
if
let
Some
(
next_arg
)
=
iter
.next
()
{
...
...
@@ -122,9 +121,9 @@ fn parse<'a>(args: Args, inputs: &'a [OsString]) -> Result<Matches<'a>, ParseErr
let
short_arg
=
OsStr
::
from_bytes
(
&
bytes
[
1
..
]);
if
let
Some
((
before
,
after
))
=
split_on_equals
(
short_arg
)
{
// TODO: remember to deal with the other bytes!
let
&
Arg
{
short
,
long
,
takes_value
}
=
args
.lookup_short
(
*
before
.as_bytes
()
.last
()
.unwrap
())
?
;
let
flag
=
Flag
::
Short
(
short
.unwrap
());
match
takes_value
{
let
arg
=
args
.lookup_short
(
*
before
.as_bytes
()
.last
()
.unwrap
())
?
;
let
flag
=
Flag
::
Short
(
arg
.
short
.unwrap
());
match
arg
.
takes_value
{
Necessary
=>
results
.flags
.push
((
flag
,
Some
(
after
))),
Forbidden
=>
return
Err
(
ParseError
::
ForbiddenValue
{
flag
})
}
...
...
@@ -133,9 +132,9 @@ fn parse<'a>(args: Args, inputs: &'a [OsString]) -> Result<Matches<'a>, ParseErr
for
byte
in
&
bytes
[
1
..
]
{
// TODO: gotta check that these don't take arguments
// like -c4
let
&
Arg
{
short
,
long
,
takes_value
}
=
args
.lookup_short
(
*
byte
)
?
;
let
arg
=
args
.lookup_short
(
*
byte
)
?
;
let
flag
=
Flag
::
Short
(
*
byte
);
match
takes_value
{
match
arg
.
takes_value
{
Forbidden
=>
results
.flags
.push
((
flag
,
None
)),
Necessary
=>
{
if
let
Some
(
next_arg
)
=
iter
.next
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录