summaryrefslogtreecommitdiffstats
path: root/build/ios/mac_build.gypi
blob: cbdbc79d17f08b3785b8d87732f3cf1deb9a288e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# 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.

# Xcode throws an error if an iOS target depends on a Mac OS X target. So
# any place a utility program needs to be build and run, an action is
# used to run ninja as script to work around this.
# Example:
# {
#   'target_name': 'foo',
#   'type': 'none',
#   'variables': {
#     # The name of a directory used for ninja. This cannot be shared with
#     # another mac build.
#     'ninja_output_dir': 'ninja-foo',
#     # The full path to the location in which the ninja executable should be
#     # placed. This cannot be shared with another mac build.
#    'ninja_product_dir':
#      '<(DEPTH)/xcodebuild/<(ninja_output_dir)/<(CONFIGURATION_NAME)',
#     # The list of all the gyp files that contain the targets to run.
#     're_run_targets': [
#       'foo.gyp',
#     ],
#   },
#   'includes': ['path_to/mac_build.gypi'],
#   'actions': [
#     {
#       'action_name': 'compile foo',
#       'inputs': [],
#       'outputs': [],
#       'action': [
#         '<@(ninja_cmd)',
#         # All the targets to build.
#         'foo1',
#         'foo2',
#       ],
#     },
#   ],
# }
{
  'variables': {
    'variables': {
     'parent_generator%': '<(GENERATOR)',
    },
    'parent_generator%': '<(parent_generator)',
    # Common ninja command line flags.
    'ninja_cmd': [
      # Bounce through clean_env to clean up the environment so things
      # set by the iOS build don't pollute the Mac build.
      '<(DEPTH)/build/ios/clean_env.py',
      # ninja must be found in the PATH.
      'ADD_TO_PATH=<!(echo $PATH)',
      'ninja',
      '-C',
      '<(ninja_product_dir)',
    ],

    # Common syntax to rerun gyp to generate the Mac projects.
    're_run_gyp': [
      'build/gyp_chromium',
      '--depth=.',
      # Don't use anything set for the iOS side of things.
      '--ignore-environment',
      # Generate for ninja
      '--format=ninja',
      # Generate files into xcodebuild/ninja
      '-Goutput_dir=xcodebuild/<(ninja_output_dir)',
      # nacl isn't in the iOS checkout, make sure it's turned off
      '-Ddisable_nacl=1',
      # Add a variable to handle specific cases for mac_build.
      '-Dios_mac_build=1',
      # Pass through the Mac SDK version.
      '-Dmac_sdk=<(mac_sdk)',
      '-Dparent_generator=<(parent_generator)'
    ],

    # Rerun gyp for each of the projects needed. This is what actually
    # generates the projects on disk.
    're_run_gyp_execution':
      '<!(cd <(DEPTH) && <@(re_run_gyp) <@(re_run_targets))',
  },
  # Since these are used to generate things needed by other targets, make
  # them hard dependencies so they are always built first.
  'hard_dependency': 1,
}