gdiplus: Don't modify container list if container restoration fails.
diff --git a/dlls/gdiplus/graphics.c b/dlls/gdiplus/graphics.c
index b81a984..12f1e26 100644
--- a/dlls/gdiplus/graphics.c
+++ b/dlls/gdiplus/graphics.c
@@ -3400,7 +3400,7 @@
return NotImplemented;
}
-GpStatus WINGDIPAPI GdipEndContainer(GpGraphics *graphics, GraphicsState state)
+GpStatus WINGDIPAPI GdipEndContainer(GpGraphics *graphics, GraphicsContainer state)
{
GpStatus sts;
GraphicsContainerItem *container, *container2;
@@ -3419,6 +3419,10 @@
if(&container->entry == &graphics->containers)
return Ok;
+ sts = restore_container(graphics, container);
+ if(sts != Ok)
+ return sts;
+
/* remove all of the containers on top of the found container */
LIST_FOR_EACH_ENTRY_SAFE(container, container2, &graphics->containers, GraphicsContainerItem, entry){
if(container->contid == state)
@@ -3428,10 +3432,9 @@
}
list_remove(&container->entry);
- sts = restore_container(graphics, container);
delete_container(container);
- return sts;
+ return Ok;
}
GpStatus WINGDIPAPI GdipScaleWorldTransform(GpGraphics *graphics, REAL sx,