Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
30e565e5
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
410
Star
4707
Fork
583
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
30e565e5
编写于
12月 01, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(traced_module): fix error message
GitOrigin-RevId: 3046225e30757d26d1e3423e2e57f46db725f958
上级
de8ffe0c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
10 deletion
+23
-10
imperative/python/megengine/traced_module/utils.py
imperative/python/megengine/traced_module/utils.py
+23
-10
未找到文件。
imperative/python/megengine/traced_module/utils.py
浏览文件 @
30e565e5
...
...
@@ -6,6 +6,7 @@
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
import
copy
import
contextlib
import
inspect
from
collections.abc
import
MutableMapping
,
MutableSequence
from
inspect
import
FullArgSpec
...
...
@@ -65,8 +66,12 @@ def _convert_kwargs_to_args(
arg_specs
=
(
inspect
.
getfullargspec
(
argspecs
)
if
isinstance
(
argspecs
,
Callable
)
else
argspecs
)
func_name
=
argspecs
.
__qualname__
if
isinstance
(
argspecs
,
Callable
)
else
"function"
assert
isinstance
(
arg_specs
,
FullArgSpec
)
arg_specs_args
=
arg_specs
.
args
arg_specs_defaults
=
arg_specs
.
defaults
if
arg_specs
.
defaults
else
[]
arg_specs_kwonlyargs
=
arg_specs
.
kwonlyargs
arg_specs_kwonlydefaults
=
arg_specs
.
kwonlydefaults
if
arg_specs
.
kwonlydefaults
else
dict
()
if
is_bounded
:
arg_specs_args
=
arg_specs
.
args
[
1
:]
new_args
=
[]
...
...
@@ -76,31 +81,39 @@ def _convert_kwargs_to_args(
repeated_arg_name
=
set
(
arg_specs_args
[
0
:
len
(
new_args
)])
&
set
(
kwargs
.
keys
())
raise
TypeError
(
"{} got multiple values for argument {}"
.
format
(
func
.
__qualname__
,
", "
.
join
(
repeated_arg_name
)
func
_name
,
", "
.
join
(
repeated_arg_name
)
)
)
if
len
(
new_args
)
<
len
(
arg_specs
.
args
):
if
len
(
new_args
)
<
len
(
arg_specs
_
args
):
for
ind
in
range
(
len
(
new_args
),
len
(
arg_specs_args
)):
arg_name
=
arg_specs_args
[
ind
]
if
arg_name
in
kwargs
:
new_args
.
append
(
kwargs
[
arg_name
])
else
:
index
=
ind
-
len
(
arg_specs_args
)
+
len
(
arg_specs
.
defaults
)
assert
index
<
len
(
arg_specs
.
defaults
)
and
index
>=
0
new_args
.
append
(
arg_specs
.
defaults
[
index
])
index
=
ind
-
len
(
arg_specs_args
)
+
len
(
arg_specs_defaults
)
if
index
>=
len
(
arg_specs_defaults
)
or
index
<
0
:
raise
TypeError
(
"{} missing required positional arguments: {}"
.
format
(
func_name
,
arg_name
)
)
new_args
.
append
(
arg_specs_defaults
[
index
])
for
kwarg_name
in
arg_specs
.
kwonlyargs
:
for
kwarg_name
in
arg_specs
_
kwonlyargs
:
if
kwarg_name
in
kwargs
:
new_kwargs
[
kwarg_name
]
=
kwargs
[
kwarg_name
]
else
:
assert
kwarg_name
in
arg_specs
.
kwonlydefaults
new_kwargs
[
kwarg_name
]
=
arg_specs
.
kwonlydefaults
[
kwarg_name
]
if
kwarg_name
not
in
arg_specs_kwonlydefaults
:
raise
TypeError
(
"{} missing required keyword-only argument: {}"
.
format
(
func_name
,
kwarg_name
))
new_kwargs
[
kwarg_name
]
=
arg_specs_kwonlydefaults
[
kwarg_name
]
for
k
,
v
in
kwargs
.
items
():
if
k
not
in
arg_specs
.
args
and
k
not
in
arg_specs
.
kwonlyargs
:
if
k
not
in
arg_specs
_args
and
k
not
in
arg_specs_
kwonlyargs
:
if
arg_specs
.
varkw
is
None
:
raise
TypeError
(
"{} got an unexpected keyword argument {}"
.
format
(
func
.
__qualname__
,
k
func_name
,
k
)
)
new_kwargs
[
k
]
=
v
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录