Skip to content

Commit f562421

Browse files
committed
Fix unpack_ex related messages
1 parent c028818 commit f562421

File tree

3 files changed

+14
-4
lines changed

3 files changed

+14
-4
lines changed

compiler/src/compile.rs

+8-1
Original file line numberDiff line numberDiff line change
@@ -1399,7 +1399,14 @@ impl<O: OutputStream> Compiler<O> {
13991399
}
14001400
}
14011401
}
1402-
_ => return Err(self.error(CompileErrorType::Assign(target.name()))),
1402+
_ => {
1403+
return Err(self.error(match target.node {
1404+
ast::ExpressionType::Starred { .. } => CompileErrorType::SyntaxError(
1405+
"starred assignment target must be in a list or tuple".to_owned(),
1406+
),
1407+
_ => CompileErrorType::Assign(target.name()),
1408+
}))
1409+
}
14031410
}
14041411

14051412
Ok(())

vm/src/frame.rs

+5-2
Original file line numberDiff line numberDiff line change
@@ -940,7 +940,9 @@ impl ExecutingFrame<'_> {
940940
if unpack {
941941
for obj in self.pop_multiple(size) {
942942
// Take all key-value pairs from the dict:
943-
let dict: PyDictRef = obj.downcast().expect("Need a dictionary to build a map.");
943+
let dict: PyDictRef = obj.downcast().map_err(|obj| {
944+
vm.new_type_error(format!("'{}' object is not a mapping", obj.class().name))
945+
})?;
944946
for (key, value) in dict {
945947
if for_call {
946948
if map_obj.contains_key(&key, vm) {
@@ -1014,6 +1016,7 @@ impl ExecutingFrame<'_> {
10141016
let kwargs = if *has_kwargs {
10151017
let kw_dict: PyDictRef = match self.pop_value().downcast() {
10161018
Err(_) => {
1019+
// TODO: check collections.abc.Mapping
10171020
return Err(vm.new_type_error("Kwargs must be a dict.".to_owned()));
10181021
}
10191022
Ok(x) => x,
@@ -1137,7 +1140,7 @@ impl ExecutingFrame<'_> {
11371140
let min_expected = before + after;
11381141
if elements.len() < min_expected {
11391142
Err(vm.new_value_error(format!(
1140-
"Not enough values to unpack (expected at least {}, got {}",
1143+
"not enough values to unpack (expected at least {}, got {})",
11411144
min_expected,
11421145
elements.len()
11431146
)))

vm/src/obj/objiter.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@ pub fn get_iter(vm: &VirtualMachine, iter_target: &PyObjectRef) -> PyResult {
2626
vm.invoke(&method, vec![])
2727
} else {
2828
vm.get_method_or_type_error(iter_target.clone(), "__getitem__", || {
29-
format!("Cannot iterate over {}", iter_target.class().name)
29+
format!("'{}' object is not iterable", iter_target.class().name)
3030
})?;
3131
Ok(PySequenceIterator::new_forward(iter_target.clone())
3232
.into_ref(vm)

0 commit comments

Comments
 (0)