refactor: use C for the external scanner (#13)
This commit is contained in:
parent
399605a02b
commit
24ed4fd565
|
@ -9,7 +9,7 @@
|
||||||
"sources": [
|
"sources": [
|
||||||
"bindings/node/binding.cc",
|
"bindings/node/binding.cc",
|
||||||
"src/parser.c",
|
"src/parser.c",
|
||||||
# If your language uses an external scanner, add it here.
|
"src/scanner.c",
|
||||||
],
|
],
|
||||||
"cflags_c": [
|
"cflags_c": [
|
||||||
"-std=c99",
|
"-std=c99",
|
||||||
|
|
|
@ -2,7 +2,7 @@ fn main() {
|
||||||
let src_dir = std::path::Path::new("src");
|
let src_dir = std::path::Path::new("src");
|
||||||
|
|
||||||
let mut c_config = cc::Build::new();
|
let mut c_config = cc::Build::new();
|
||||||
c_config.include(&src_dir);
|
c_config.include(src_dir);
|
||||||
c_config
|
c_config
|
||||||
.flag_if_supported("-Wno-unused-parameter")
|
.flag_if_supported("-Wno-unused-parameter")
|
||||||
.flag_if_supported("-Wno-unused-but-set-variable")
|
.flag_if_supported("-Wno-unused-but-set-variable")
|
||||||
|
@ -10,29 +10,10 @@ fn main() {
|
||||||
let parser_path = src_dir.join("parser.c");
|
let parser_path = src_dir.join("parser.c");
|
||||||
c_config.file(&parser_path);
|
c_config.file(&parser_path);
|
||||||
|
|
||||||
// If your language uses an external scanner written in C,
|
|
||||||
// then include this block of code:
|
|
||||||
|
|
||||||
/*
|
|
||||||
let scanner_path = src_dir.join("scanner.c");
|
let scanner_path = src_dir.join("scanner.c");
|
||||||
c_config.file(&scanner_path);
|
c_config.file(&scanner_path);
|
||||||
println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap());
|
println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap());
|
||||||
*/
|
|
||||||
|
|
||||||
c_config.compile("parser");
|
c_config.compile("parser");
|
||||||
println!("cargo:rerun-if-changed={}", parser_path.to_str().unwrap());
|
println!("cargo:rerun-if-changed={}", parser_path.to_str().unwrap());
|
||||||
|
|
||||||
// If your language uses an external scanner written in C++,
|
|
||||||
// then include this block of code:
|
|
||||||
|
|
||||||
let mut cpp_config = cc::Build::new();
|
|
||||||
cpp_config.cpp(true);
|
|
||||||
cpp_config.include(&src_dir);
|
|
||||||
cpp_config
|
|
||||||
.flag_if_supported("-Wno-unused-parameter")
|
|
||||||
.flag_if_supported("-Wno-unused-but-set-variable");
|
|
||||||
let scanner_path = src_dir.join("scanner.cc");
|
|
||||||
cpp_config.file(&scanner_path);
|
|
||||||
cpp_config.compile("scanner");
|
|
||||||
println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap());
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
#include <cwctype>
|
|
||||||
#include <tree_sitter/parser.h>
|
#include <tree_sitter/parser.h>
|
||||||
|
#include <wctype.h>
|
||||||
|
|
||||||
namespace {
|
|
||||||
enum TokenType { BRACKET_ARGUMENT, BRACKET_COMMENT, LINE_COMMENT };
|
enum TokenType { BRACKET_ARGUMENT, BRACKET_COMMENT, LINE_COMMENT };
|
||||||
void skip(TSLexer *lexer) { lexer->advance(lexer, true); }
|
void skip(TSLexer *lexer) { lexer->advance(lexer, true); }
|
||||||
void advance(TSLexer *lexer) { lexer->advance(lexer, false); }
|
void advance(TSLexer *lexer) { lexer->advance(lexer, false); }
|
||||||
void skip_wspace(TSLexer *lexer) {
|
void skip_wspace(TSLexer *lexer) {
|
||||||
while (std::iswspace(lexer->lookahead)) {
|
while (iswspace(lexer->lookahead)) {
|
||||||
skip(lexer);
|
skip(lexer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,8 +71,6 @@ bool scan(void *payload, TSLexer *lexer, bool const *valid_symbols) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
|
||||||
extern "C" {
|
|
||||||
void *tree_sitter_cmake_external_scanner_create() { return NULL; }
|
void *tree_sitter_cmake_external_scanner_create() { return NULL; }
|
||||||
void tree_sitter_cmake_external_scanner_destroy(void *payload) {}
|
void tree_sitter_cmake_external_scanner_destroy(void *payload) {}
|
||||||
unsigned tree_sitter_cmake_external_scanner_serialize(void *payload,
|
unsigned tree_sitter_cmake_external_scanner_serialize(void *payload,
|
||||||
|
@ -87,4 +84,3 @@ bool tree_sitter_cmake_external_scanner_scan(void *payload, TSLexer *lexer,
|
||||||
bool const *valid_symbols) {
|
bool const *valid_symbols) {
|
||||||
return scan(payload, lexer, valid_symbols);
|
return scan(payload, lexer, valid_symbols);
|
||||||
}
|
}
|
||||||
}
|
|
Loading…
Reference in a new issue