1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6 #ifndef mozilla_image_DecoderFlags_h
7 #define mozilla_image_DecoderFlags_h
9 #include "mozilla/TypedEnumBits.h"
15 * Flags that influence decoder behavior. Note that these flags *don't*
16 * influence the logical content of the surfaces that the decoder generates, so
17 * they're not in a factor in SurfaceCache lookups and the like. These flags
18 * instead either influence which surfaces are generated at all or the tune the
19 * decoder's behavior for a particular scenario.
21 enum class DecoderFlags
: uint8_t {
22 FIRST_FRAME_ONLY
= 1 << 0,
24 IMAGE_IS_TRANSIENT
= 1 << 2,
25 ASYNC_NOTIFY
= 1 << 3,
28 * By default, a surface is considered substitutable. That means callers are
29 * willing to accept a less than ideal match to display. If a caller requires
30 * a specific size and won't accept alternatives, then this flag should be
33 CANNOT_SUBSTITUTE
= 1 << 4,
36 // The flags below are stored in RasterImage to allow a decoded image to
37 // remain consistent in whether it is animated or not.
39 // Set according to the "image.avif.sequence.enabled" preference.
40 AVIF_SEQUENCES_ENABLED
= 1 << 5,
41 // Set according to the
42 // "image.avif.sequence.animate_avif_major_branded_images" preference.
43 AVIF_ANIMATE_AVIF_MAJOR
= 1 << 6,
46 MOZ_MAKE_ENUM_CLASS_BITWISE_OPERATORS(DecoderFlags
)
49 * @return the default set of decode flags.
51 inline DecoderFlags
DefaultDecoderFlags() { return DecoderFlags(); }
54 } // namespace mozilla
56 #endif // mozilla_image_DecoderFlags_h