OLD | NEW |
1 # Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 2 # Use of this source code is governed by a BSD-style license that can be |
3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
4 | 4 |
5 source_set("system") { | 5 source_set("system") { |
6 sources = [ | 6 sources = [ |
7 "../../platform/native/system_thunks.cc", | 7 "../../platform/native/system_thunks.cc", |
8 "../../platform/native/system_thunks.h", | 8 "../../platform/native/system_thunks.h", |
9 "buffer.h", | 9 "buffer.h", |
10 "core.h", | 10 "core.h", |
11 "data_pipe.h", | 11 "data_pipe.h", |
12 "functions.h", | 12 "functions.h", |
13 "macros.h", | 13 "macros.h", |
14 "message_pipe.h", | 14 "message_pipe.h", |
15 "system_export.h", | 15 "system_export.h", |
16 "types.h", | 16 "types.h", |
17 ] | 17 ] |
18 defines = [ "MOJO_SYSTEM_IMPLEMENTATION" ] | 18 defines = [ "MOJO_SYSTEM_IMPLEMENTATION" ] |
19 | 19 |
20 # The GYP target analogous to this one builds this code into a | 20 # The GYP target analogous to this one builds this code into a |
21 # static library. When building for Android, both the GYP and GN | 21 # static library. When building for Android, both the GYP and GN |
22 # builds add --exclude-libs=ALL globally, which means that all | 22 # builds add --exclude-libs=ALL globally, which means that all |
23 # symbols in static libraries are excluded from export. That's a | 23 # symbols in static libraries are excluded from export. That's a |
24 # problem, as code outside this target needs to be able to call | 24 # problem, as code outside this target needs to be able to call |
25 # MojoSetSystemThunks(). Therefore, the GYP target needs to specifiy | 25 # MojoSetSystemThunks(). Therefore, the GYP target needs to specifiy |
26 # that all dependent targets remove that link flag. Since GN uses a | 26 # that all dependent targets remove that link flag. Since GN uses a |
27 # source_set here, this flag change is not needed. | 27 # source_set here, this flag change is not needed. |
28 } | 28 } |
| 29 |
| 30 # In an is_component_build build, everything can link against //mojo/system |
| 31 # because it is built as a shared library. However, in a static build, |
| 32 # //mojo/system is linked into an executable (e.g., mojo_shell), and must be |
| 33 # injected into other shared libraries (i.e., Mojo Apps) that need the mojo |
| 34 # system API. |
| 35 # |
| 36 # For component targets, add //mojo/public/c/system:for_component to your deps |
| 37 # section. |
| 38 # |
| 39 # For shared_library targets (e.g., a Mojo App), add |
| 40 # //mojo/public/c/system:for_shared_library to your deps |
| 41 |
| 42 group("for_shared_library") { |
| 43 if (is_component_build) { |
| 44 deps = [ "//mojo/system" ] |
| 45 } else { |
| 46 deps = [ ":system" ] |
| 47 } |
| 48 } |
| 49 |
| 50 group("for_component") { |
| 51 if (is_component_build) { |
| 52 deps = [ "//mojo/system" ] |
| 53 } |
| 54 } |
OLD | NEW |