| OLD | NEW |
| 1 # Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2013 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 # TODO(brettw) Use "gcc_toolchain.gni" like the Linux toolchains. This requires | 5 # TODO(brettw) Use "gcc_toolchain.gni" like the Linux toolchains. This requires |
| 6 # some enhancements since the commands on Mac are slightly different than on | 6 # some enhancements since the commands on Mac are slightly different than on |
| 7 # Linux. | 7 # Linux. |
| 8 | 8 |
| 9 import("../goma.gni") | 9 import("../goma.gni") |
| 10 | 10 |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 45 "mac_clang_toolchain() must specify a \"toolchain_os\"") | 45 "mac_clang_toolchain() must specify a \"toolchain_os\"") |
| 46 | 46 |
| 47 # We can't do string interpolation ($ in strings) on things with dots in | 47 # We can't do string interpolation ($ in strings) on things with dots in |
| 48 # them. To allow us to use $cc below, for example, we create copies of | 48 # them. To allow us to use $cc below, for example, we create copies of |
| 49 # these values in our scope. | 49 # these values in our scope. |
| 50 cc = invoker.cc | 50 cc = invoker.cc |
| 51 cxx = invoker.cxx | 51 cxx = invoker.cxx |
| 52 ld = invoker.ld | 52 ld = invoker.ld |
| 53 | 53 |
| 54 # Make these apply to all tools below. | 54 # Make these apply to all tools below. |
| 55 lib_prefix = "-l" | 55 lib_switch = "-l" |
| 56 lib_dir_prefix="-L" | 56 lib_dir_switch = "-L" |
| 57 | 57 |
| 58 tool("cc") { | 58 tool("cc") { |
| 59 command = "$cc -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_c \
$cflags_pch_c -c \$in -o \$out" | 59 depfile = "{{output}}.d" |
| 60 description = "CC \$out" | 60 command = "$cc -MMD -MF $depfile {{defines}} {{include_dirs}} {{cflags}} {
{cflags_c}} -c {{source}} -o {{output}}" |
| 61 depfile = "\$out.d" | |
| 62 depsformat = "gcc" | 61 depsformat = "gcc" |
| 62 description = "CC {{output}}" |
| 63 outputs = [ |
| 64 "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 65 ] |
| 63 } | 66 } |
| 67 |
| 64 tool("cxx") { | 68 tool("cxx") { |
| 65 command = "$cxx -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_cc
\$cflags_pch_cc -c \$in -o \$out" | 69 depfile = "{{output}}.d" |
| 66 description = "CXX \$out" | 70 command = "$cxx -MMD -MF $depfile {{defines}} {{include_dirs}} {{cflags}}
{{cflags_cc}} -c {{source}} -o {{output}}" |
| 67 depfile = "\$out.d" | |
| 68 depsformat = "gcc" | 71 depsformat = "gcc" |
| 72 description = "CXX {{output}}" |
| 73 outputs = [ |
| 74 "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 75 ] |
| 69 } | 76 } |
| 77 |
| 78 tool("asm") { |
| 79 # For GCC we can just use the C compiler to compile assembly. |
| 80 depfile = "{{output}}.d" |
| 81 command = "$cc -MMD -MF $depfile {{defines}} {{include_dirs}} {{cflags}} {
{cflags_c}} -c {{source}} -o {{output}}" |
| 82 depsformat = "gcc" |
| 83 description = "ASM {{output}}" |
| 84 outputs = [ |
| 85 "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 86 ] |
| 87 } |
| 88 |
| 70 tool("objc") { | 89 tool("objc") { |
| 71 command = "$cc -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_c \
$cflags_objc \$cflags_pch_objc -c \$in -o \$out" | 90 depfile = "{{output}}.d" |
| 72 description = "OBJC \$out" | 91 command = "$cxx -MMD -MF $depfile {{defines}} {{include_dirs}} {{cflags}}
{{cflags_c}} {{cflags_objc}} -c {{source}} -o {{output}}" |
| 73 depfile = "\$out.d" | |
| 74 depsformat = "gcc" | 92 depsformat = "gcc" |
| 93 description = "OBJC {{output}}" |
| 94 outputs = [ |
| 95 "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 96 ] |
| 75 } | 97 } |
| 98 |
| 76 tool("objcxx") { | 99 tool("objcxx") { |
| 77 command = "$cxx -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_cc
\$cflags_objcc \$cflags_pch_objcc -c \$in -o \$out" | 100 depfile = "{{output}}.d" |
| 78 description = "OBJCXX \$out" | 101 command = "$cxx -MMD -MF $depfile {{defines}} {{include_dirs}} {{cflags}}
{{cflags_cc}} {{cflags_objcc}} -c {{source}} -o {{output}}" |
| 79 depfile = "\$out.d" | |
| 80 depsformat = "gcc" | 102 depsformat = "gcc" |
| 103 description = "OBJCXX {{output}}" |
| 104 outputs = [ |
| 105 "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 106 ] |
| 81 } | 107 } |
| 108 |
| 82 tool("alink") { | 109 tool("alink") { |
| 83 command = "rm -f \$out && ./gyp-mac-tool filter-libtool libtool \$libtool_
flags -static -o \$out \$in \$postbuilds" | 110 command = "rm -f {{output}} && ./gyp-mac-tool filter-libtool libtool -stat
ic -o {{output}} {{inputs}}" |
| 84 description = "LIBTOOL-STATIC \$out" | 111 description = "LIBTOOL-STATIC {{output}}" |
| 112 outputs = [ |
| 113 "{{target_out_dir}}/{{target_output_name}}{{output_extension}}" |
| 114 ] |
| 115 default_output_extension = ".a" |
| 116 output_prefix = "lib" |
| 85 } | 117 } |
| 118 |
| 86 tool("solink") { | 119 tool("solink") { |
| 87 command = "if [ ! -e \$lib -o ! -e \${lib}.TOC ] || otool -l \$lib | grep
-q LC_REEXPORT_DYLIB ; then $ld -shared \$ldflags -o \$lib -Wl,-filelist,\$rspfi
le \$solibs \$libs \$postbuilds && { otool -l \$lib | grep LC_ID_DYLIB -A 5; nm
-gP \$lib | cut -f1-2 -d' ' | grep -v U\$\$; true; } > \${lib}.TOC; else $ld -sh
ared \$ldflags -o \$lib \$in \$solibs \$libs \$postbuilds && { otool -l \$lib |
grep LC_ID_DYLIB -A 5; nm -gP \$lib | cut -f1-2 -d' ' | grep -v U\$\$; true; } >
\${lib}.tmp && if ! cmp -s \${lib}.tmp \${lib}.TOC; then mv \${lib}.tmp \${lib}
.TOC ; fi; fi" | 120 dylib = "{{target_output_name}}{{output_extension}}" # eg "libfoo.dylib" |
| 88 description = "SOLINK \$lib" | 121 rspfile = dylib + ".rsp" |
| 89 rspfile = "\$out.rsp" | 122 |
| 90 rspfile_content = "\$in_newline" | 123 # These variables are not build into GN but are helpers that implement |
| 91 #pool = "link_pool" | 124 # (1) linking to produce a .so, (2) extracting the symbols from that file |
| 92 restat = "1" | 125 # to a temporary file, (3) if the temporary file has differences from the |
| 126 # existing .TOC file, overwrite it, oterwise, don't change it. |
| 127 # |
| 128 # As a special case, if the library reexports symbols from other dynamic |
| 129 # libraries, we always update the .TOC and skip the temporary file and |
| 130 # diffing steps, since that library always needs to be re-linked. |
| 131 tocname = dylib + ".TOC" |
| 132 temporary_tocname = dylib + ".tmp" |
| 133 |
| 134 does_reexport_command = "[ ! -e $dylib -o ! -e $tocname ] || otool -l $dyl
ib | grep -q LC_REEXPORT_DYLIB" |
| 135 link_command = "$ld -shared {{ldflags}} -o $dylib -Wl,-filelist,$rspfile {
{solibs}} {{libs}}" |
| 136 replace_command = "if ! cmp -s $temporary_tocname $tocname; then mv $tempo
rary_tocname $tocname" |
| 137 extract_toc_command = "{ otool -l $dylib | grep LC_ID_DYLIB -A 5; nm -gP $
dylib | cut -f1-2 -d' ' | grep -v U\$\$; true; }" |
| 138 |
| 139 command = "if $does_reexport_command ; then $link_command && $extract_toc_
command > $tocname; else $link_command && $extract_toc_command > $temporary_tocn
ame && $replace_command ; fi; fi" |
| 140 |
| 141 rspfile_content = "{{inputs_newline}}" |
| 142 |
| 143 description = "SOLINK {{output}}" |
| 144 |
| 145 # Use this for {{output_extension}} expansions unless a target manually |
| 146 # overrides it (in which case {{output_extension}} will be what the target |
| 147 # specifies). |
| 148 default_output_extension = ".dylib" |
| 149 |
| 150 output_prefix = "lib" |
| 151 |
| 152 # Since the above commands only updates the .TOC file when it changes, ask |
| 153 # Ninja to check if the timestamp actually changed to know if downstream |
| 154 # dependencies should be recompiled. |
| 155 restat = true |
| 156 |
| 157 # Tell GN about the output files. It will link to the dylib but use the |
| 158 # tocname for dependency management. |
| 159 outputs = [ |
| 160 dylib, |
| 161 tocname, |
| 162 ] |
| 163 link_output = dylib |
| 164 depend_output = tocname |
| 93 } | 165 } |
| 166 |
| 94 tool("link") { | 167 tool("link") { |
| 95 command = "$ld \$ldflags -o \$out -Wl,-filelist,\$rspfile \$solibs \$libs
\$postbuilds" | 168 outfile = "{{target_output_name}}{{output_extension}}" |
| 96 description = "LINK \$out" | 169 rspfile = "$outfile.rsp" |
| 97 rspfile = "\$out.rsp" | 170 command = "$ld {{ldflags}} -o $outfile -Wl,-filelist,$rspfile {{solibs}} {
{libs}}" |
| 98 rspfile_content = "\$in_newline" | 171 description = "LINK $outfile" |
| 99 #pool = "link_pool" | 172 rspfile_content = "{{inputs_newline}}" |
| 173 outputs = [ outfile ] |
| 100 } | 174 } |
| 101 #tool("infoplist") { | 175 |
| 102 # command = "$cc -E -P -Wno-trigraphs -x c \$defines \$in -o \$out && pluti
l -convert xml1 \$out \$out" | |
| 103 # description = "INFOPLIST \$out" | |
| 104 #} | |
| 105 #tool("mac_tool") { | |
| 106 # command = "\$env ./gyp-mac-tool \$mactool_cmd \$in \$out" | |
| 107 # description = "MACTOOL \$mactool_cmd \$in" | |
| 108 #} | |
| 109 #tool("package_framework") { | |
| 110 # command = "./gyp-mac-tool package-framework \$out \$version \$postbuilds
&& touch \$out" | |
| 111 # description = "PACKAGE FRAMEWORK \$out, POSTBUILDS" | |
| 112 #} | |
| 113 tool("stamp") { | 176 tool("stamp") { |
| 114 command = "\${postbuilds}touch \$out" | 177 command = "touch {{output}}" |
| 115 description = "STAMP \$out" | 178 description = "STAMP {{output}}" |
| 116 } | 179 } |
| 180 |
| 117 tool("copy") { | 181 tool("copy") { |
| 118 command = "ln -f \$in \$out 2>/dev/null || (rm -rf \$out && cp -af \$in \$
out)" | 182 command = "ln -f {{source}} {{output}} 2>/dev/null || (rm -rf {{output}} &
& cp -af {{source}} {{output}})" |
| 119 description = "COPY \$in \$out" | 183 description = "COPY {{source}} {{output}}" |
| 120 } | 184 } |
| 121 | 185 |
| 122 toolchain_args() { | 186 toolchain_args() { |
| 123 os = invoker.toolchain_os | 187 os = invoker.toolchain_os |
| 124 } | 188 } |
| 125 } | 189 } |
| 126 } | 190 } |
| 127 | 191 |
| 128 # Toolchain representing the target build (either mac or iOS). | 192 # Toolchain representing the target build (either mac or iOS). |
| 129 mac_clang_toolchain("clang") { | 193 mac_clang_toolchain("clang") { |
| 130 toolchain_os = os | 194 toolchain_os = os |
| 131 } | 195 } |
| 132 | 196 |
| 133 # This toolchain provides a way for iOS target compiles to reference targets | 197 # This toolchain provides a way for iOS target compiles to reference targets |
| 134 # compiled for the host system. It just overrides the OS back to "mac". | 198 # compiled for the host system. It just overrides the OS back to "mac". |
| 135 mac_clang_toolchain("host_clang") { | 199 mac_clang_toolchain("host_clang") { |
| 136 toolchain_os = "mac" | 200 toolchain_os = "mac" |
| 137 } | 201 } |
| OLD | NEW |