GNU Binutils with patches for OS216
Revision | 800eb1cebe736f6867d13e5df40a2c463a4b23ad (tree) |
---|---|
Time | 2015-02-11 22:40:14 |
Author | Jan Kratochvil <jan.kratochvil@redh...> |
Commiter | Jan Kratochvil |
framefilter quit: Code cleanup: Avoid gotos
goto error patters are sometimes AFAIK used in C for the cases like:
int retval=-1;
if (!(a=malloc())) goto error;
if (!(b=malloc())) goto error_a;
if (!(c=malloc())) goto error_b;
retval=0;
error_c: free(c);
error_b: free(b);
error_a: free(a);
error: return retval;
But here there is single error label with one do_cleanups() which I do not find
it worth the goto complication. Without goto one can then furher merge code in
the exit paths in the next patches and ... after all it is all the same, just
without a goto.
gdb/ChangeLog
2015-02-11 Jan Kratochvil <jan.kratochvil@redhat.com>
* python/py-framefilter.c (py_print_frame): Substitute goto error.
Remove the error label.
@@ -1,5 +1,10 @@ | ||
1 | 1 | 2015-02-11 Jan Kratochvil <jan.kratochvil@redhat.com> |
2 | 2 | |
3 | + * python/py-framefilter.c (py_print_frame): Substitute goto error. | |
4 | + Remove the error label. | |
5 | + | |
6 | +2015-02-11 Jan Kratochvil <jan.kratochvil@redhat.com> | |
7 | + | |
3 | 8 | * python/py-framefilter.c (py_print_frame): Put conditional code paths |
4 | 9 | with goto first, indent the former else codepath left. Put variable |
5 | 10 | 'elided' to a new inner block. |
@@ -1033,14 +1033,20 @@ py_print_frame (PyObject *filter, int flags, | ||
1033 | 1033 | read them if they returned filter object requires us to do so. */ |
1034 | 1034 | py_inf_frame = PyObject_CallMethod (filter, "inferior_frame", NULL); |
1035 | 1035 | if (py_inf_frame == NULL) |
1036 | - goto error; | |
1036 | + { | |
1037 | + do_cleanups (cleanup_stack); | |
1038 | + return EXT_LANG_BT_ERROR; | |
1039 | + } | |
1037 | 1040 | |
1038 | 1041 | frame = frame_object_to_frame_info (py_inf_frame);; |
1039 | 1042 | |
1040 | 1043 | Py_DECREF (py_inf_frame); |
1041 | 1044 | |
1042 | 1045 | if (frame == NULL) |
1043 | - goto error; | |
1046 | + { | |
1047 | + do_cleanups (cleanup_stack); | |
1048 | + return EXT_LANG_BT_ERROR; | |
1049 | + } | |
1044 | 1050 | |
1045 | 1051 | TRY_CATCH (except, RETURN_MASK_ALL) |
1046 | 1052 | { |
@@ -1049,7 +1055,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1049 | 1055 | if (except.reason < 0) |
1050 | 1056 | { |
1051 | 1057 | gdbpy_convert_exception (except); |
1052 | - goto error; | |
1058 | + do_cleanups (cleanup_stack); | |
1059 | + return EXT_LANG_BT_ERROR; | |
1053 | 1060 | } |
1054 | 1061 | |
1055 | 1062 | /* stack-list-variables. */ |
@@ -1057,7 +1064,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1057 | 1064 | { |
1058 | 1065 | if (py_mi_print_variables (filter, out, &opts, |
1059 | 1066 | args_type, frame) == EXT_LANG_BT_ERROR) |
1060 | - goto error; | |
1067 | + { | |
1068 | + do_cleanups (cleanup_stack); | |
1069 | + return EXT_LANG_BT_ERROR; | |
1070 | + } | |
1061 | 1071 | do_cleanups (cleanup_stack); |
1062 | 1072 | return EXT_LANG_BT_COMPLETED; |
1063 | 1073 | } |
@@ -1080,7 +1090,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1080 | 1090 | if (except.reason < 0) |
1081 | 1091 | { |
1082 | 1092 | gdbpy_convert_exception (except); |
1083 | - goto error; | |
1093 | + do_cleanups (cleanup_stack); | |
1094 | + return EXT_LANG_BT_ERROR; | |
1084 | 1095 | } |
1085 | 1096 | } |
1086 | 1097 |
@@ -1091,7 +1102,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1091 | 1102 | PyObject *paddr = PyObject_CallMethod (filter, "address", NULL); |
1092 | 1103 | |
1093 | 1104 | if (paddr == NULL) |
1094 | - goto error; | |
1105 | + { | |
1106 | + do_cleanups (cleanup_stack); | |
1107 | + return EXT_LANG_BT_ERROR; | |
1108 | + } | |
1095 | 1109 | |
1096 | 1110 | if (paddr != Py_None) |
1097 | 1111 | { |
@@ -1135,7 +1149,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1135 | 1149 | if (except.reason < 0) |
1136 | 1150 | { |
1137 | 1151 | gdbpy_convert_exception (except); |
1138 | - goto error; | |
1152 | + do_cleanups (cleanup_stack); | |
1153 | + return EXT_LANG_BT_ERROR; | |
1139 | 1154 | } |
1140 | 1155 | } |
1141 | 1156 |
@@ -1155,7 +1170,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1155 | 1170 | if (except.reason < 0) |
1156 | 1171 | { |
1157 | 1172 | gdbpy_convert_exception (except); |
1158 | - goto error; | |
1173 | + do_cleanups (cleanup_stack); | |
1174 | + return EXT_LANG_BT_ERROR; | |
1159 | 1175 | } |
1160 | 1176 | } |
1161 | 1177 |
@@ -1166,7 +1182,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1166 | 1182 | const char *function = NULL; |
1167 | 1183 | |
1168 | 1184 | if (py_func == NULL) |
1169 | - goto error; | |
1185 | + { | |
1186 | + do_cleanups (cleanup_stack); | |
1187 | + return EXT_LANG_BT_ERROR; | |
1188 | + } | |
1170 | 1189 | |
1171 | 1190 | if (gdbpy_is_string (py_func)) |
1172 | 1191 | { |
@@ -1178,7 +1197,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1178 | 1197 | if (function == NULL) |
1179 | 1198 | { |
1180 | 1199 | Py_DECREF (py_func); |
1181 | - goto error; | |
1200 | + do_cleanups (cleanup_stack); | |
1201 | + return EXT_LANG_BT_ERROR; | |
1182 | 1202 | } |
1183 | 1203 | make_cleanup (xfree, function_to_free); |
1184 | 1204 | } |
@@ -1188,7 +1208,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1188 | 1208 | struct bound_minimal_symbol msymbol; |
1189 | 1209 | |
1190 | 1210 | if (PyErr_Occurred ()) |
1191 | - goto error; | |
1211 | + { | |
1212 | + do_cleanups (cleanup_stack); | |
1213 | + return EXT_LANG_BT_ERROR; | |
1214 | + } | |
1192 | 1215 | |
1193 | 1216 | msymbol = lookup_minimal_symbol_by_pc (addr); |
1194 | 1217 | if (msymbol.minsym != NULL) |
@@ -1200,7 +1223,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1200 | 1223 | _("FrameDecorator.function: expecting a " \ |
1201 | 1224 | "String, integer or None.")); |
1202 | 1225 | Py_DECREF (py_func); |
1203 | - goto error; | |
1226 | + do_cleanups (cleanup_stack); | |
1227 | + return EXT_LANG_BT_ERROR; | |
1204 | 1228 | } |
1205 | 1229 | |
1206 | 1230 | TRY_CATCH (except, RETURN_MASK_ALL) |
@@ -1215,7 +1239,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1215 | 1239 | { |
1216 | 1240 | Py_DECREF (py_func); |
1217 | 1241 | gdbpy_convert_exception (except); |
1218 | - goto error; | |
1242 | + do_cleanups (cleanup_stack); | |
1243 | + return EXT_LANG_BT_ERROR; | |
1219 | 1244 | } |
1220 | 1245 | Py_DECREF (py_func); |
1221 | 1246 | } |
@@ -1227,7 +1252,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1227 | 1252 | if (print_args) |
1228 | 1253 | { |
1229 | 1254 | if (py_print_args (filter, out, args_type, frame) == EXT_LANG_BT_ERROR) |
1230 | - goto error; | |
1255 | + { | |
1256 | + do_cleanups (cleanup_stack); | |
1257 | + return EXT_LANG_BT_ERROR; | |
1258 | + } | |
1231 | 1259 | } |
1232 | 1260 | |
1233 | 1261 | /* File name/source/line number information. */ |
@@ -1240,7 +1268,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1240 | 1268 | if (except.reason < 0) |
1241 | 1269 | { |
1242 | 1270 | gdbpy_convert_exception (except); |
1243 | - goto error; | |
1271 | + do_cleanups (cleanup_stack); | |
1272 | + return EXT_LANG_BT_ERROR; | |
1244 | 1273 | } |
1245 | 1274 | |
1246 | 1275 | if (PyObject_HasAttrString (filter, "filename")) |
@@ -1248,7 +1277,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1248 | 1277 | PyObject *py_fn = PyObject_CallMethod (filter, "filename", NULL); |
1249 | 1278 | |
1250 | 1279 | if (py_fn == NULL) |
1251 | - goto error; | |
1280 | + { | |
1281 | + do_cleanups (cleanup_stack); | |
1282 | + return EXT_LANG_BT_ERROR; | |
1283 | + } | |
1252 | 1284 | |
1253 | 1285 | if (py_fn != Py_None) |
1254 | 1286 | { |
@@ -1257,7 +1289,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1257 | 1289 | if (filename == NULL) |
1258 | 1290 | { |
1259 | 1291 | Py_DECREF (py_fn); |
1260 | - goto error; | |
1292 | + do_cleanups (cleanup_stack); | |
1293 | + return EXT_LANG_BT_ERROR; | |
1261 | 1294 | } |
1262 | 1295 | |
1263 | 1296 | make_cleanup (xfree, filename); |
@@ -1273,7 +1306,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1273 | 1306 | { |
1274 | 1307 | Py_DECREF (py_fn); |
1275 | 1308 | gdbpy_convert_exception (except); |
1276 | - goto error; | |
1309 | + do_cleanups (cleanup_stack); | |
1310 | + return EXT_LANG_BT_ERROR; | |
1277 | 1311 | } |
1278 | 1312 | } |
1279 | 1313 | Py_DECREF (py_fn); |
@@ -1285,7 +1319,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1285 | 1319 | int line; |
1286 | 1320 | |
1287 | 1321 | if (py_line == NULL) |
1288 | - goto error; | |
1322 | + { | |
1323 | + do_cleanups (cleanup_stack); | |
1324 | + return EXT_LANG_BT_ERROR; | |
1325 | + } | |
1289 | 1326 | |
1290 | 1327 | if (py_line != Py_None) |
1291 | 1328 | { |
@@ -1300,7 +1337,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1300 | 1337 | { |
1301 | 1338 | Py_DECREF (py_line); |
1302 | 1339 | gdbpy_convert_exception (except); |
1303 | - goto error; | |
1340 | + do_cleanups (cleanup_stack); | |
1341 | + return EXT_LANG_BT_ERROR; | |
1304 | 1342 | } |
1305 | 1343 | } |
1306 | 1344 | Py_DECREF (py_line); |
@@ -1319,7 +1357,8 @@ py_print_frame (PyObject *filter, int flags, | ||
1319 | 1357 | if (except.reason < 0) |
1320 | 1358 | { |
1321 | 1359 | gdbpy_convert_exception (except); |
1322 | - goto error; | |
1360 | + do_cleanups (cleanup_stack); | |
1361 | + return EXT_LANG_BT_ERROR; | |
1323 | 1362 | } |
1324 | 1363 | } |
1325 | 1364 |
@@ -1327,7 +1366,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1327 | 1366 | { |
1328 | 1367 | if (py_print_locals (filter, out, args_type, indent, |
1329 | 1368 | frame) == EXT_LANG_BT_ERROR) |
1330 | - goto error; | |
1369 | + { | |
1370 | + do_cleanups (cleanup_stack); | |
1371 | + return EXT_LANG_BT_ERROR; | |
1372 | + } | |
1331 | 1373 | } |
1332 | 1374 | |
1333 | 1375 | { |
@@ -1336,7 +1378,10 @@ py_print_frame (PyObject *filter, int flags, | ||
1336 | 1378 | /* Finally recursively print elided frames, if any. */ |
1337 | 1379 | elided = get_py_iter_from_func (filter, "elided"); |
1338 | 1380 | if (elided == NULL) |
1339 | - goto error; | |
1381 | + { | |
1382 | + do_cleanups (cleanup_stack); | |
1383 | + return EXT_LANG_BT_ERROR; | |
1384 | + } | |
1340 | 1385 | |
1341 | 1386 | make_cleanup_py_decref (elided); |
1342 | 1387 | if (elided != Py_None) |
@@ -1358,23 +1403,23 @@ py_print_frame (PyObject *filter, int flags, | ||
1358 | 1403 | if (success == EXT_LANG_BT_ERROR) |
1359 | 1404 | { |
1360 | 1405 | Py_DECREF (item); |
1361 | - goto error; | |
1406 | + do_cleanups (cleanup_stack); | |
1407 | + return EXT_LANG_BT_ERROR; | |
1362 | 1408 | } |
1363 | 1409 | |
1364 | 1410 | Py_DECREF (item); |
1365 | 1411 | } |
1366 | 1412 | if (item == NULL && PyErr_Occurred ()) |
1367 | - goto error; | |
1413 | + { | |
1414 | + do_cleanups (cleanup_stack); | |
1415 | + return EXT_LANG_BT_ERROR; | |
1416 | + } | |
1368 | 1417 | } |
1369 | 1418 | } |
1370 | 1419 | |
1371 | 1420 | |
1372 | 1421 | do_cleanups (cleanup_stack); |
1373 | 1422 | return EXT_LANG_BT_COMPLETED; |
1374 | - | |
1375 | - error: | |
1376 | - do_cleanups (cleanup_stack); | |
1377 | - return EXT_LANG_BT_ERROR; | |
1378 | 1423 | } |
1379 | 1424 | |
1380 | 1425 | /* Helper function to initiate frame filter invocation at starting |