generated from ElnuDev/rust-project
Compare commits
2 commits
24e33aa550
...
a518097ff0
Author | SHA1 | Date | |
---|---|---|---|
a518097ff0 | |||
8faf2eb636 |
3 changed files with 30 additions and 8 deletions
|
@ -4,6 +4,9 @@ what the heck
|
||||||
"this is a string with a # comment"
|
"this is a string with a # comment"
|
||||||
"this is a string over
|
"this is a string over
|
||||||
multiple lines"
|
multiple lines"
|
||||||
|
"this is \"escaped\""
|
||||||
|
'this is a single quote string'
|
||||||
|
'this also has escaped \'quotes\''
|
||||||
this is cool # comment
|
this is cool # comment
|
||||||
|
|
||||||
huh
|
huh
|
19
src/lib.rs
19
src/lib.rs
|
@ -19,11 +19,22 @@ pub fn parse(file_path: &str) {
|
||||||
for token in line.into_inner() {
|
for token in line.into_inner() {
|
||||||
match token.as_rule() {
|
match token.as_rule() {
|
||||||
Rule::token => {
|
Rule::token => {
|
||||||
println!("{}", token.as_str());
|
let token = token.into_inner().next().unwrap();
|
||||||
|
match token.as_rule() {
|
||||||
|
Rule::string => {
|
||||||
|
let string_data = token.into_inner().next().unwrap();
|
||||||
|
let str = string_data.as_str();
|
||||||
|
println!("string: {}", match string_data.as_rule() {
|
||||||
|
Rule::single_quote_string_data => str.replace("\\'", "'"),
|
||||||
|
Rule::double_quote_string_data => str.replace("\\\"", "\""),
|
||||||
|
_ => unreachable!(),
|
||||||
|
});
|
||||||
},
|
},
|
||||||
_ => {
|
Rule::keyword => println!("keyword: {}", token.as_str()),
|
||||||
println!("{}", token.as_str());
|
_ => unreachable!(),
|
||||||
}
|
};
|
||||||
|
},
|
||||||
|
_ => unreachable!(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
println!()
|
println!()
|
||||||
|
|
16
src/rpy.pest
16
src/rpy.pest
|
@ -13,10 +13,18 @@ token = { string | keyword }
|
||||||
// has to be atomic for no implicit separate (spaces)
|
// has to be atomic for no implicit separate (spaces)
|
||||||
keyword = @{ (!(WHITESPACE | NEWLINE) ~ ANY)+ }
|
keyword = @{ (!(WHITESPACE | NEWLINE) ~ ANY)+ }
|
||||||
|
|
||||||
// strings cannot contain quotes
|
single_quote_string_data = @{ (
|
||||||
// TODO: escaped quotes
|
"\\'" // Escaped single quotes
|
||||||
string_data = @{ (!"\"" ~ ANY)* }
|
| (!"'" ~ ANY)
|
||||||
string = ${ "\"" ~ string_data ~ "\"" }
|
)* }
|
||||||
|
double_quote_string_data = @{ (
|
||||||
|
"\\\"" // Escaped double quotes
|
||||||
|
| (!"\"" ~ ANY)
|
||||||
|
)* }
|
||||||
|
string = ${
|
||||||
|
("'" ~ single_quote_string_data ~ "'")
|
||||||
|
| ("\"" ~ double_quote_string_data ~ "\"")
|
||||||
|
}
|
||||||
|
|
||||||
// comments are a # followed by
|
// comments are a # followed by
|
||||||
// any number of non-newline characters
|
// any number of non-newline characters
|
||||||
|
|
Loading…
Add table
Reference in a new issue