summaryrefslogtreecommitdiffstats
path: root/image/DecoderFlags.h
blob: 778cdd2942144284f633512bdabcc263ffa785e7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef mozilla_image_DecoderFlags_h
#define mozilla_image_DecoderFlags_h

#include "mozilla/TypedEnumBits.h"

namespace mozilla {
namespace image {

/**
 * Flags that influence decoder behavior. Note that these flags *don't*
 * influence the logical content of the surfaces that the decoder generates, so
 * they're not in a factor in SurfaceCache lookups and the like. These flags
 * instead either influence which surfaces are generated at all or the tune the
 * decoder's behavior for a particular scenario.
 */
enum class DecoderFlags : uint8_t {
  FIRST_FRAME_ONLY = 1 << 0,
  IS_REDECODE = 1 << 1,
  IMAGE_IS_TRANSIENT = 1 << 2,
  ASYNC_NOTIFY = 1 << 3,

  /**
   * By default, a surface is considered substitutable. That means callers are
   * willing to accept a less than ideal match to display. If a caller requires
   * a specific size and won't accept alternatives, then this flag should be
   * set.
   */
  CANNOT_SUBSTITUTE = 1 << 4,

#ifdef MOZ_AV1
  // The flags below are stored in RasterImage to allow a decoded image to
  // remain consistent in whether it is animated or not.

  // Set according to the "image.avif.sequence.enabled" preference.
  AVIF_SEQUENCES_ENABLED = 1 << 5,
  // Set according to the
  // "image.avif.sequence.animate_avif_major_branded_images" preference.
  AVIF_ANIMATE_AVIF_MAJOR = 1 << 6,
#endif
};
MOZ_MAKE_ENUM_CLASS_BITWISE_OPERATORS(DecoderFlags)

/**
 * @return the default set of decode flags.
 */
inline DecoderFlags DefaultDecoderFlags() { return DecoderFlags(); }

}  // namespace image
}  // namespace mozilla

#endif  // mozilla_image_DecoderFlags_h