Commit 64faf815 authored by Kevin Modzelewski's avatar Kevin Modzelewski

Merge commit 'd9896' into refcounting

parents 287a69e4 d98960b4
......@@ -423,16 +423,14 @@ public:
}
// Sort in order of `num_parents_from_passed_closure`
std::sort(allDerefVarsAndInfo.begin(), allDerefVarsAndInfo.end(), derefComparator);
std::sort(
allDerefVarsAndInfo.begin(), allDerefVarsAndInfo.end(),
[](const std::pair<InternedString, DerefInfo>& p1, const std::pair<InternedString, DerefInfo>& p2) {
return p1.second.num_parents_from_passed_closure < p2.second.num_parents_from_passed_closure;
});
}
return allDerefVarsAndInfo;
}
private:
static bool derefComparator(const std::pair<InternedString, DerefInfo>& p1,
const std::pair<InternedString, DerefInfo>& p2) {
return p1.second.num_parents_from_passed_closure < p2.second.num_parents_from_passed_closure;
};
};
static void raiseGlobalAndLocalException(InternedString name, AST* node) {
......
......@@ -566,8 +566,31 @@ extern "C" int PyObject_HasAttrString(PyObject* v, const char* name) noexcept {
// I'm not sure how we can support this one:
extern "C" PyObject** _PyObject_GetDictPtr(PyObject* obj) noexcept {
fatalOrError(PyExc_NotImplementedError, "unimplemented");
return nullptr;
Py_ssize_t dictoffset;
PyTypeObject* tp = Py_TYPE(obj);
if (!tp->instancesHaveHCAttrs()) {
dictoffset = tp->tp_dictoffset;
if (dictoffset == 0)
return NULL;
if (dictoffset < 0) {
Py_ssize_t tsize;
size_t size;
tsize = ((PyVarObject*)obj)->ob_size;
if (tsize < 0)
tsize = -tsize;
size = _PyObject_VAR_SIZE(tp, tsize);
dictoffset += (long)size;
assert(dictoffset > 0);
assert(dictoffset % SIZEOF_VOID_P == 0);
}
return (PyObject**)((char*)obj + dictoffset);
} else {
fatalOrError(PyExc_NotImplementedError, "unimplemented for hcattrs");
return nullptr;
}
}
/* These methods are used to control infinite recursion in repr, str, print,
......
......@@ -139,7 +139,7 @@ public:
AST_TYPE::AST_TYPE convert(boolop_ty op) {
switch (op) {
CASE(Add);
CASE(And);
CASE(Or);
}
// GCC wants this:
......
......@@ -1106,11 +1106,11 @@ AST_Module* parse_file(const char* fn, FutureFlags inherited_flags) {
const char* getMagic() {
if (ENABLE_CPYTHON_PARSER)
return "a\nCO";
return "a\nCP";
else if (ENABLE_PYPA_PARSER)
return "a\ncO";
return "a\ncP";
else
return "a\nco";
return "a\ncp";
}
#define MAGIC_STRING_LENGTH 4
......
......@@ -1560,6 +1560,9 @@ bool PrintVisitor::visit_langprimitive(AST_LangPrimitive* node) {
case AST_LangPrimitive::HASNEXT:
stream << "HASNEXT";
break;
case AST_LangPrimitive::PRINT_EXPR:
stream << "PRINT_EXPR";
break;
default:
RELEASE_ASSERT(0, "%d", node->opcode);
}
......
......@@ -746,9 +746,11 @@ private:
if (node->op_type == AST_TYPE::Or) {
br->iftrue = crit_break_block;
br->iffalse = next_block;
} else {
} else if (node->op_type == AST_TYPE::And) {
br->iffalse = crit_break_block;
br->iftrue = next_block;
} else {
RELEASE_ASSERT(0, "");
}
curblock = crit_break_block;
......
......@@ -1635,7 +1635,7 @@ void setupFloat() {
_addFunc("__rdiv__", BOXED_FLOAT, (void*)floatRDivFloat, (void*)floatRDivInt, (void*)floatRDiv);
_addFunc("__floordiv__", BOXED_FLOAT, (void*)floatFloorDivFloat, (void*)floatFloorDivInt, (void*)floatFloorDiv);
float_cls->giveAttr("__rfloordiv__",
new BoxedFunction(FunctionMetadata::create((void*)floatRFloorDiv, BOXED_FLOAT, 2)));
new BoxedFunction(FunctionMetadata::create((void*)floatRFloorDiv, UNKNOWN, 2)));
_addFunc("__truediv__", BOXED_FLOAT, (void*)floatDivFloat, (void*)floatDivInt, (void*)floatTruediv);
float_cls->giveAttr("__rtruediv__", new BoxedFunction(FunctionMetadata::create((void*)floatRTruediv, UNKNOWN, 2)));
......
......@@ -2,6 +2,16 @@
# Doesn't test much of the functionality, but even importing the module is tough:
import datetime
def typeErrorTest(val):
try:
x = datetime.timedelta(43)
x // val
except TypeError as e:
return True
return False
print repr(datetime.time())
print datetime.datetime.__base__
print repr(datetime.datetime(1, 2, 3))
......@@ -11,3 +21,8 @@ print str(datetime.timedelta(0))
datetime.datetime.now().now()
print datetime.datetime(1924, 2, 3).strftime("%B %d, %Y - %X")
a = 3
b = 3.4
assert not typeErrorTest(a)
assert typeErrorTest(b)
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