Skip to content

Commit

Permalink
Merge branch 'kcl-lang:main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
zong-zhe authored Oct 17, 2023
2 parents 54fba25 + 83cc443 commit 4d2c6f6
Show file tree
Hide file tree
Showing 6 changed files with 89 additions and 10 deletions.
37 changes: 28 additions & 9 deletions kclvm/sema/src/pre_process/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,30 @@ impl ConfigNestAttrTransformer {
pub fn walk_config_entry(&mut self, config_entry: &mut Box<ast::Node<ast::ConfigEntry>>) {
if let Some(key) = config_entry.node.key.as_mut() {
if let ast::Expr::Identifier(identifier) = &mut key.node {
// desuger config expr, e.g., desuger
// ```
// foo = Foo {
// bar.baz : xxx
// }
// ```
// to:
// ```
// foo = Foo {
// bar : Bar {
// baz : xxx
// }
// }
// ```
if identifier.names.len() > 1 {
let mut names = identifier.names.clone();
let names = &mut names[1..];
names.reverse();
identifier.names = vec![identifier.names[0].clone()];
key.filename = identifier.names[0].filename.clone();
key.line = identifier.names[0].line;
key.column = identifier.names[0].column;
key.end_line = identifier.names[0].end_line;
key.end_column = identifier.names[0].end_column;

let mut value = config_entry.node.value.clone();
for (i, name) in names.iter().enumerate() {
Expand All @@ -29,11 +48,11 @@ impl ConfigNestAttrTransformer {
let entry_value = ast::ConfigEntry {
key: Some(Box::new(ast::Node::new(
ast::Expr::Identifier(name_node),
key.filename.clone(),
key.line,
key.column,
key.end_line,
key.end_column,
name.filename.clone(),
name.line,
name.column,
name.end_line,
name.end_column,
))),
value: value.clone(),
operation: if is_last_item {
Expand All @@ -47,17 +66,17 @@ impl ConfigNestAttrTransformer {
items: vec![Box::new(ast::Node::new(
entry_value,
config_entry.filename.clone(),
config_entry.line,
config_entry.column,
name.line,
name.column,
config_entry.end_line,
config_entry.end_column,
))],
};
value = Box::new(ast::Node::new(
ast::Expr::Config(config_expr),
value.filename.clone(),
value.line,
value.column,
name.line,
name.column,
value.end_line,
value.end_column,
))
Expand Down
6 changes: 6 additions & 0 deletions kclvm/sema/src/resolver/test_fail_data/lambda_ty_error.k
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
_func = lambda x: int, y: int -> int {
x - y
} # Ok
_func = lambda x: int, y: int -> str {
str(x + y)
} # Error: expect function (int, int) -> str, got function (int, int) -> int
20 changes: 20 additions & 0 deletions kclvm/sema/src/resolver/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -549,3 +549,23 @@ fn test_resolve_assignment_in_lambda() {
let images_scope_obj = lambda_scope.borrow().elems.get("images").unwrap().clone();
assert_eq!(images_scope_obj.borrow().ty.ty_str(), "[str]");
}

#[test]
fn test_resolve_lambda_assignment_diagnostic() {
let sess = Arc::new(ParseSession::default());
let mut program = load_program(
sess.clone(),
&["./src/resolver/test_fail_data/lambda_ty_error.k"],
None,
)
.unwrap();
let scope = resolve_program(&mut program);
assert_eq!(scope.handler.diagnostics.len(), 1);
let diag = &scope.handler.diagnostics[0];
assert_eq!(diag.code, Some(DiagnosticId::Error(ErrorKind::TypeError)));
assert_eq!(diag.messages.len(), 1);
assert_eq!(
diag.messages[0].message,
"expected function (int, int) -> int, got function (int, int) -> str"
);
}
16 changes: 15 additions & 1 deletion kclvm/sema/src/ty/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ impl Type {
.join("|"),
TypeKind::Schema(schema_ty) => schema_ty.name.to_string(),
TypeKind::NumberMultiplier(number_multiplier) => number_multiplier.ty_str(),
TypeKind::Function(_) => FUNCTION_TYPE_STR.to_string(),
TypeKind::Function(func_ty) => func_ty.ty_str(),
TypeKind::Void => VOID_TYPE_STR.to_string(),
TypeKind::Module(module_ty) => format!("{} '{}'", MODULE_TYPE_STR, module_ty.pkgpath),
TypeKind::Named(name) => name.to_string(),
Expand Down Expand Up @@ -387,6 +387,20 @@ pub struct FunctionType {
pub kw_only_index: Option<usize>,
}

impl FunctionType {
pub fn ty_str(&self) -> String {
format!(
"function ({}) -> {}",
self.params
.iter()
.map(|param| param.ty.ty_str())
.collect::<Vec<String>>()
.join(", "),
self.return_ty.ty_str()
)
}
}

impl FunctionType {
#[inline]
pub fn variadic_func() -> Self {
Expand Down
16 changes: 16 additions & 0 deletions kclvm/tools/src/LSP/src/goto_def.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1031,4 +1031,20 @@ mod tests {
let res = goto_definition(&program, &pos, &prog_scope);
compare_goto_res(res, (&file, 18, 4, 18, 8));
}

#[test]
#[bench_test]
fn config_desuger_def_goto_def() {
let (file, program, prog_scope, _) =
compile_test_file("src/test_data/goto_def_test/goto_def.k");

let pos = KCLPos {
filename: file.clone(),
line: 82,
column: Some(9),
};

let res = goto_definition(&program, &pos, &prog_scope);
compare_goto_res(res, (&file, 81, 6, 81, 10));
}
}
4 changes: 4 additions & 0 deletions kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_def.k
Original file line number Diff line number Diff line change
Expand Up @@ -77,3 +77,7 @@ items1 = [item | {
"securityContext": {"capabilities": {"add" += [cc] if cc not in (container?.securityContext?.capabilities?.drop or []) else [] for cc in capabilities}}
} for container in item.spec.containers]
} for item in option("items")]

p4 = Person {
n.name: "a"
}

0 comments on commit 4d2c6f6

Please sign in to comment.