mirror of
https://github.com/python/cpython.git
synced 2025-08-15 22:30:42 +00:00
Merged revisions 82169 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r82169 | antoine.pitrou | 2010-06-22 23:42:05 +0200 (mar., 22 juin 2010) | 4 lines Fix misindents in compile.c (for Benjamin). Of course, whoever used the wrong indentation rules needs to be spanked. ........
This commit is contained in:
parent
8d6496385d
commit
c31616d558
1 changed files with 38 additions and 38 deletions
|
@ -995,7 +995,7 @@ compiler_addop_o(struct compiler *c, int opcode, PyObject *dict,
|
||||||
{
|
{
|
||||||
int arg = compiler_add_o(c, dict, o);
|
int arg = compiler_add_o(c, dict, o);
|
||||||
if (arg < 0)
|
if (arg < 0)
|
||||||
return 0;
|
return 0;
|
||||||
return compiler_addop_i(c, opcode, arg);
|
return compiler_addop_i(c, opcode, arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1006,11 +1006,11 @@ compiler_addop_name(struct compiler *c, int opcode, PyObject *dict,
|
||||||
int arg;
|
int arg;
|
||||||
PyObject *mangled = _Py_Mangle(c->u->u_private, o);
|
PyObject *mangled = _Py_Mangle(c->u->u_private, o);
|
||||||
if (!mangled)
|
if (!mangled)
|
||||||
return 0;
|
return 0;
|
||||||
arg = compiler_add_o(c, dict, mangled);
|
arg = compiler_add_o(c, dict, mangled);
|
||||||
Py_DECREF(mangled);
|
Py_DECREF(mangled);
|
||||||
if (arg < 0)
|
if (arg < 0)
|
||||||
return 0;
|
return 0;
|
||||||
return compiler_addop_i(c, opcode, arg);
|
return compiler_addop_i(c, opcode, arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1161,7 +1161,7 @@ static int
|
||||||
compiler_isdocstring(stmt_ty s)
|
compiler_isdocstring(stmt_ty s)
|
||||||
{
|
{
|
||||||
if (s->kind != Expr_kind)
|
if (s->kind != Expr_kind)
|
||||||
return 0;
|
return 0;
|
||||||
return s->v.Expr.value->kind == Str_kind;
|
return s->v.Expr.value->kind == Str_kind;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1267,11 +1267,11 @@ compiler_lookup_arg(PyObject *dict, PyObject *name)
|
||||||
PyObject *k, *v;
|
PyObject *k, *v;
|
||||||
k = PyTuple_Pack(2, name, name->ob_type);
|
k = PyTuple_Pack(2, name, name->ob_type);
|
||||||
if (k == NULL)
|
if (k == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
v = PyDict_GetItem(dict, k);
|
v = PyDict_GetItem(dict, k);
|
||||||
Py_DECREF(k);
|
Py_DECREF(k);
|
||||||
if (v == NULL)
|
if (v == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
return PyInt_AS_LONG(v);
|
return PyInt_AS_LONG(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2866,35 +2866,35 @@ compiler_with(struct compiler *c, stmt_ty s)
|
||||||
assert(s->kind == With_kind);
|
assert(s->kind == With_kind);
|
||||||
|
|
||||||
if (!enter_attr) {
|
if (!enter_attr) {
|
||||||
enter_attr = PyString_InternFromString("__enter__");
|
enter_attr = PyString_InternFromString("__enter__");
|
||||||
if (!enter_attr)
|
if (!enter_attr)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (!exit_attr) {
|
if (!exit_attr) {
|
||||||
exit_attr = PyString_InternFromString("__exit__");
|
exit_attr = PyString_InternFromString("__exit__");
|
||||||
if (!exit_attr)
|
if (!exit_attr)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
block = compiler_new_block(c);
|
block = compiler_new_block(c);
|
||||||
finally = compiler_new_block(c);
|
finally = compiler_new_block(c);
|
||||||
if (!block || !finally)
|
if (!block || !finally)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (s->v.With.optional_vars) {
|
if (s->v.With.optional_vars) {
|
||||||
/* Create a temporary variable to hold context.__enter__().
|
/* Create a temporary variable to hold context.__enter__().
|
||||||
We need to do this rather than preserving it on the stack
|
We need to do this rather than preserving it on the stack
|
||||||
because SETUP_FINALLY remembers the stack level.
|
because SETUP_FINALLY remembers the stack level.
|
||||||
We need to do the assignment *inside* the try/finally
|
We need to do the assignment *inside* the try/finally
|
||||||
so that context.__exit__() is called when the assignment
|
so that context.__exit__() is called when the assignment
|
||||||
fails. But we need to call context.__enter__() *before*
|
fails. But we need to call context.__enter__() *before*
|
||||||
the try/finally so that if it fails we won't call
|
the try/finally so that if it fails we won't call
|
||||||
context.__exit__().
|
context.__exit__().
|
||||||
*/
|
*/
|
||||||
tmpvalue = compiler_new_tmpname(c);
|
tmpvalue = compiler_new_tmpname(c);
|
||||||
if (tmpvalue == NULL)
|
if (tmpvalue == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
PyArena_AddPyObject(c->c_arena, tmpvalue);
|
PyArena_AddPyObject(c->c_arena, tmpvalue);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Evaluate EXPR */
|
/* Evaluate EXPR */
|
||||||
|
@ -2910,13 +2910,13 @@ compiler_with(struct compiler *c, stmt_ty s)
|
||||||
ADDOP_I(c, CALL_FUNCTION, 0);
|
ADDOP_I(c, CALL_FUNCTION, 0);
|
||||||
|
|
||||||
if (s->v.With.optional_vars) {
|
if (s->v.With.optional_vars) {
|
||||||
/* Store it in tmpvalue */
|
/* Store it in tmpvalue */
|
||||||
if (!compiler_nameop(c, tmpvalue, Store))
|
if (!compiler_nameop(c, tmpvalue, Store))
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* Discard result from context.__enter__() */
|
/* Discard result from context.__enter__() */
|
||||||
ADDOP(c, POP_TOP);
|
ADDOP(c, POP_TOP);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Start the try block */
|
/* Start the try block */
|
||||||
|
@ -2924,15 +2924,15 @@ compiler_with(struct compiler *c, stmt_ty s)
|
||||||
|
|
||||||
compiler_use_next_block(c, block);
|
compiler_use_next_block(c, block);
|
||||||
if (!compiler_push_fblock(c, FINALLY_TRY, block)) {
|
if (!compiler_push_fblock(c, FINALLY_TRY, block)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s->v.With.optional_vars) {
|
if (s->v.With.optional_vars) {
|
||||||
/* Bind saved result of context.__enter__() to VAR */
|
/* Bind saved result of context.__enter__() to VAR */
|
||||||
if (!compiler_nameop(c, tmpvalue, Load) ||
|
if (!compiler_nameop(c, tmpvalue, Load) ||
|
||||||
!compiler_nameop(c, tmpvalue, Del))
|
!compiler_nameop(c, tmpvalue, Del))
|
||||||
return 0;
|
return 0;
|
||||||
VISIT(c, expr, s->v.With.optional_vars);
|
VISIT(c, expr, s->v.With.optional_vars);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* BLOCK code */
|
/* BLOCK code */
|
||||||
|
@ -2945,7 +2945,7 @@ compiler_with(struct compiler *c, stmt_ty s)
|
||||||
ADDOP_O(c, LOAD_CONST, Py_None, consts);
|
ADDOP_O(c, LOAD_CONST, Py_None, consts);
|
||||||
compiler_use_next_block(c, finally);
|
compiler_use_next_block(c, finally);
|
||||||
if (!compiler_push_fblock(c, FINALLY_END, finally))
|
if (!compiler_push_fblock(c, FINALLY_END, finally))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* Finally block starts; context.__exit__ is on the stack under
|
/* Finally block starts; context.__exit__ is on the stack under
|
||||||
the exception or return information. Just issue our magic
|
the exception or return information. Just issue our magic
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue