mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-11-24 22:36:09 +03:00
220 lines
6.0 KiB
Plaintext
220 lines
6.0 KiB
Plaintext
# Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
|
|
#
|
|
# Use of this source code is governed by a BSD-style license
|
|
# that can be found in the LICENSE file in the root of the source
|
|
# tree. An additional intellectual property rights grant can be found
|
|
# in the file PATENTS. All contributing project authors may
|
|
# be found in the AUTHORS file in the root of the source tree.
|
|
|
|
import("../../webrtc.gni")
|
|
|
|
# Note this target is missing an implementation for the video capture.
|
|
# Targets must link with either 'video_capture' or
|
|
# 'video_capture_internal_impl' depending on whether they want to
|
|
# use the internal capturer.
|
|
rtc_static_library("video_capture_module") {
|
|
sources = [
|
|
"device_info_impl.cc",
|
|
"device_info_impl.h",
|
|
"video_capture.h",
|
|
"video_capture_config.h",
|
|
"video_capture_defines.h",
|
|
"video_capture_factory.cc",
|
|
"video_capture_factory.h",
|
|
"video_capture_impl.cc",
|
|
"video_capture_impl.h",
|
|
]
|
|
|
|
deps = [
|
|
"..:module_api",
|
|
"../..:webrtc_common",
|
|
"../../common_video",
|
|
"../../rtc_base:rtc_base_approved",
|
|
"../../system_wrappers",
|
|
]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
|
|
rtc_static_library("video_capture") {
|
|
sources = [
|
|
"external/device_info_external.cc",
|
|
"external/video_capture_external.cc",
|
|
]
|
|
|
|
deps = [
|
|
":video_capture_module",
|
|
"../../rtc_base:rtc_base_approved",
|
|
"../../system_wrappers",
|
|
]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
|
|
if (!build_with_chromium) {
|
|
config("video_capture_internal_impl_config") {
|
|
if (is_ios || is_mac) {
|
|
libs = [
|
|
"AVFoundation.framework",
|
|
"CoreMedia.framework",
|
|
"CoreVideo.framework",
|
|
]
|
|
}
|
|
}
|
|
|
|
config("video_capture_internal_impl_warnings_config") {
|
|
if (is_win && is_clang) {
|
|
cflags = [
|
|
"-Wno-comment",
|
|
"-Wno-ignored-attributes",
|
|
|
|
# See https://bugs.chromium.org/p/webrtc/issues/detail?id=6269
|
|
# for -Wno-ignored-qualifiers
|
|
"-Wno-ignored-qualifiers",
|
|
"-Wno-microsoft-extra-qualification",
|
|
"-Wno-missing-braces",
|
|
"-Wno-overloaded-virtual",
|
|
"-Wno-reorder",
|
|
"-Wno-writable-strings",
|
|
]
|
|
}
|
|
}
|
|
|
|
if (is_ios || is_mac) {
|
|
rtc_source_set("video_capture_internal_impl_objc") {
|
|
visibility = [ ":video_capture_internal_impl" ]
|
|
configs += [ ":video_capture_internal_impl_warnings_config" ]
|
|
|
|
deps = [
|
|
":video_capture_module",
|
|
"../../rtc_base:rtc_base_approved",
|
|
"../../system_wrappers",
|
|
]
|
|
|
|
sources = [
|
|
"objc/device_info.h",
|
|
"objc/device_info.mm",
|
|
"objc/device_info_objc.h",
|
|
"objc/device_info_objc.mm",
|
|
"objc/rtc_video_capture_objc.h",
|
|
"objc/rtc_video_capture_objc.mm",
|
|
"objc/video_capture.h",
|
|
"objc/video_capture.mm",
|
|
]
|
|
|
|
all_dependent_configs = [ ":video_capture_internal_impl_config" ]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
}
|
|
|
|
rtc_source_set("video_capture_internal_impl") {
|
|
configs += [ ":video_capture_internal_impl_warnings_config" ]
|
|
|
|
deps = [
|
|
":video_capture_module",
|
|
"../../rtc_base:rtc_base_approved",
|
|
"../../system_wrappers",
|
|
]
|
|
|
|
if (is_linux) {
|
|
sources = [
|
|
"linux/device_info_linux.cc",
|
|
"linux/device_info_linux.h",
|
|
"linux/video_capture_linux.cc",
|
|
"linux/video_capture_linux.h",
|
|
]
|
|
deps += [
|
|
"../..:webrtc_common",
|
|
"../../media:rtc_media_base",
|
|
]
|
|
}
|
|
if (is_win) {
|
|
sources = [
|
|
"windows/device_info_ds.cc",
|
|
"windows/device_info_ds.h",
|
|
"windows/device_info_mf.cc",
|
|
"windows/device_info_mf.h",
|
|
"windows/help_functions_ds.cc",
|
|
"windows/help_functions_ds.h",
|
|
"windows/sink_filter_ds.cc",
|
|
"windows/sink_filter_ds.h",
|
|
"windows/video_capture_ds.cc",
|
|
"windows/video_capture_ds.h",
|
|
"windows/video_capture_factory_windows.cc",
|
|
"windows/video_capture_mf.cc",
|
|
"windows/video_capture_mf.h",
|
|
]
|
|
|
|
libs = [ "Strmiids.lib" ]
|
|
|
|
deps += [ "//third_party/winsdk_samples" ]
|
|
}
|
|
if (is_ios || is_mac) {
|
|
deps += [ ":video_capture_internal_impl_objc" ]
|
|
}
|
|
|
|
all_dependent_configs = [ ":video_capture_internal_impl_config" ]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
|
|
if (!is_android && rtc_include_tests) {
|
|
rtc_test("video_capture_tests") {
|
|
sources = [
|
|
"test/video_capture_unittest.cc",
|
|
]
|
|
|
|
cflags = []
|
|
if (is_linux || is_mac) {
|
|
cflags += [ "-Wno-write-strings" ]
|
|
}
|
|
|
|
ldflags = []
|
|
if (is_linux || is_mac) {
|
|
ldflags += [
|
|
"-lpthread",
|
|
"-lm",
|
|
]
|
|
}
|
|
if (is_linux) {
|
|
ldflags += [
|
|
"-lrt",
|
|
"-lXext",
|
|
"-lX11",
|
|
]
|
|
}
|
|
|
|
deps = [
|
|
":video_capture_internal_impl",
|
|
":video_capture_module",
|
|
"../../common_video:common_video",
|
|
"../../rtc_base:rtc_base_approved",
|
|
"../../system_wrappers:system_wrappers",
|
|
"../../system_wrappers:system_wrappers_default",
|
|
"../../test:video_test_common",
|
|
"../utility",
|
|
"//testing/gtest",
|
|
]
|
|
deps += [ "../../test:test_main" ]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
}
|
|
}
|