Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
scie
提交
afc1b4e8
S
scie
项目概览
Phodal
/
scie
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
scie
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
afc1b4e8
编写于
8月 25, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Revert "refactor: try to remove helper clone"
This reverts commit
9fdc1bc2
.
上级
9fdc1bc2
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
29 addition
and
34 deletion
+29
-34
scie-grammar/src/grammar/grammar/mod.rs
scie-grammar/src/grammar/grammar/mod.rs
+1
-2
scie-grammar/src/rule.rs
scie-grammar/src/rule.rs
+28
-32
未找到文件。
scie-grammar/src/grammar/grammar/mod.rs
浏览文件 @
afc1b4e8
...
...
@@ -109,12 +109,11 @@ impl Grammar {
prev_state
:
Option
<
StackElement
>
,
emit_binary_tokens
:
bool
,
)
{
let
mut
rule_factory
=
RuleFactory
::
new
(
self
);
if
self
.root_id
==
-
1
{
let
repository
=
self
.grammar.repository
.clone
()
.unwrap
();
let
based
=
repository
.clone
()
.map.base_s
.unwrap
();
self
.root_id
=
rule_factory
.get_compiled_rule_id
(
based
.clone
()
,
repository
.clone
());
RuleFactory
::
get_compiled_rule_id
(
based
.clone
(),
self
,
repository
.clone
());
}
let
mut
is_first_line
:
bool
=
false
;
...
...
scie-grammar/src/rule.rs
浏览文件 @
afc1b4e8
...
...
@@ -15,20 +15,13 @@ fn remove_first(s: &str) -> &str {
last
}
pub
struct
RuleFactory
<
'a
>
{
helper
:
&
'a
mut
Grammar
}
pub
struct
RuleFactory
{}
impl
<
'a
>
RuleFactory
<
'a
>
{
pub
fn
new
(
helper
:
&
mut
Grammar
)
->
RuleFactory
{
RuleFactory
{
helper
}
}
impl
RuleFactory
{
// todo: add more rule builder
pub
fn
compile_captures
(
&
mut
self
,
fn
compile_captures
(
captures
:
Option
<
Box
<
IRawCaptures
>>
,
helper
:
&
mut
Grammar
,
repository
:
IRawRepository
,
)
->
Vec
<
CaptureRule
>
{
let
mut
r
=
vec!
[];
...
...
@@ -58,7 +51,7 @@ impl<'a> RuleFactory<'a> {
let
desc
=
captures
.clone
()
.unwrap
()
.map.capture_map
[
&
id_str
]
.clone
();
if
let
Some
(
rule
)
=
options_patterns
{
retokenizeCapturedWithRuleId
=
self
.get_compiled_rule_id
(
desc
,
repository
.clone
());
RuleFactory
::
get_compiled_rule_id
(
desc
,
helper
,
repository
.clone
());
}
// r[numericCaptureId] = RuleFactory::create_capture_rule(helper, desc.location, desc.name, desc.content_name, retokenizeCapturedWithRuleId);
}
...
...
@@ -68,8 +61,8 @@ impl<'a> RuleFactory<'a> {
}
pub
fn
compile_patterns
(
&
mut
self
,
origin_patterns
:
Option
<
Vec
<
IRawRule
>>
,
helper
:
Box
<&
mut
Grammar
>
,
repository
:
IRawRepository
,
)
->
ICompilePatternsResult
{
let
mut
r
:
Vec
<
i32
>
=
vec!
[];
...
...
@@ -84,7 +77,7 @@ impl<'a> RuleFactory<'a> {
let
first
=
remove_first
(
include_s
.as_str
());
let
local_included_rule
=
map
.get
(
first
);
if
let
Some
(
rule
)
=
local_included_rule
{
pattern_id
=
self
.get_compiled_rule_id
(
*
rule
.clone
(),
repository
.clone
());
pattern_id
=
RuleFactory
::
get_compiled_rule_id
(
*
rule
.clone
(),
&
mut
(
*
helper
)
.clone
(),
repository
.clone
());
}
else
{
println!
(
"CANNOT find rule for scopeName: {:?}"
,
pattern
.clone
()
.include
);
}
...
...
@@ -92,7 +85,7 @@ impl<'a> RuleFactory<'a> {
let
option
=
pattern
.include
.unwrap
();
let
local_included_rule
=
map
.get
(
option
.as_str
());
if
let
Some
(
rule
)
=
local_included_rule
{
pattern_id
=
self
.get_compiled_rule_id
(
*
(
rule
)
.clone
(),
repository
.clone
());
pattern_id
=
RuleFactory
::
get_compiled_rule_id
(
*
(
rule
)
.clone
(),
&
mut
(
*
helper
)
.clone
(),
repository
.clone
());
}
}
else
{
println!
(
"todo: {:?}"
,
pattern
.include
);
...
...
@@ -112,11 +105,11 @@ impl<'a> RuleFactory<'a> {
}
}
}
else
{
pattern_id
=
self
.get_compiled_rule_id
(
pattern
,
repository
.clone
());
pattern_id
=
RuleFactory
::
get_compiled_rule_id
(
pattern
,
&
mut
(
*
helper
)
.clone
()
,
repository
.clone
());
}
if
pattern_id
!=
-
1
{
let
rule
=
self
.
helper
.get_rule
(
pattern_id
);
let
rule
=
helper
.get_rule
(
pattern_id
);
println!
(
"{:?}"
,
rule
)
}
}
...
...
@@ -131,17 +124,18 @@ impl<'a> RuleFactory<'a> {
}
pub
fn
get_compiled_rule_id
(
&
mut
self
,
mut
desc
:
IRawRule
,
helper
:
&
mut
Grammar
,
repository
:
IRawRepository
,
)
->
i32
{
if
let
None
=
desc
.id
{
let
id
=
self
.
helper
.register_id
();
let
id
=
helper
.register_id
();
desc
.id
=
Some
(
id
.clone
());
if
let
Some
(
match_s
)
=
desc
.match_s
{
let
rule_factory
=
self
.
compile_captures
(
let
rule_factory
=
RuleFactory
::
compile_captures
(
desc
.captures
.clone
(),
helper
,
repository
.clone
(),
);
let
match_rule
=
MatchRule
::
new
(
...
...
@@ -152,7 +146,7 @@ impl<'a> RuleFactory<'a> {
rule_factory
,
);
self
.
helper
.register_rule
(
Box
::
new
(
match_rule
));
helper
.register_rule
(
Box
::
new
(
match_rule
));
return
desc
.id
.unwrap
();
};
...
...
@@ -169,8 +163,9 @@ impl<'a> RuleFactory<'a> {
}
}
let
rule_factory
=
self
.
compile_patterns
(
let
rule_factory
=
RuleFactory
::
compile_patterns
(
patterns
.clone
(),
Box
::
new
(
helper
),
repository
.clone
(),
);
let
include_only_rule
=
IncludeOnlyRule
::
new
(
...
...
@@ -180,17 +175,18 @@ impl<'a> RuleFactory<'a> {
desc
.content_name
.clone
(),
rule_factory
,
);
self
.
helper
.register_rule
(
Box
::
new
(
include_only_rule
));
helper
.register_rule
(
Box
::
new
(
include_only_rule
));
return
desc
.id
.unwrap
();
}
if
let
Some
(
while_s
)
=
desc
.while_s
{
let
begin_rule_factory
=
self
.compile_captures
(
desc
.begin_captures
,
repository
.clone
());
RuleFactory
::
compile_captures
(
desc
.begin_captures
,
helper
,
repository
.clone
());
let
end_rule_factory
=
self
.compile_captures
(
desc
.end_captures
,
repository
.clone
());
let
pattern_factory
=
self
.
compile_patterns
(
RuleFactory
::
compile_captures
(
desc
.end_captures
,
helper
,
repository
.clone
());
let
pattern_factory
=
RuleFactory
::
compile_patterns
(
desc
.patterns
.clone
(),
Box
::
new
(
helper
),
repository
.clone
(),
);
...
...
@@ -206,14 +202,14 @@ impl<'a> RuleFactory<'a> {
pattern_factory
,
);
self
.
helper
.register_rule
(
Box
::
new
(
begin_while_rule
));
helper
.register_rule
(
Box
::
new
(
begin_while_rule
));
return
desc
.id
.unwrap
();
}
let
begin_rule_factory
=
self
.compile_captures
(
desc
.begin_captures
,
repository
.clone
());
RuleFactory
::
compile_captures
(
desc
.begin_captures
,
helper
,
repository
.clone
());
let
end_rule_factory
=
self
.compile_captures
(
desc
.end_captures
,
repository
.clone
());
RuleFactory
::
compile_captures
(
desc
.end_captures
,
helper
,
repository
.clone
());
// let pattern_factory = RuleFactory::compile_patterns(
// desc.patterns.clone(),
// Box::new(helper),
...
...
@@ -234,7 +230,7 @@ impl<'a> RuleFactory<'a> {
// pattern_factory,
);
self
.
helper
.register_rule
(
Box
::
new
(
begin_end_rule
));
helper
.register_rule
(
Box
::
new
(
begin_end_rule
));
return
desc
.id
.unwrap
();
}
...
...
@@ -331,7 +327,7 @@ impl BeginWhileRule {
end_captures
:
None
,
apply_end_pattern_last
:
None
,
patterns
:
None
,
cached_compiled_patterns
:
None
,
cached_compiled_patterns
:
None
}
}
}
...
...
@@ -398,7 +394,7 @@ impl BeginEndRule {
end_captures
:
None
,
apply_end_pattern_last
,
patterns
:
None
,
cached_compiled_patterns
:
None
,
cached_compiled_patterns
:
None
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录