blob: 0e8148e1ab76d459a7064367cab861d58a654ebe [file] [log] [blame]
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef MEDIA_BASE_SUPPORTED_TYPES_H_
#define MEDIA_BASE_SUPPORTED_TYPES_H_
#include "base/containers/flat_set.h"
#include "media/base/media_export.h"
#include "media/base/media_types.h"
namespace media {
// These functions will attempt to delegate to MediaClient (when present) to
// describe what types of media are supported. When no MediaClient is provided,
// they will fall back to calling the Default functions below.
MEDIA_EXPORT bool IsSupportedAudioType(const AudioType& type);
MEDIA_EXPORT bool IsSupportedVideoType(const VideoType& type);
// These functions describe what media/ alone supports. They do not call out to
// MediaClient and do not describe media/ embedder customization. Callers should
// generally prefer the non-Default APIs above.
MEDIA_EXPORT bool IsDefaultSupportedAudioType(const AudioType& type);
MEDIA_EXPORT bool IsDefaultSupportedVideoType(const VideoType& type);
// This function describe if the specific video codec is a built into the binary
// or not.
MEDIA_EXPORT bool IsBuiltInVideoCodec(VideoCodec codec);
// This function lets the caller add additional codec profiles to those
// supported by default. Used primarily to add hardware codec profiles once
// support is known.
MEDIA_EXPORT void UpdateDefaultSupportedVideoProfiles(
const base::flat_set<VideoCodecProfile>& profiles);
} // namespace media
#endif // MEDIA_BASE_SUPPORTED_TYPES_H_