[skottie] Fix assert for missing layer type
When the layer type is missing, fType == -1 and we rely on unsigned (size_t) underflow + check against the known types array size to catch the condition. The problem is SkToSizeT() itself asserts the input is a valid size_t, and even if it didn't clusterfuzz would likely complain about underflowing. Refactor to check for negative values explicitly. Bug: b/200660146 Change-Id: Iae74dca14ac0202ffcdd4449f0d470063916eff5 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/493116 Reviewed-by: Kevin Lubick <kjlubick@google.com> Commit-Queue: Florin Malita <fmalita@google.com>
This commit is contained in:
parent
2e6181cac4
commit
3e1354a592
@ -450,12 +450,11 @@ sk_sp<sksg::RenderNode> LayerBuilder::buildRenderTree(const AnimationBuilder& ab
|
|||||||
{ nullptr , 0 }, // 'ty': 14 -> light
|
{ nullptr , 0 }, // 'ty': 14 -> light
|
||||||
};
|
};
|
||||||
|
|
||||||
const auto type = SkToSizeT(fType);
|
if (fType < 0 || static_cast<size_t>(fType) >= SK_ARRAY_COUNT(gLayerBuildInfo)) {
|
||||||
if (type >= SK_ARRAY_COUNT(gLayerBuildInfo)) {
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto& build_info = gLayerBuildInfo[type];
|
const auto& build_info = gLayerBuildInfo[fType];
|
||||||
|
|
||||||
// Switch to the layer animator scope (which at this point holds transform-only animators).
|
// Switch to the layer animator scope (which at this point holds transform-only animators).
|
||||||
AnimationBuilder::AutoScope ascope(&abuilder, std::move(fLayerScope));
|
AnimationBuilder::AutoScope ascope(&abuilder, std::move(fLayerScope));
|
||||||
|
@ -861,3 +861,29 @@ DEF_TEST(Skottie_Image_Loading, reporter) {
|
|||||||
REPORTER_ASSERT(reporter, SkScalarNearlyEqual(multi_asset->requestedFrames()[1], 2));
|
REPORTER_ASSERT(reporter, SkScalarNearlyEqual(multi_asset->requestedFrames()[1], 2));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DEF_TEST(Skottie_Layer_NoType, r) {
|
||||||
|
static constexpr char json[] =
|
||||||
|
R"({
|
||||||
|
"v": "5.2.1",
|
||||||
|
"w": 100,
|
||||||
|
"h": 100,
|
||||||
|
"fr": 10,
|
||||||
|
"ip": 0,
|
||||||
|
"op": 100,
|
||||||
|
"layers": [
|
||||||
|
{
|
||||||
|
"ind": 0,
|
||||||
|
"ip": 0,
|
||||||
|
"op": 100,
|
||||||
|
"ks": {}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
})";
|
||||||
|
|
||||||
|
SkMemoryStream stream(json, strlen(json));
|
||||||
|
auto anim = Animation::Make(&stream);
|
||||||
|
|
||||||
|
// passes if we don't crash
|
||||||
|
REPORTER_ASSERT(r, anim);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user