Reland "Remove SkTLList"

This reverts commit 14b1d56a2b2b8f0ffcb62180382b7347673aaa11.

Reason for revert: fix emplace_back() usage

Original change's description:
> Revert "Remove SkTLList"
>
> This reverts commit e1d523d70fec3b3d24fef6da4a823c52092b6c77.
>
> Reason for revert: breaking old stdlib versions (< c17)
>
> Original change's description:
> > Remove SkTLList
> >
> > Change-Id: I198678b5cb298cf51872fbb8d4fd5d705a6b684e
> > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/437339
> > Reviewed-by: Brian Osman <brianosman@google.com>
> > Commit-Queue: Michael Ludwig <michaelludwig@google.com>
>
> TBR=brianosman@google.com,michaelludwig@google.com,skcq-be@skia-corp.google.com.iam.gserviceaccount.com
>
> Change-Id: I8e02e4cd2f293e7530f842be783de10f69be2ef4
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/438078
> Reviewed-by: Michael Ludwig <michaelludwig@google.com>
> Commit-Queue: Michael Ludwig <michaelludwig@google.com>

# Not skipping CQ checks because this is a reland.

Change-Id: Ied33ce81a8312963ff0713c4660cdb8541a02180
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/438080
Commit-Queue: Michael Ludwig <michaelludwig@google.com>
Reviewed-by: Brian Osman <brianosman@google.com>
diff --git a/gm/convexpolyeffect.cpp b/gm/convexpolyeffect.cpp
index 7485293..05747dc 100644
--- a/gm/convexpolyeffect.cpp
+++ b/gm/convexpolyeffect.cpp
@@ -20,7 +20,6 @@
 #include "include/core/SkString.h"
 #include "include/private/GrTypesPriv.h"
 #include "src/core/SkCanvasPriv.h"
-#include "src/core/SkTLList.h"
 #include "src/gpu/GrFragmentProcessor.h"
 #include "src/gpu/GrPaint.h"
 #include "src/gpu/effects/GrConvexPolyEffect.h"
@@ -56,11 +55,12 @@
         tri.lineTo(100.f, 20.f);
         tri.lineTo(15.f, 100.f);
 
-        fPaths.addToTail(tri);
-        fPaths.addToTail(SkPath())->reverseAddPath(tri);
+        fPaths.push_back(tri);
+        fPaths.emplace_back();
+        fPaths.back().reverseAddPath(tri);
 
         tri.close();
-        fPaths.addToTail(tri);
+        fPaths.push_back(tri);
 
         SkPath ngon;
         constexpr SkScalar kRadius = 50.f;
@@ -77,16 +77,16 @@
             }
         }
 
-        fPaths.addToTail(ngon);
+        fPaths.push_back(ngon);
         SkMatrix scaleM;
         scaleM.setScale(1.1f, 0.4f);
         ngon.transform(scaleM);
-        fPaths.addToTail(ngon);
+        fPaths.push_back(ngon);
 
         SkPath linePath;
         linePath.moveTo(5.f, 5.f);
         linePath.lineTo(6.f, 6.f);
-        fPaths.addToTail(linePath);
+        fPaths.push_back(linePath);
     }
 
     DrawResult onDraw(GrRecordingContext* rContext, SkCanvas* canvas, SkString* errorMsg) override {
@@ -100,16 +100,13 @@
         static constexpr SkScalar kDX = 12.f;
         static constexpr SkScalar kOutset = 5.f;
 
-        for (PathList::Iter iter(fPaths, PathList::Iter::kHead_IterStart);
-             iter.get();
-             iter.next()) {
-            const SkPath* path = iter.get();
+        for (const SkPath& path : fPaths) {
             SkScalar x = 0;
 
             for (int et = 0; et < kGrClipEdgeTypeCnt; ++et) {
                 const SkMatrix m = SkMatrix::Translate(x, y);
                 SkPath p;
-                path->transform(m, &p);
+                path.transform(m, &p);
 
                 GrClipEdgeType edgeType = (GrClipEdgeType) et;
                 auto [success, fp] = GrConvexPolyEffect::Make(/*inputFP=*/nullptr, edgeType, p);
@@ -125,28 +122,27 @@
                 auto op = sk_gpu_test::test_ops::MakeRect(rContext, std::move(grPaint), rect);
                 sdc->addDrawOp(std::move(op));
 
-                x += SkScalarCeilToScalar(path->getBounds().width() + kDX);
+                x += SkScalarCeilToScalar(path.getBounds().width() + kDX);
             }
 
             // Draw AA and non AA paths using normal API for reference.
             canvas->save();
             canvas->translate(x, y);
             SkPaint paint;
-            canvas->drawPath(*path, paint);
-            canvas->translate(path->getBounds().width() + 10.f, 0);
+            canvas->drawPath(path, paint);
+            canvas->translate(path.getBounds().width() + 10.f, 0);
             paint.setAntiAlias(true);
-            canvas->drawPath(*path, paint);
+            canvas->drawPath(path, paint);
             canvas->restore();
 
-            y += SkScalarCeilToScalar(path->getBounds().height() + 20.f);
+            y += SkScalarCeilToScalar(path.getBounds().height() + 20.f);
         }
 
         return DrawResult::kOk;
     }
 
 private:
-    typedef SkTLList<SkPath, 1> PathList;
-    PathList fPaths;
+    std::vector<SkPath> fPaths;
 
     using INHERITED = GM;
 };