blob: d62115e31f4028f8bc17b6261b7d9af1f5ab21be [file] [log] [blame]
// Copyright (c) 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef MEDIA_FILTERS_STREAM_PARSER_FACTORY_H_
#define MEDIA_FILTERS_STREAM_PARSER_FACTORY_H_
#include <memory>
#include <string>
#include <vector>
#include "media/base/media_export.h"
#include "media/base/media_log.h"
namespace media {
class StreamParser;
class MEDIA_EXPORT StreamParserFactory {
public:
// Checks to see if the specified |type| and |codecs| list are supported.
// Returns true if |type| and all codecs listed in |codecs| are supported.
static bool IsTypeSupported(
const std::string& type, const std::vector<std::string>& codecs);
// Creates a new StreamParser object if the specified |type| and |codecs| list
// are supported. |media_log| can be used to report errors if there is
// something wrong with |type| or the codec IDs in |codecs|.
// Returns a new StreamParser object if |type| and all codecs listed in
// |codecs| are supported.
// |has_audio| is true if an audio codec was specified.
// |has_video| is true if a video codec was specified.
// Returns NULL otherwise. The values of |has_audio| and |has_video| are
// undefined.
static std::unique_ptr<StreamParser> Create(
const std::string& type,
const std::vector<std::string>& codecs,
const scoped_refptr<MediaLog>& media_log,
bool* has_audio,
bool* has_video);
};
} // namespace media
#endif // MEDIA_FILTERS_STREAM_PARSER_FACTORY_H_