pub const ELEMENT_QUERY: &str = r"
(block_mapping_pair key: (_) @func_name) @function
";
pub const CALL_QUERY: &str = "";
#[cfg(all(test, feature = "lang-yaml"))]
mod tests {
use tree_sitter::{Parser, StreamingIterator};
fn parse_and_query(src: &str, query_str: &str, capture_name: &str) -> Vec<String> {
let language = tree_sitter_yaml::LANGUAGE;
let mut parser = Parser::new();
parser
.set_language(&language.into())
.expect("failed to set language");
let tree = parser.parse(src, None).expect("parse failed");
let query = tree_sitter::Query::new(&language.into(), query_str).expect("invalid query");
let mut cursor = tree_sitter::QueryCursor::new();
let mut matches = cursor.matches(&query, tree.root_node(), src.as_bytes());
let capture_idx = query
.capture_index_for_name(capture_name)
.expect("capture not found");
let mut results = Vec::new();
while let Some(m) = matches.next() {
for cap in m.captures {
if cap.index == capture_idx {
let text = &src[cap.node.start_byte()..cap.node.end_byte()];
results.push(text.trim().to_owned());
}
}
}
results
}
#[test]
fn test_yaml_block_mapping_element_extraction() {
let src = "name: my-project\nversion: 1.0.0\ndescription: A test project\n";
let names = parse_and_query(src, super::ELEMENT_QUERY, "func_name");
assert_eq!(names, vec!["name", "version", "description"]);
}
#[test]
fn test_yaml_empty_file() {
let names = parse_and_query("", super::ELEMENT_QUERY, "func_name");
assert!(names.is_empty());
}
#[test]
fn test_yaml_multi_document_stream() {
let src = "---\nfoo: bar\nbaz: qux\n---\nalpha: beta\n";
let names = parse_and_query(src, super::ELEMENT_QUERY, "func_name");
assert!(names.contains(&"foo".to_owned()));
assert!(names.contains(&"baz".to_owned()));
assert!(names.contains(&"alpha".to_owned()));
}
}