Index: Source/platform/graphics/GraphicsContext.h |
diff --git a/Source/platform/graphics/GraphicsContext.h b/Source/platform/graphics/GraphicsContext.h |
index 0178d341b7c3bf99f85c3ec1ff175482359a8572..fd736a9a9d94f9ee6a0eeac2429cbd5b7ff670e7 100644 |
--- a/Source/platform/graphics/GraphicsContext.h |
+++ b/Source/platform/graphics/GraphicsContext.h |
@@ -462,11 +462,14 @@ private: |
if (m_paintState->saveCount()) { |
m_paintState->decrementSaveCount(); |
++m_paintStateIndex; |
- if (m_paintStateStack.size() == m_paintStateIndex) |
- m_paintStateStack.append(GraphicsContextState::create()); |
- GraphicsContextState* priorPaintState = m_paintState; |
- m_paintState = m_paintStateStack[m_paintStateIndex].get(); |
- m_paintState->copy(priorPaintState); |
+ if (m_paintStateStack.size() == m_paintStateIndex) { |
+ m_paintStateStack.append(GraphicsContextState::createAndCopy(*m_paintState)); |
+ m_paintState = m_paintStateStack[m_paintStateIndex].get(); |
+ } else { |
+ GraphicsContextState* priorPaintState = m_paintState; |
+ m_paintState = m_paintStateStack[m_paintStateIndex].get(); |
+ m_paintState->copy(*priorPaintState); |
+ } |
} |
} |