Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
scie
提交
b41cfa36
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 搜索 >>
未验证
提交
b41cfa36
编写于
9月 02, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: use scanner in realy codE
上级
6edd82ae
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
17 addition
and
3 deletion
+17
-3
scie-grammar/src/grammar/grammar.rs
scie-grammar/src/grammar/grammar.rs
+11
-2
scie-grammar/src/rule/compiled_rule.rs
scie-grammar/src/rule/compiled_rule.rs
+5
-0
scie-scanner/src/scanner/scanner.rs
scie-scanner/src/scanner/scanner.rs
+1
-1
未找到文件。
scie-grammar/src/grammar/grammar.rs
浏览文件 @
b41cfa36
...
...
@@ -5,6 +5,7 @@ use crate::grammar::{ScopeListElement, StackElement};
use
crate
::
inter
::{
IRawGrammar
,
IRawRepository
,
IRawRepositoryMap
,
IRawRule
};
use
crate
::
rule
::
rule_factory
::
RuleFactory
;
use
crate
::
rule
::{
AbstractRule
,
EmptyRule
,
IGrammarRegistry
,
IRuleFactoryHelper
,
IRuleRegistry
};
use
scie_scanner
::
scanner
::
scanner
::
IOnigMatch
;
pub
struct
IToken
{
pub
start_index
:
i32
,
...
...
@@ -214,14 +215,22 @@ impl Grammar {
line_pos
:
i32
,
stack
:
StackElement
,
anchor_position
:
i32
,
)
{
)
->
Option
<
IOnigMatch
>
{
let
mut
rule
=
stack
.get_rule
(
self
);
let
rule_scanner
=
rule
.compile
(
let
mut
rule_scanner
=
rule
.compile
(
self
,
stack
.end_rule
,
is_first_line
,
line_pos
==
anchor_position
,
);
// rule_scanner.scanner
let
r
=
rule_scanner
.scanner
.find_next_match_sync
(
line_text
,
line_pos
);
if
let
Some
(
result
)
=
r
{
println!
(
"{:?}"
,
result
);
Some
(
result
)
}
else
{
None
}
}
pub
fn
tokenize_line
(
&
mut
self
,
line_text
:
String
,
prev_state
:
Option
<
StackElement
>
)
{
...
...
scie-grammar/src/rule/compiled_rule.rs
浏览文件 @
b41cfa36
use
scie_scanner
::
scanner
::
scanner
::
Scanner
;
#[derive(Clone,
Debug,
Serialize)]
pub
struct
CompiledRule
{
pub
debug_reg_exps
:
Vec
<
String
>
,
pub
rules
:
Vec
<
i32
>
,
pub
scanner
:
Box
<
Scanner
>
}
impl
CompiledRule
{
pub
fn
new
(
debug_reg_exps
:
Vec
<
String
>
,
rules
:
Vec
<
i32
>
)
->
Self
{
let
mut
scanner
=
Scanner
::
new
(
debug_reg_exps
.clone
());
CompiledRule
{
debug_reg_exps
,
rules
,
scanner
:
Box
::
new
(
scanner
)
}
}
}
scie-scanner/src/scanner/scanner.rs
浏览文件 @
b41cfa36
...
...
@@ -14,7 +14,7 @@ pub struct IOnigMatch {
pub
capture_indices
:
Vec
<
IOnigCaptureIndex
>
,
}
#[derive(Debug,
Clone)]
#[derive(Debug,
Clone
,
Serialize
)]
pub
struct
Scanner
{
pub
index
:
usize
,
pub
patterns
:
Vec
<
String
>
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录