[Android WebView] Fix webview perf bot switchover to use org.chromium.webview_shell...
[chromium-blink-merge.git] / content / common / BUILD.gn
blob09f7a4a989204e33a05aad18fa063f18163d780e
1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
5 import("//build/config/features.gni")
6 import("//build/config/ui.gni")
7 import("//content/common/common.gni")
8 import("//third_party/mojo/src/mojo/public/tools/bindings/mojom.gni")
10 if (is_chromeos && current_cpu != "arm") {
11   action("libva_generate_stubs") {
12     extra_header = "gpu/media/va_stub_header.fragment"
14     script = "../../tools/generate_stubs/generate_stubs.py"
15     sources = [
16       "gpu/media/va.sigs",
17     ]
18     inputs = [
19       extra_header,
20     ]
21     if (use_x11) {
22       sources += [ "gpu/media/va_x11.sigs" ]
23     }
24     if (use_ozone) {
25       sources += [ "gpu/media/va_drm.sigs" ]
26     }
27     stubs_filename_root = "va_stubs"
29     outputs = [
30       "$target_gen_dir/gpu/media/$stubs_filename_root.cc",
31       "$target_gen_dir/gpu/media/$stubs_filename_root.h",
32     ]
33     args = [
34       "-i",
35       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
36       "-o",
37       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
38       "-t",
39       "posix_stubs",
40       "-e",
41       rebase_path(extra_header, root_build_dir),
42       "-s",
43       stubs_filename_root,
44       "-p",
45       "content/common/gpu/media",
46     ]
48     args += rebase_path(sources, root_build_dir)
49   }
52 if (is_chromeos && use_v4lplugin) {
53   action("libv4l2_generate_stubs") {
54     extra_header = "gpu/media/v4l2_stub_header.fragment"
56     script = "../../tools/generate_stubs/generate_stubs.py"
57     sources = [
58       "gpu/media/v4l2.sig",
59     ]
60     inputs = [
61       extra_header,
62     ]
63     stubs_filename_root = "v4l2_stubs"
65     outputs = [
66       "$target_gen_dir/gpu/media/$stubs_filename_root.cc",
67       "$target_gen_dir/gpu/media/$stubs_filename_root.h",
68     ]
69     args = [
70       "-i",
71       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
72       "-o",
73       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
74       "-t",
75       "posix_stubs",
76       "-e",
77       rebase_path(extra_header, root_build_dir),
78       "-s",
79       stubs_filename_root,
80       "-p",
81       "content/common/gpu/media",
82     ]
84     args += rebase_path(sources, root_build_dir)
85   }
88 if (is_mac) {
89   action("libvt_generate_stubs") {
90     extra_header = "gpu/media/vt_stubs_header.fragment"
92     script = "../../tools/generate_stubs/generate_stubs.py"
93     sources = [
94       "gpu/media/vt.sig",
95     ]
96     inputs = [
97       extra_header,
98     ]
99     stubs_filename_root = "vt_stubs"
101     outputs = [
102       "$target_gen_dir/gpu/media/$stubs_filename_root.cc",
103       "$target_gen_dir/gpu/media/$stubs_filename_root.h",
104     ]
105     args = [
106       "-i",
107       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
108       "-o",
109       rebase_path("$target_gen_dir/gpu/media", root_build_dir),
110       "-t",
111       "posix_stubs",
112       "-e",
113       rebase_path(extra_header, root_build_dir),
114       "-s",
115       stubs_filename_root,
116       "-p",
117       "content/common/gpu/media",
118     ]
120     args += rebase_path(sources, root_build_dir)
121   }
124 source_set("common") {
125   # Only the public target should depend on this. All other targets (even
126   # internal content ones) should depend on the public one.
127   visibility = [ "//content/public/common:common_sources" ]
129   sources = rebase_path(content_common_gypi_values.private_common_sources,
130                         ".",
131                         "//content")
133   configs += [
134     "//content:content_implementation",
135     "//build/config/compiler:no_size_t_to_int_warning",
136   ]
138   public_deps = [
139     "//gpu/command_buffer/common",
140     "//third_party/WebKit/public:blink_headers",
141   ]
142   deps = [
143     "//base",
144     "//build/util:webkit_version",
145     "//components/tracing",
146     "//gpu/command_buffer/client:gles2_interface",
147     "//gpu/command_buffer/common:gles2_utils",
148     "//net",
149     "//skia",
150     "//third_party/icu",
151     "//ui/accessibility",
152     "//ui/base",
153     "//ui/base/ime",
154     "//ui/events/ipc",
155     "//ui/gfx",
156     "//ui/gfx/geometry",
157     "//ui/gfx/ipc",
158     "//ui/shell_dialogs",
159     "//url",
160     "//third_party/libjingle",
161   ]
163   if (!is_ios) {
164     deps += [
165       "//cc",
166       "//ipc",
167       "//ipc/mojo",
169       # TODO: the dependency on gl_in_process_context should be decoupled from
170       # content and moved to android_webview. See crbug.com/365797.
171       "//gpu/blink",
172       "//gpu/command_buffer/client:gl_in_process_context",
173       "//gpu/command_buffer/client:gles2_c_lib",
174       "//gpu/command_buffer/client:gles2_cmd_helper",
175       "//gpu/command_buffer/client:gles2_implementation",
176       "//gpu/command_buffer/service",
177       "//gpu/ipc",
178       "//gpu/skia_bindings",
179       "//media",
180       "//media/midi",
181       "//media:shared_memory_support",
182       "//mojo/application/public/interfaces",
183       "//mojo/environment:chromium",
184       "//sandbox",
185       "//storage/common",
186       "//third_party/WebKit/public:blink",
187       "//third_party/mojo/src/mojo/edk/system",
188       "//ui/gl",
189     ]
190   }
192   defines = []
193   include_dirs = []
194   libs = []
195   ldflags = []
197   if (is_android && use_seccomp_bpf) {
198     set_sources_assignment_filter([])
199     sources += [
200       "sandbox_linux/sandbox_bpf_base_policy_linux.cc",
201       "sandbox_linux/sandbox_bpf_base_policy_linux.h",
202     ]
203     set_sources_assignment_filter(sources_assignment_filter)
204   }
206   if (is_mac) {
207     sources += [
208                  "gpu/client/gpu_memory_buffer_impl_io_surface.cc",
209                  "gpu/client/gpu_memory_buffer_impl_io_surface.h",
210                  "gpu/gpu_memory_buffer_factory_io_surface.cc",
211                  "gpu/gpu_memory_buffer_factory_io_surface.h",
212                  "gpu/media/vt.h",
213                  "gpu/media/vt_video_decode_accelerator.cc",
214                  "gpu/media/vt_video_decode_accelerator.h",
215                ] + get_target_outputs(":libvt_generate_stubs")
217     sources -= [ "plugin_list_posix.cc" ]
219     deps += [
220       ":libvt_generate_stubs",
221       "//content/app/resources",
222       "//content:resources",
223       "//third_party/WebKit/public:image_resources",
224       "//third_party/WebKit/public:resources",
225       "//ui/accelerated_widget_mac",
226     ]
227     libs += [
228       "IOSurface.framework",
229       "OpenGL.framework",
230       "QuartzCore.framework",
231     ]
232   }
234   if (is_android) {
235     sources += [
236       "gpu/client/gpu_memory_buffer_impl_surface_texture.cc",
237       "gpu/client/gpu_memory_buffer_impl_surface_texture.h",
238       "gpu/gpu_memory_buffer_factory_surface_texture.cc",
239       "gpu/gpu_memory_buffer_factory_surface_texture.h",
240     ]
242     deps += [
243       "//content/public/android:jni",
244       "//content/public/android:common_aidl",
245     ]
247     libs += [ "android" ]
248   }
250   if (is_debug && !is_component_build) {
251     # Content depends on the PPAPI message logging stuff; if this isn't here,
252     # some unit test binaries won't compile. This only worked in release mode
253     # because logging is disabled there.
254     deps += [ "//ppapi/proxy:ipc_sources" ]
255   }
257   if (is_ios) {
258     sources -= [ "user_agent.cc" ]
259     assert(false, "Need to add lots of conditions here")
260   }
262   if (use_ozone) {
263     deps += [
264       "//ui/ozone:ozone",
265       "//ui/ozone:ozone_base",
266       "//ui/ozone/gpu",
267     ]
268   } else {
269     sources -= [
270       "cursors/webcursor_ozone.cc",
271       "font_list_ozone.cc",
272       "gpu/client/gpu_memory_buffer_impl_ozone_native_buffer.cc",
273       "gpu/client/gpu_memory_buffer_impl_ozone_native_buffer.h",
274       "gpu/gpu_memory_buffer_factory_ozone_native_buffer.cc",
275       "gpu/gpu_memory_buffer_factory_ozone_native_buffer.h",
276     ]
277   }
279   if (!use_aura) {
280     sources -= [ "cursors/webcursor_aura.cc" ]
281   }
283   if (!use_aura || !use_x11) {
284     sources -= [ "cursors/webcursor_aurax11.cc" ]
285   }
287   if (use_pango) {
288     configs += [ "//build/config/linux:pangocairo" ]
289     if (use_ozone) {
290       # If we're using pango, never use this ozone file (it was removed in all
291       # non-ozone cases above).
292       sources -= [ "font_list_ozone.cc" ]
293     }
294   } else {
295     sources -= [ "font_list_pango.cc" ]
296   }
298   if (use_x11) {
299     configs += [
300       "//build/config/linux:xcomposite",
301       "//third_party/khronos:khronos_headers",
302     ]
304     if (current_cpu != "arm" || !is_chromeos) {
305       sources += [ "gpu/x_util.h" ]
306     }
307   }
309   if (enable_plugins) {
310     deps += [ "//ppapi/shared_impl" ]
311   } else {
312     sources -= [
313       "pepper_file_util.cc",
314       "pepper_file_util.h",
315       "pepper_messages.h",
316       "pepper_plugin_list.cc",
317       "pepper_plugin_list.h",
318       "pepper_renderer_instance_data.cc",
319       "pepper_renderer_instance_data.h",
320       "plugin_list.cc",
321       "plugin_list.h",
322       "plugin_list_posix.cc",
323       "sandbox_util.cc",
324     ]
325   }
327   if (is_android) {
328     sources += [
329       "gpu/media/android_video_decode_accelerator.cc",
330       "gpu/media/android_video_decode_accelerator.h",
331     ]
333     if (enable_webrtc) {
334       deps += [ "//third_party/libyuv" ]
335     }
336   }
338   if (is_chromeos) {
339     sources += [
340       "gpu/media/accelerated_video_decoder.h",
341       "gpu/media/h264_decoder.cc",
342       "gpu/media/h264_decoder.h",
343       "gpu/media/h264_dpb.cc",
344       "gpu/media/h264_dpb.h",
345       "gpu/media/vp8_decoder.cc",
346       "gpu/media/vp8_decoder.h",
347       "gpu/media/vp8_picture.cc",
348       "gpu/media/vp8_picture.h",
349     ]
350     if (use_v4lplugin) {
351       defines += [ "USE_LIBV4L2" ]
352       sources += get_target_outputs(":libv4l2_generate_stubs")
353       deps += [ ":libv4l2_generate_stubs" ]
354     }
355     if (use_v4l2_codec) {
356       defines += [ "USE_V4L2_CODEC" ]
357       sources += [
358         "gpu/media/generic_v4l2_device.cc",
359         "gpu/media/generic_v4l2_device.h",
360         "gpu/media/v4l2_device.cc",
361         "gpu/media/v4l2_device.h",
362         "gpu/media/v4l2_image_processor.cc",
363         "gpu/media/v4l2_image_processor.h",
364         "gpu/media/v4l2_slice_video_decode_accelerator.cc",
365         "gpu/media/v4l2_slice_video_decode_accelerator.h",
366         "gpu/media/v4l2_video_decode_accelerator.cc",
367         "gpu/media/v4l2_video_decode_accelerator.h",
368         "gpu/media/v4l2_video_encode_accelerator.cc",
369         "gpu/media/v4l2_video_encode_accelerator.h",
370       ]
371       libs = [
372         "EGL",
373         "GLESv2",
374       ]
375     }
376     if (current_cpu == "arm") {
377       sources += [
378         "gpu/media/tegra_v4l2_device.cc",
379         "gpu/media/tegra_v4l2_device.h",
380       ]
381     }
382     if (current_cpu != "arm") {
383       sources += [
384                    "gpu/media/va_surface.h",
385                    "gpu/media/vaapi_picture.cc",
386                    "gpu/media/vaapi_picture.h",
387                    "gpu/media/vaapi_video_decode_accelerator.cc",
388                    "gpu/media/vaapi_video_decode_accelerator.h",
389                    "gpu/media/vaapi_video_encode_accelerator.cc",
390                    "gpu/media/vaapi_video_encode_accelerator.h",
391                    "gpu/media/vaapi_wrapper.cc",
392                    "gpu/media/vaapi_wrapper.h",
393                  ] + get_target_outputs(":libva_generate_stubs")
394       configs += [
395         "//third_party/libva:libva_config",
396         "//third_party/libyuv:libyuv_config",
397       ]
398       deps += [
399         ":libva_generate_stubs",
400         "//media",
401         "//third_party/libyuv",
402       ]
403       if (use_x11) {
404         sources += [
405           "gpu/media/vaapi_tfp_picture.cc",
406           "gpu/media/vaapi_tfp_picture.h",
407         ]
408       }
409       if (use_ozone) {
410         sources += [
411           "gpu/media/vaapi_drm_picture.cc",
412           "gpu/media/vaapi_drm_picture.h",
413         ]
414       }
415     }
416   }
418   if (is_win) {
419     sources += [
420       "gpu/media/dxva_video_decode_accelerator.cc",
421       "gpu/media/dxva_video_decode_accelerator.h",
422     ]
423     configs += [ "//third_party/khronos:khronos_headers" ]
424     deps += [ "//ui/gl" ]
425     libs += [
426       "d3d9.lib",
427       "d3d11.lib",
428       "dxva2.lib",
429       "strmiids.lib",
430       "mf.lib",
431       "mfplat.lib",
432       "mfuuid.lib",
433     ]
434     ldflags += [
435       "/DELAYLOAD:d3d9.dll",
436       "/DELAYLOAD:d3d11.dll",
437       "/DELAYLOAD:dxva2.dll",
438       "/DELAYLOAD:mf.dll",
439       "/DELAYLOAD:mfplat.dll",
440     ]
442     # TODO(GYP): extract_xinput action.
443   }
445   if (!is_win || !use_aura) {
446     sources -= [ "cursors/webcursor_aurawin.cc" ]
447   }
449   if (use_seccomp_bpf) {
450     defines += [ "USE_SECCOMP_BPF" ]
451   } else {
452     if (is_linux) {
453       sources -= [
454         "sandbox_linux/bpf_cros_arm_gpu_policy_linux.cc",
455         "sandbox_linux/bpf_cros_arm_gpu_policy_linux.h",
456         "sandbox_linux/bpf_gpu_policy_linux.cc",
457         "sandbox_linux/bpf_gpu_policy_linux.h",
458         "sandbox_linux/bpf_ppapi_policy_linux.cc",
459         "sandbox_linux/bpf_ppapi_policy_linux.h",
460         "sandbox_linux/bpf_renderer_policy_linux.cc",
461         "sandbox_linux/bpf_renderer_policy_linux.h",
462         "sandbox_linux/bpf_utility_policy_linux.cc",
463         "sandbox_linux/bpf_utility_policy_linux.h",
464         "sandbox_linux/sandbox_bpf_base_policy_linux.cc",
465         "sandbox_linux/sandbox_bpf_base_policy_linux.h",
466       ]
467     }
468     if (is_android) {
469       sources -= [
470         "sandbox_linux/android/sandbox_bpf_base_policy_android.cc",
471         "sandbox_linux/android/sandbox_bpf_base_policy_android.h",
472       ]
473     }
474   }
476   if (is_win && current_cpu == "x64") {
477     # TODO(jschuh): Remove this after crbug.com/173851 gets fixed.
478     cflags = [ "/bigobj" ]
479   }
482 mojom("mojo_bindings") {
483   sources = [
484     "application_setup.mojom",
485     "background_sync_service.mojom",
486     "geolocation_service.mojom",
487     "permission_service.mojom",
488     "presentation/presentation_service.mojom",
489     "process_control.mojom",
490     "render_frame_setup.mojom",
491   ]
493   import_dirs = [ "//mojo/services" ]
495   deps = [
496     "//content/public/common:mojo_bindings",
497     "//mojo/application/public/interfaces",
498   ]