mirror of
https://github.com/SerenityOS/serenity
synced 2024-09-20 00:12:20 +00:00
57e19a7e56
When trying to figure out the correct implementation, we now have a very strong distinction on plugins that are well suited for sniffing, and plugins that need a MIME type to be chosen. Instead of having multiple calls to non-static virtual sniff methods for each Image decoding plugin, we have 2 static methods for each implementation: 1. The sniff method, which in contrast to the old method, gets a ReadonlyBytes parameter and ensures we can figure out the result with zero heap allocations for most implementations. 2. The create method, which just creates a new instance so we don't expose the constructor to everyone anymore. In addition to that, we have a new virtual method called initialize, which has a per-implementation initialization pattern to actually ensure each implementation can construct a decoder object, and then have a correct context being applied to it for the actual decoding. |
||
---|---|---|
.. | ||
BenchmarkGfxPainter.cpp | ||
CMakeLists.txt | ||
TestFont.font | ||
TestFontHandling.cpp | ||
TestImageDecoder.cpp |