1
0
forked from M-Labs/nac3

store operation method signature

This commit is contained in:
pca006132 2021-08-07 10:41:53 +08:00
parent c405e46b00
commit 34d3317ea0

View File

@ -182,6 +182,7 @@ impl<'a> Inferencer<'a> {
fn build_method_call( fn build_method_call(
&mut self, &mut self,
location: Location,
method: String, method: String,
obj: Type, obj: Type,
params: Vec<Type>, params: Vec<Type>,
@ -193,6 +194,7 @@ impl<'a> Inferencer<'a> {
ret, ret,
fun: RefCell::new(None), fun: RefCell::new(None),
}); });
self.calls.insert(location.into(), call.clone());
let call = self.unifier.add_ty(TypeEnum::TCall(vec![call].into())); let call = self.unifier.add_ty(TypeEnum::TCall(vec![call].into()));
let fields = once((method, call)).collect(); let fields = once((method, call)).collect();
let record = self.unifier.add_record(fields); let record = self.unifier.add_record(fields);
@ -477,6 +479,7 @@ impl<'a> Inferencer<'a> {
let method = binop_name(op); let method = binop_name(op);
let ret = self.unifier.get_fresh_var().0; let ret = self.unifier.get_fresh_var().0;
self.build_method_call( self.build_method_call(
left.location,
method.to_string(), method.to_string(),
left.custom.unwrap(), left.custom.unwrap(),
vec![right.custom.unwrap()], vec![right.custom.unwrap()],
@ -491,7 +494,13 @@ impl<'a> Inferencer<'a> {
) -> InferenceResult { ) -> InferenceResult {
let method = unaryop_name(op); let method = unaryop_name(op);
let ret = self.unifier.get_fresh_var().0; let ret = self.unifier.get_fresh_var().0;
self.build_method_call(method.to_string(), operand.custom.unwrap(), vec![], ret) self.build_method_call(
operand.location,
method.to_string(),
operand.custom.unwrap(),
vec![],
ret,
)
} }
fn infer_compare( fn infer_compare(
@ -504,7 +513,7 @@ impl<'a> Inferencer<'a> {
for (a, b, c) in izip!(once(left).chain(comparators), comparators, ops) { for (a, b, c) in izip!(once(left).chain(comparators), comparators, ops) {
let method = let method =
comparison_name(c).ok_or_else(|| "unsupported comparator".to_string())?.to_string(); comparison_name(c).ok_or_else(|| "unsupported comparator".to_string())?.to_string();
self.build_method_call(method, a.custom.unwrap(), vec![b.custom.unwrap()], boolean)?; self.build_method_call(a.location, method, a.custom.unwrap(), vec![b.custom.unwrap()], boolean)?;
} }
Ok(boolean) Ok(boolean)
} }