Index: infra/bots/recipe_modules/flavor/gn_flavor.py |
diff --git a/infra/bots/recipe_modules/flavor/gn_flavor.py b/infra/bots/recipe_modules/flavor/gn_flavor.py |
index 019967748b5a4bff39d45e9c783f1c789a17bd7c..ef258965695f7e144dc728a583a90a7909662d4d 100644 |
--- a/infra/bots/recipe_modules/flavor/gn_flavor.py |
+++ b/infra/bots/recipe_modules/flavor/gn_flavor.py |
@@ -6,50 +6,51 @@ import default_flavor |
"""GN flavor utils, used for building Skia with GN.""" |
class GNFlavorUtils(default_flavor.DefaultFlavorUtils): |
- def compile(self, target, **kwargs): |
- """Build Skia with GN.""" |
- # Get the gn executable. |
- fetch_gn = self.m.vars.skia_dir.join('bin', 'fetch-gn') |
- self.m.run(self.m.step, 'fetch-gn', |
- cmd=[fetch_gn], |
- cwd=self.m.vars.skia_dir, |
- **kwargs) |
+ def supported(self): |
+ extra_config = self.m.vars.builder_cfg.get('extra_config', '') |
+ |
+ return any([ |
+ extra_config == 'GN', |
+ extra_config == 'Fast', |
+ extra_config.startswith('SK') |
+ ]) |
- is_debug = 'is_debug=true' |
- if self.m.vars.configuration != 'Debug': |
- is_debug = 'is_debug=false' |
- gn_args = [is_debug] |
+ def compile(self, unused_target, **kwargs): |
+ """Build Skia with GN.""" |
+ compiler = self.m.vars.builder_cfg.get('compiler', '') |
+ configuration = self.m.vars.builder_cfg.get('configuration', '') |
+ extra_config = self.m.vars.builder_cfg.get('extra_config', '') |
- is_clang = 'Clang' in self.m.vars.builder_name |
- is_gcc = 'GCC' in self.m.vars.builder_name |
+ gn_args = [] |
+ if configuration != 'Debug': |
+ gn_args.append('is_debug=false') |
cc, cxx = 'cc', 'c++' |
- if is_clang: |
+ cflags = [] |
+ |
+ if compiler == 'Clang': |
cc, cxx = 'clang', 'clang++' |
- elif is_gcc: |
+ elif compiler == 'GCC': |
cc, cxx = 'gcc', 'g++' |
ccache = self.m.run.ccache() |
if ccache: |
cc, cxx = '%s %s' % (ccache, cc), '%s %s' % (ccache, cxx) |
- if is_clang: |
+ if compiler == 'Clang': |
# Stifle "argument unused during compilation: ..." warnings. |
- stifle = '-Qunused-arguments' |
- cc, cxx = '%s %s' % (cc, stifle), '%s %s' % (cxx, stifle) |
- |
- gn_args += [ 'cc="%s"' % cc, 'cxx="%s"' % cxx ] |
- |
- # Run gn gen. |
- gn_exe = 'gn' |
- if self.m.platform.is_win: |
- gn_exe = 'gn.exe' |
- gn_gen = [gn_exe, 'gen', self.out_dir, '--args=%s' % ' '.join(gn_args)] |
- self.m.run(self.m.step, 'gn_gen', cmd=gn_gen, |
- cwd=self.m.vars.skia_dir, **kwargs) |
- |
- # Run ninja. |
- ninja_cmd = ['ninja', '-C', self.out_dir] |
- self.m.run(self.m.step, 'compile %s' % target, |
- cmd=ninja_cmd, |
- cwd=self.m.vars.skia_dir, |
- **kwargs) |
+ cflags.append('-Qunused-arguments') |
+ |
+ if extra_config == 'Fast': |
+ cflags.extend(['-march=native', '-fomit-frame-pointer']) |
+ if extra_config.startswith('SK'): |
+ cflags.append('-D' + extra_config) |
+ |
+ cflags = ' '.join(cflags) |
+ gn_args += [ 'cc="%s %s"' % (cc, cflags), 'cxx="%s %s"' % (cxx, cflags) ] |
+ |
+ run = lambda title, cmd: self.m.run(self.m.step, title, cmd=cmd, |
+ cwd=self.m.vars.skia_dir, **kwargs) |
+ |
+ run('fetch-gn', [self.m.vars.skia_dir.join('bin', 'fetch-gn')]) |
+ run('gn gen', ['gn', 'gen', self.out_dir, '--args=%s' % ' '.join(gn_args)]) |
+ run('ninja', ['ninja', '-C', self.out_dir]) |