Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1123)

Unified Diff: content/public/browser/desktop_media_id.cc

Issue 1503563004: Desktop chrome tab capture-chooseDesktopMedia() (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/public/browser/desktop_media_id.cc
diff --git a/content/public/browser/desktop_media_id.cc b/content/public/browser/desktop_media_id.cc
index 523c61d39bc696c912a50f7253076bf912091354..e727be0480e39dcd3c18355a64e534d6ec2c2085 100644
--- a/content/public/browser/desktop_media_id.cc
+++ b/content/public/browser/desktop_media_id.cc
@@ -82,7 +82,7 @@ const char kWindowPrefix[] = "window";
// static
DesktopMediaID DesktopMediaID::RegisterAuraWindow(DesktopMediaID::Type type,
aura::Window* window) {
- DCHECK(type == TYPE_SCREEN || type == TYPE_WINDOW);
+ DCHECK(type == TYPE_SCREEN || type == TYPE_WINDOW || type == TYPE_TAB);
DCHECK(window);
DesktopMediaID media_id(type, kNullId);
media_id.aura_id = AuraWindowRegistry::GetInstance()->RegisterWindow(window);
@@ -96,45 +96,81 @@ aura::Window* DesktopMediaID::GetAuraWindowById(const DesktopMediaID& id) {
#endif // defined(USE_AURA)
+bool DesktopMediaID::operator<(const DesktopMediaID& other) const {
+#if defined(USE_AURA)
+ return std::tie(type, id, aura_id, tab_id) <
+ std::tie(other.type, other.id, other.aura_id, other.tab_id);
+#else
+ return std::tie(type, id, tab_id) < std::tie(other.type, other.id, tab_id);
+#endif
+}
+
+bool DesktopMediaID::operator==(const DesktopMediaID& other) const {
+#if defined(USE_AURA)
+ return type == other.type && id == other.id && aura_id == other.aura_id &&
+ tab_id == other.tab_id;
+#else
+ return type == other.type && id == other.id && tab_id == other.tab_id;
+#endif
+}
+
// static
+// Input string should in format:
+// for tab: web-contents-media-stream://"render_process_id":"render_process_id"
+// for no tab and aura: screen:"window_id" or window:"window_id"
+// for no tab and no aura: screen:"window_id:aura_id" or
+// window:"window_id:aura_id".
DesktopMediaID DesktopMediaID::Parse(const std::string& str) {
std::vector<std::string> parts = base::SplitString(
str, ":", base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL);
-#if defined(USE_AURA)
- if (parts.size() != 3)
- return DesktopMediaID();
-#else
- if (parts.size() != 2)
+ if (parts.size() < 2)
return DesktopMediaID();
-#endif
Type type = TYPE_NONE;
if (parts[0] == kScreenPrefix) {
type = TYPE_SCREEN;
} else if (parts[0] == kWindowPrefix) {
type = TYPE_WINDOW;
+ } else if (parts[0] == kWebContentsCaptureScheme) {
+ type = TYPE_TAB;
Avi (use Gerrit) 2016/01/11 16:27:57 Yeah, the TYPE_WEB_CONTENTS fits better here.
GeorgeZ 2016/01/11 19:16:19 Done.
} else {
return DesktopMediaID();
}
- int64_t id;
- if (!base::StringToInt64(parts[1], &id))
+ // Tab type.
+ if (type == TYPE_TAB) {
+ WebContentsMediaCaptureId temp_id = WebContentsMediaCaptureId::Parse(str);
+ return DesktopMediaID(type, 0, temp_id);
+ }
+
+// Screen and window types.
+#if defined(USE_AURA)
+ if (parts.size() != 3)
+ return DesktopMediaID();
+#else
+ if (parts.size() != 2)
+ return DesktopMediaID();
+#endif // defined(USE_AURA)
+
+ int64_t tempid;
+ if (!base::StringToInt64(parts[1], &tempid))
return DesktopMediaID();
- DesktopMediaID media_id(type, id);
+ DesktopMediaID media_id(type, tempid);
#if defined(USE_AURA)
int64_t aura_id;
if (!base::StringToInt64(parts[2], &aura_id))
return DesktopMediaID();
+
media_id.aura_id = aura_id;
#endif // defined(USE_AURA)
return media_id;
}
-std::string DesktopMediaID::ToString() {
+std::string DesktopMediaID::ToString() const {
std::string prefix;
switch (type) {
case TYPE_NONE:
@@ -146,9 +182,13 @@ std::string DesktopMediaID::ToString() {
case TYPE_WINDOW:
prefix = kWindowPrefix;
break;
+ case TYPE_TAB:
+ return tab_id.ToString();
+ break;
}
DCHECK(!prefix.empty());
+ // Screen and Window types.
prefix.append(":");
prefix.append(base::Int64ToString(id));

Powered by Google App Engine
This is Rietveld 408576698