Commit 83aae4d
committed
fix: resolve memory leaks causing VSCode crashes with hierarchical tasks
- Enhanced task disposal coordination with timeout protection in ClineProvider
- Added comprehensive error handling to ensure cleanup always succeeds
- Implemented defensive programming to clear task hierarchy references
- Improved resource cleanup verification with ensureTaskDisposal method
- Added clearTaskReferences method to break potential circular references
- Made disposal methods idempotent to prevent multiple disposal attempts
- Enhanced Task.dispose() with timeout protection and comprehensive cleanup
- Added isDisposed flag to prevent resource leaks from repeated disposal calls
Fixes #5768: VSCode crashes when using Roo for extended periods with hierarchical child tasks1 parent d513b9c commit 83aae4d
2 files changed
+209
-56
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1021 | 1021 | | |
1022 | 1022 | | |
1023 | 1023 | | |
1024 | | - | |
1025 | | - | |
1026 | | - | |
1027 | | - | |
| 1024 | + | |
| 1025 | + | |
| 1026 | + | |
| 1027 | + | |
1028 | 1028 | | |
| 1029 | + | |
| 1030 | + | |
| 1031 | + | |
| 1032 | + | |
| 1033 | + | |
| 1034 | + | |
| 1035 | + | |
| 1036 | + | |
1029 | 1037 | | |
1030 | | - | |
1031 | 1038 | | |
| 1039 | + | |
| 1040 | + | |
| 1041 | + | |
| 1042 | + | |
| 1043 | + | |
| 1044 | + | |
1032 | 1045 | | |
1033 | | - | |
1034 | | - | |
1035 | | - | |
1036 | | - | |
| 1046 | + | |
| 1047 | + | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
1037 | 1052 | | |
1038 | | - | |
1039 | | - | |
1040 | | - | |
1041 | | - | |
1042 | | - | |
| 1053 | + | |
| 1054 | + | |
| 1055 | + | |
| 1056 | + | |
| 1057 | + | |
1043 | 1058 | | |
1044 | | - | |
1045 | | - | |
1046 | | - | |
1047 | | - | |
1048 | | - | |
| 1059 | + | |
| 1060 | + | |
| 1061 | + | |
| 1062 | + | |
| 1063 | + | |
1049 | 1064 | | |
1050 | | - | |
1051 | | - | |
1052 | | - | |
1053 | | - | |
| 1065 | + | |
| 1066 | + | |
| 1067 | + | |
| 1068 | + | |
| 1069 | + | |
| 1070 | + | |
| 1071 | + | |
| 1072 | + | |
1054 | 1073 | | |
1055 | | - | |
1056 | | - | |
1057 | | - | |
1058 | | - | |
1059 | 1074 | | |
1060 | | - | |
1061 | | - | |
| 1075 | + | |
| 1076 | + | |
| 1077 | + | |
| 1078 | + | |
| 1079 | + | |
| 1080 | + | |
| 1081 | + | |
| 1082 | + | |
| 1083 | + | |
| 1084 | + | |
| 1085 | + | |
| 1086 | + | |
| 1087 | + | |
| 1088 | + | |
| 1089 | + | |
| 1090 | + | |
| 1091 | + | |
| 1092 | + | |
| 1093 | + | |
| 1094 | + | |
| 1095 | + | |
| 1096 | + | |
| 1097 | + | |
| 1098 | + | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
| 1102 | + | |
| 1103 | + | |
| 1104 | + | |
| 1105 | + | |
| 1106 | + | |
| 1107 | + | |
| 1108 | + | |
| 1109 | + | |
| 1110 | + | |
| 1111 | + | |
| 1112 | + | |
| 1113 | + | |
| 1114 | + | |
| 1115 | + | |
| 1116 | + | |
| 1117 | + | |
1062 | 1118 | | |
1063 | | - | |
| 1119 | + | |
| 1120 | + | |
| 1121 | + | |
1064 | 1122 | | |
| 1123 | + | |
1065 | 1124 | | |
| 1125 | + | |
| 1126 | + | |
| 1127 | + | |
| 1128 | + | |
1066 | 1129 | | |
1067 | | - | |
1068 | | - | |
1069 | | - | |
1070 | | - | |
| 1130 | + | |
| 1131 | + | |
| 1132 | + | |
| 1133 | + | |
| 1134 | + | |
| 1135 | + | |
| 1136 | + | |
1071 | 1137 | | |
1072 | | - | |
| 1138 | + | |
1073 | 1139 | | |
1074 | 1140 | | |
1075 | 1141 | | |
| 1142 | + | |
| 1143 | + | |
| 1144 | + | |
| 1145 | + | |
| 1146 | + | |
1076 | 1147 | | |
1077 | 1148 | | |
1078 | 1149 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
199 | 199 | | |
200 | 200 | | |
201 | 201 | | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
202 | 215 | | |
203 | 216 | | |
204 | 217 | | |
205 | 218 | | |
206 | 219 | | |
207 | 220 | | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
208 | 263 | | |
209 | 264 | | |
210 | 265 | | |
| |||
256 | 311 | | |
257 | 312 | | |
258 | 313 | | |
259 | | - | |
260 | | - | |
261 | 314 | | |
262 | | - | |
263 | | - | |
264 | | - | |
265 | | - | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
266 | 327 | | |
267 | | - | |
| 328 | + | |
| 329 | + | |
268 | 330 | | |
269 | | - | |
270 | | - | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
271 | 334 | | |
272 | | - | |
273 | | - | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
274 | 338 | | |
275 | | - | |
276 | 339 | | |
277 | | - | |
278 | | - | |
279 | | - | |
280 | | - | |
281 | | - | |
282 | | - | |
283 | | - | |
284 | | - | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
285 | 364 | | |
286 | | - | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
287 | 369 | | |
288 | 370 | | |
289 | 371 | | |
| |||
0 commit comments