Skip to content

Commit f178423

Browse files
committed
Finish revamping dict_new()
1 parent bdc80dc commit f178423

File tree

1 file changed

+33
-1
lines changed

1 file changed

+33
-1
lines changed

vm/src/obj/objdict.rs

+33-1
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ use super::super::pyobject::{
22
PyContext, PyFuncArgs, PyObject, PyObjectKind, PyObjectRef, PyResult, TypeProtocol,
33
};
44
use super::super::vm::VirtualMachine;
5+
use super::objiter;
56
use super::objstr;
67
use super::objtype;
78
use num_bigint::ToBigInt;
@@ -114,7 +115,38 @@ pub fn content_contains_key_str(elements: &DictContentType, key: &str) -> bool {
114115
// Python dict methods:
115116

116117
fn dict_new(vm: &mut VirtualMachine, args: PyFuncArgs) -> PyResult {
117-
let dict = new(args.args[0].clone());
118+
arg_check!(
119+
vm,
120+
args,
121+
required = [(_ty, Some(vm.ctx.type_type()))],
122+
optional = [(dict_obj, None)]
123+
);
124+
let dict = vm.ctx.new_dict();
125+
if let Some(dict_obj) = dict_obj {
126+
if objtype::isinstance(&dict_obj, &vm.ctx.dict_type()) {
127+
for (needle, value) in get_key_value_pairs(&dict_obj) {
128+
set_item(&dict, &needle, &value);
129+
}
130+
} else {
131+
let iter = objiter::get_iter(vm, dict_obj)?;
132+
loop {
133+
fn err(vm: &mut VirtualMachine) -> PyObjectRef {
134+
vm.new_type_error("Iterator must have exactly two elements".to_string())
135+
}
136+
let element = match objiter::get_next_object(vm, &iter)? {
137+
Some(obj) => obj,
138+
None => break,
139+
};
140+
let elem_iter = objiter::get_iter(vm, &element)?;
141+
let needle = objiter::get_next_object(vm, &elem_iter)?.ok_or_else(|| err(vm))?;
142+
let value = objiter::get_next_object(vm, &elem_iter)?.ok_or_else(|| err(vm))?;
143+
if let Some(_) = objiter::get_next_object(vm, &elem_iter)? {
144+
return Err(err(vm));
145+
}
146+
set_item(&dict, &needle, &value);
147+
}
148+
}
149+
}
118150
for (needle, value) in args.kwargs {
119151
set_item(&dict, &vm.new_str(needle), &value);
120152
}

0 commit comments

Comments
 (0)