Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
4df2654f
R
Rust
项目概览
int
/
Rust
大约 1 年 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rust
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4df2654f
编写于
6月 25, 2012
作者:
P
Paul Stansifer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make it possible to make built-in tt syntax extensions
上级
4f104954
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
53 addition
and
6 deletion
+53
-6
src/libsyntax/ext/base.rs
src/libsyntax/ext/base.rs
+7
-3
src/libsyntax/ext/expand.rs
src/libsyntax/ext/expand.rs
+35
-1
src/libsyntax/parse/parser.rs
src/libsyntax/parse/parser.rs
+11
-2
未找到文件。
src/libsyntax/ext/base.rs
浏览文件 @
4df2654f
...
...
@@ -6,19 +6,23 @@
type
syntax_expander_
=
fn
@
(
ext_ctxt
,
span
,
ast
::
mac_arg
,
ast
::
mac_body
)
->
@
ast
::
expr
;
type
syntax_expander
=
{
expander
:
syntax_expander_
,
span
:
option
<
span
>
};
type
syntax_expander
=
{
expander
:
syntax_expander_
,
span
:
option
<
span
>
};
type
macro_def
=
{
ident
:
ast
::
ident
,
ext
:
syntax_extension
};
type
macro_definer
=
fn
@
(
ext_ctxt
,
span
,
ast
::
mac_arg
,
ast
::
mac_body
)
->
macro_def
;
type
item_decorator
=
fn
@
(
ext_ctxt
,
span
,
ast
::
meta_item
,
[
@
ast
::
item
])
->
[
@
ast
::
item
];
type
syntax_expander_tt
=
{
expander
:
syntax_expander_tt_
,
span
:
option
<
span
>
};
type
syntax_expander_tt_
=
fn
@
(
ext_ctxt
,
span
,
ast
::
token_tree
)
->
@
ast
::
expr
;
enum
syntax_extension
{
normal
(
syntax_expander
),
macro_defining
(
macro_definer
),
item_decorator
(
item_decorator
),
normal_tt
(
syntax_expander_tt
)
}
// A temporary hard-coded map of methods for expanding syntax extension
...
...
src/libsyntax/ext/expand.rs
浏览文件 @
4df2654f
...
...
@@ -47,6 +47,39 @@ fn expand_expr(exts: hashmap<str, syntax_extension>, cx: ext_ctxt,
exts
.insert
(
*
named_extension
.ident
,
named_extension
.ext
);
(
ast
::
expr_rec
([],
none
),
s
)
}
some
(
normal_tt
(
_
))
{
cx
.span_fatal
(
pth
.span
,
#
fmt
[
"this tt-style macro should be
\
invoked '%s!{...}'"
,
*
extname
])
}
}
}
mac_invoc_tt
(
pth
,
tt
)
{
assert
(
vec
::
len
(
pth
.idents
)
>
0u
);
let
extname
=
pth
.idents
[
0
];
alt
exts
.find
(
*
extname
)
{
none
{
cx
.span_fatal
(
pth
.span
,
#
fmt
[
"macro undefined: '%s'"
,
*
extname
])
}
some
(
normal_tt
({
expander
:
exp
,
span
:
exp_sp
}))
{
let
expanded
=
exp
(
cx
,
pth
.span
,
tt
);
cx
.bt_push
(
expanded_from
({
call_site
:
s
,
callie
:
{
name
:
*
extname
,
span
:
exp_sp
}}));
//keep going, outside-in
let
fully_expanded
=
fld
.fold_expr
(
expanded
)
.node
;
cx
.bt_pop
();
(
fully_expanded
,
s
)
}
_
{
cx
.span_fatal
(
pth
.span
,
#
fmt
[
"'%s' is not a tt-style macro"
,
*
extname
])
}
}
}
_
{
cx
.span_bug
(
mac
.span
,
"naked syntactic bit"
)
}
...
...
@@ -75,7 +108,8 @@ fn expand_mod_items(exts: hashmap<str, syntax_extension>, cx: ext_ctxt,
ast
::
meta_list
(
n
,
_
)
{
n
}
};
alt
exts
.find
(
*
mname
)
{
none
|
some
(
normal
(
_
))
|
some
(
macro_defining
(
_
))
{
none
|
some
(
normal
(
_
))
|
some
(
macro_defining
(
_
))
|
some
(
normal_tt
(
_
))
{
items
}
...
...
src/libsyntax/parse/parser.rs
浏览文件 @
4df2654f
...
...
@@ -883,8 +883,17 @@ fn parse_bottom_expr() -> pexpr {
is_ident
(
self
.token
)
&&
!
self
.is_keyword
(
"true"
)
&&
!
self
.is_keyword
(
"false"
)
{
let
pth
=
self
.parse_path_with_tps
(
true
);
hi
=
pth
.span.hi
;
ex
=
expr_path
(
pth
);
/* `!`, as an operator, is prefix, so we know this isn't that */
if
self
.token
==
token
::
NOT
{
self
.bump
();
let
m_body
=
self
.parse_token_tree
();
let
hi
=
self
.span.hi
;
ret
pexpr
(
self
.mk_mac_expr
(
lo
,
hi
,
mac_invoc_tt
(
pth
,
m_body
)));
}
else
{
hi
=
pth
.span.hi
;
ex
=
expr_path
(
pth
);
}
}
else
{
let
lit
=
self
.parse_lit
();
hi
=
lit
.span.hi
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录