Browse Source

prevent stack leak (see #7667)

ncannasse 6 years ago
parent
commit
d944bc40b1
1 changed files with 1 additions and 2 deletions
  1. 1 2
      src/context/abstractCast.ml

+ 1 - 2
src/context/abstractCast.ml

@@ -28,8 +28,7 @@ let do_check_cast ctx tleft eright p =
 	let recurse cf f =
 		if cf == ctx.curfield || List.mem cf !cast_stack then error "Recursive implicit cast" p;
 		cast_stack := cf :: !cast_stack;
-		let r = f() in
-		cast_stack := List.tl !cast_stack;
+		let r = Std.finally (fun() -> cast_stack := List.tl !cast_stack) f () in
 		r
 	in
 	let find a tl f =