Commit bebda731 authored by Bob Fang's avatar Bob Fang

unifying behaviour -- step 1

unifying behaviour -- step 2

unifying behaviour -- step 3
parent 05fb51ad
...@@ -712,24 +712,22 @@ static PyObject* instance_index(PyObject* self) noexcept { ...@@ -712,24 +712,22 @@ static PyObject* instance_index(PyObject* self) noexcept {
return res; return res;
} }
Box* instanceEq(Box* _inst, Box* other) { Box* _instanceBinary(Box* _inst, Box* other, const char* attr) {
RELEASE_ASSERT(_inst->cls == instance_cls, ""); RELEASE_ASSERT(_inst->cls == instance_cls, "");
BoxedInstance* inst = static_cast<BoxedInstance*>(_inst); BoxedInstance* inst = static_cast<BoxedInstance*>(_inst);
Box* func = _instanceGetattribute(inst, boxStrConstant("__eq__"), false); Box* func = _instanceGetattribute(inst, boxStrConstant(attr), false);
if (!func) if (!func)
return NotImplemented; return NotImplemented;
return runtimeCall(func, ArgPassSpec(1), other, NULL, NULL, NULL, NULL); return runtimeCall(func, ArgPassSpec(1), other, NULL, NULL, NULL, NULL);
} }
Box* instanceNe(Box* _inst, Box* other) { Box* instanceEq(Box* _inst, Box* other) {
RELEASE_ASSERT(_inst->cls == instance_cls, ""); return _instanceBinary(_inst, other, "__eq__");
BoxedInstance* inst = static_cast<BoxedInstance*>(_inst); }
Box* func = _instanceGetattribute(inst, boxStrConstant("__ne__"), false); Box* instanceNe(Box* _inst, Box* other) {
if (!func) return _instanceBinary(_inst, other, "__ne__");
return NotImplemented;
return runtimeCall(func, ArgPassSpec(1), other, NULL, NULL, NULL, NULL);
} }
Box* instanceCall(Box* _inst, Box* _args, Box* _kwargs) { Box* instanceCall(Box* _inst, Box* _args, Box* _kwargs) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment