mirror of https://github.com/python/cpython.git
printobject now returns an error code
This commit is contained in:
parent
909336104b
commit
d783a46d73
|
@ -162,7 +162,7 @@ typedef struct _typeobject {
|
|||
/* Methods to implement standard operations */
|
||||
|
||||
void (*tp_dealloc) FPROTO((object *));
|
||||
void (*tp_print) FPROTO((object *, FILE *, int));
|
||||
int (*tp_print) FPROTO((object *, FILE *, int));
|
||||
object *(*tp_getattr) FPROTO((object *, char *));
|
||||
int (*tp_setattr) FPROTO((object *, char *, object *));
|
||||
int (*tp_compare) FPROTO((object *, object *));
|
||||
|
@ -180,7 +180,7 @@ extern typeobject Typetype; /* The type of type objects */
|
|||
#define is_typeobject(op) ((op)->ob_type == &Typetype)
|
||||
|
||||
/* Generic operations on objects */
|
||||
extern void printobject PROTO((object *, FILE *, int));
|
||||
extern int printobject PROTO((object *, FILE *, int));
|
||||
extern object * reprobject PROTO((object *));
|
||||
extern int cmpobject PROTO((object *, object *));
|
||||
extern object *getattr PROTO((object *, char *));
|
||||
|
|
|
@ -1286,13 +1286,14 @@ window_dealloc(wp)
|
|||
free((char *)wp);
|
||||
}
|
||||
|
||||
static void
|
||||
static int
|
||||
window_print(wp, fp, flags)
|
||||
windowobject *wp;
|
||||
FILE *fp;
|
||||
int flags;
|
||||
{
|
||||
fprintf(fp, "<window titled '%s'>", getstringvalue(wp->w_title));
|
||||
return 0;
|
||||
}
|
||||
|
||||
static object *
|
||||
|
|
|
@ -289,10 +289,12 @@ print_error()
|
|||
object *exception, *v;
|
||||
err_get(&exception, &v);
|
||||
fprintf(stderr, "Unhandled exception: ");
|
||||
printobject(exception, stderr, PRINT_RAW);
|
||||
if (printobject(exception, stderr, PRINT_RAW) != 0)
|
||||
err_clear();
|
||||
if (v != NULL && v != None) {
|
||||
fprintf(stderr, ": ");
|
||||
printobject(v, stderr, PRINT_RAW);
|
||||
if (printobject(v, stderr, PRINT_RAW) != 0)
|
||||
err_clear();
|
||||
}
|
||||
fprintf(stderr, "\n");
|
||||
XDECREF(exception);
|
||||
|
|
|
@ -186,12 +186,14 @@ tb_printinternal(tb, fp)
|
|||
FILE *fp;
|
||||
{
|
||||
while (tb != NULL) {
|
||||
if (intrcheck()) {
|
||||
fprintf(fp, "[interrupted]\n");
|
||||
if (intrcheck())
|
||||
break;
|
||||
fprintf(fp, " File \"");
|
||||
if (printobject(tb->tb_frame->f_code->co_filename,
|
||||
fp, PRINT_RAW) != 0) {
|
||||
err_clear();
|
||||
break;
|
||||
}
|
||||
fprintf(fp, " File \"");
|
||||
printobject(tb->tb_frame->f_code->co_filename, fp, PRINT_RAW);
|
||||
fprintf(fp, "\", line %d\n", tb->tb_lineno);
|
||||
tb_displayline(fp,
|
||||
getstringvalue(tb->tb_frame->f_code->co_filename),
|
||||
|
|
Loading…
Reference in New Issue