// Copyright (c) 2012 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. #include "content/common/media/media_stream_options.h" #include "base/logging.h" namespace content { const char kMediaStreamSource[] = "chromeMediaSource"; const char kMediaStreamSourceId[] = "chromeMediaSourceId"; const char kMediaStreamSourceInfoId[] = "sourceId"; const char kMediaStreamSourceTab[] = "tab"; const char kMediaStreamSourceScreen[] = "screen"; const char kMediaStreamSourceDesktop[] = "desktop"; const char kMediaStreamSourceSystem[] = "system"; const char kMediaStreamRenderToAssociatedSink[] = "chromeRenderToAssociatedSink"; namespace { bool GetFirstConstraintByName(const StreamOptions::Constraints& constraints, const std::string& name, std::string* value) { for (StreamOptions::Constraints::const_iterator it = constraints.begin(); it != constraints.end(); ++it ) { if (it->name == name) { *value = it->value; return true; } } return false; } bool GetFirstConstraintByName(const StreamOptions::Constraints& mandatory, const StreamOptions::Constraints& optional, const std::string& name, std::string* value, bool* is_mandatory) { if (GetFirstConstraintByName(mandatory, name, value)) { if (is_mandatory) *is_mandatory = true; return true; } if (is_mandatory) *is_mandatory = false; return GetFirstConstraintByName(optional, name, value); } } // namespace StreamOptions::StreamOptions() : audio_requested(false), video_requested(false) {} StreamOptions::StreamOptions(bool request_audio, bool request_video) : audio_requested(request_audio), video_requested(request_video) { } StreamOptions::~StreamOptions() {} StreamOptions::Constraint::Constraint() {} StreamOptions::Constraint::Constraint(const std::string& name, const std::string& value) : name(name), value(value) { } bool StreamOptions::GetFirstAudioConstraintByName(const std::string& name, std::string* value, bool* is_mandatory) const { return GetFirstConstraintByName(mandatory_audio, optional_audio, name, value, is_mandatory); } bool StreamOptions::GetFirstVideoConstraintByName(const std::string& name, std::string* value, bool* is_mandatory) const { return GetFirstConstraintByName(mandatory_video, optional_video, name, value, is_mandatory); } // static void StreamOptions::GetConstraintsByName( const StreamOptions::Constraints& constraints, const std::string& name, std::vector<std::string>* values) { for (StreamOptions::Constraints::const_iterator it = constraints.begin(); it != constraints.end(); ++it ) { if (it->name == name) values->push_back(it->value); } } // static const int StreamDeviceInfo::kNoId = -1; StreamDeviceInfo::StreamDeviceInfo() : session_id(kNoId) {} StreamDeviceInfo::StreamDeviceInfo(MediaStreamType service_param, const std::string& name_param, const std::string& device_param) : device(service_param, device_param, name_param), session_id(kNoId) { } StreamDeviceInfo::StreamDeviceInfo(MediaStreamType service_param, const std::string& name_param, const std::string& device_param, int sample_rate, int channel_layout, int frames_per_buffer) : device(service_param, device_param, name_param, sample_rate, channel_layout, frames_per_buffer), session_id(kNoId) { } // static bool StreamDeviceInfo::IsEqual(const StreamDeviceInfo& first, const StreamDeviceInfo& second) { return first.device.IsEqual(second.device) && first.session_id == second.session_id; } } // namespace content