# HG changeset patch # User Bastien Orivel # Date 1464898848 -7200 # Node ID b21a246349f3fae939233baf53296802eacebbc6 # Parent a0fb169fe0f921e85d9eb86f4ea438c7c05c9bab Add ast.DictComp diff --git a/example/dictcomp.py b/example/dictcomp.py new file mode 100644 --- /dev/null +++ b/example/dictcomp.py @@ -0,0 +1,1 @@ +d = {key: 4 for key in imaginary_list if key % 12} diff --git a/src/ast_convert.rs b/src/ast_convert.rs --- a/src/ast_convert.rs +++ b/src/ast_convert.rs @@ -216,6 +216,7 @@ fn parse_expr(py: Python, ast: PyObject) let compare_type = ast_module.get(py, "Compare").unwrap(); let call_type = ast_module.get(py, "Call").unwrap(); let listcomp_type = ast_module.get(py, "ListComp").unwrap(); + let dictcomp_type = ast_module.get(py, "DictComp").unwrap(); assert!(is_instance(&ast, &ast_type)); @@ -335,8 +336,23 @@ fn parse_expr(py: Python, ast: PyObject) new_gens.push(gen); } expr::ListComp(Box::new(elt), new_gens) - } - else { + } else if is_instance(&ast, &dictcomp_type) { + let key = ast.getattr(py, "key").unwrap(); + let value = ast.getattr(py, "value").unwrap(); + let generators = ast.getattr(py, "generators").unwrap(); + let generators = generators.iter(py).unwrap(); + + let key = parse_expr(py, key); + let value = parse_expr(py, value); + + let mut new_gens = vec!(); + for gen in generators { + let gen = gen.unwrap(); + let gen = parse_comprehension(py, gen); + new_gens.push(gen); + } + expr::DictComp(Box::new(key), Box::new(value), new_gens) + } else { println!("expr {}", ast); unreachable!() } diff --git a/src/ast_dump.rs b/src/ast_dump.rs --- a/src/ast_dump.rs +++ b/src/ast_dump.rs @@ -147,7 +147,8 @@ impl expr { expr::Attribute(value, attr, ctx) => format!("{}.{}", value.to_string(), attr), expr::Name(name, ctx) => format!("{}", name), expr::List(elts, ctx) => format!("[{}]", args_to_string(elts)), - expr::ListComp(elt, generators) => format!("[{} {}]", elt.to_string(), generators_to_string(generators)) + expr::ListComp(elt, generators) => format!("[{} {}]", elt.to_string(), generators_to_string(generators)), + expr::DictComp(key, value, generators) => format!("{{{}: {} {}}}", key.to_string(), value.to_string(), generators_to_string(generators)) } } } diff --git a/src/python_ast.rs b/src/python_ast.rs --- a/src/python_ast.rs +++ b/src/python_ast.rs @@ -86,7 +86,7 @@ pub enum expr { //Set(Vec) ListComp(Box, Vec), //SetComp(Box, Vec) - //DictComp(Box, Box, Vec) + DictComp(Box, Box, Vec), //GeneratorExp(Box, Vec) // the grammar constrains where yield expressions can occur