1diff --git a/third_party/agg23/agg_math_stroke.h b/third_party/agg23/agg_math_stroke.h
2index 6d7ba8a..2b06b1b 100644
3--- a/third_party/agg23/agg_math_stroke.h
4+++ b/third_party/agg23/agg_math_stroke.h
5@@ -60,28 +60,30 @@ void stroke_calc_arc(VertexConsumer& out_vertices,
6     }
7     da = acos(width / (width + ((1.0f / 8) / approximation_scale))) * 2;
8     out_vertices.add(coord_type(x + dx1, y + dy1));
9-    if(!ccw) {
10-        if(a1 > a2) {
11-            a2 += 2 * FX_PI;
12+    if (da > 0) {
13+      if (!ccw) {
14+        if (a1 > a2) {
15+          a2 += 2 * FX_PI;
16         }
17         a2 -= da / 4;
18         a1 += da;
19-        while(a1 < a2) {
20+        while (a1 < a2) {
21           out_vertices.add(coord_type(x + (width * cos(a1)),
22                                       y + (width * sin(a1))));
23-            a1 += da;
24+          a1 += da;
25         }
26-    } else {
27-        if(a1 < a2) {
28-            a2 -= 2 * FX_PI;
29+      } else {
30+        if (a1 < a2) {
31+          a2 -= 2 * FX_PI;
32         }
33         a2 += da / 4;
34         a1 -= da;
35-        while(a1 > a2) {
36+        while (a1 > a2) {
37           out_vertices.add(coord_type(x + (width * cos(a1)),
38                                       y + (width * sin(a1))));
39-            a1 -= da;
40+          a1 -= da;
41         }
42+      }
43     }
44     out_vertices.add(coord_type(x + dx2, y + dy2));
45 }
46