Getting rid of GetDefaultProfile(), clean up of ProfileManager (which was in a seriou...
[chromium-blink-merge.git] / skia / skia_common.gypi
blob6aa3c70fab5a131922fab71b5bd98a8d33677dfd
1 # Copyright 2013 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 # This gypi file handles the removal of platform-specific files from the
6 # Skia build.
8   'include_dirs': [
9     '..',
10     'config',
11   ],
13   'conditions': [
14     [ 'OS != "android"', {
15       'sources/': [
16          ['exclude', '_android\\.(cc|cpp)$'],
17       ],
18     }],
19     [ 'OS == "android"', {
20       'defines': [
21         'SK_FONTHOST_DOES_NOT_USE_FONTMGR',
22       ],
23     }],
24     [ 'OS != "ios"', {
25       'sources/': [
26          ['exclude', '_ios\\.(cc|cpp|mm?)$'],
27       ],
28     }],
29     [ 'OS == "ios"', {
30       'defines': [
31         'SK_BUILD_FOR_IOS',
32       ],
33     }],
34     [ 'OS != "mac"', {
35       'sources/': [
36         ['exclude', '_mac\\.(cc|cpp|mm?)$'],
37       ],
38     }],
39     [ 'OS == "mac"', {
40       'defines': [
41         'SK_BUILD_FOR_MAC',
42       ],
43     }],
44     [ 'OS != "win"', {
45       'sources/': [ ['exclude', '_win\\.(cc|cpp)$'] ],
46     }],
47     [ 'OS == "win"', {
48       'defines': [
49         # On windows, GDI handles are a scarse system-wide resource so we have to keep
50         # the glyph cache, which holds up to 4 GDI handles per entry, to a fairly small
51         # size.
52         # http://crbug.com/314387
53         'SK_DEFAULT_FONT_CACHE_COUNT_LIMIT=256',
54       ],
55     }],
56     [ 'desktop_linux == 0 and chromeos == 0', {
57       'sources/': [ ['exclude', '_linux\\.(cc|cpp)$'] ],
58     }],
59     [ 'use_cairo == 0', {
60       'sources/': [ ['exclude', '_cairo\\.(cc|cpp)$'] ],
61     }],
63     #Settings for text blitting, chosen to approximate the system browser.
64     [ 'OS == "linux"', {
65       'defines': [
66         'SK_GAMMA_EXPONENT=1.2',
67         'SK_GAMMA_CONTRAST=0.2',
68       ],
69     }],
70     ['OS == "android"', {
71       'defines': [
72         'SK_GAMMA_APPLY_TO_A8',
73         'SK_GAMMA_EXPONENT=1.4',
74         'SK_GAMMA_CONTRAST=0.0',
75       ],
76     }],
77     ['OS == "win"', {
78       'defines': [
79         'SK_GAMMA_SRGB',
80         'SK_GAMMA_CONTRAST=0.5',
81       ],
82     }],
83     ['OS == "mac"', {
84       'defines': [
85         'SK_GAMMA_SRGB',
86         'SK_GAMMA_CONTRAST=0.0',
87       ],
88     }],
90     # For POSIX platforms, prefer the Mutex implementation provided by Skia
91     # since it does not generate static initializers.
92     [ 'os_posix == 1', {
93       'defines+': [
94         'SK_USE_POSIX_THREADS',
95       ],
96       'direct_dependent_settings': {
97         'defines': [
98           'SK_USE_POSIX_THREADS',
99         ],
100       },
101     }],
103     # Neon support.
104     [ 'target_arch == "arm" and arm_version >= 7 and arm_neon == 1', {
105       'defines': [
106         '__ARM_HAVE_NEON',
107       ],
108     }],
109     [ 'target_arch == "arm" and arm_version >= 7 and arm_neon_optional == 1', {
110       'defines': [
111         '__ARM_HAVE_OPTIONAL_NEON_SUPPORT',
112       ],
113     }],
114   ],
116   'variables': {
117     'variables': {
118       'conditions': [
119         ['OS== "ios"', {
120           'skia_support_gpu': 0,
121         }, {
122           'skia_support_gpu': 1,
123         }],
124         ['OS=="ios" or enable_printing == 0', {
125           'skia_support_pdf': 0,
126         }, {
127           'skia_support_pdf': 1,
128         }],
129       ],
130     },
131     'skia_support_gpu': '<(skia_support_gpu)',
132     'skia_support_pdf': '<(skia_support_pdf)',
134     # These two set the paths so we can include skia/gyp/core.gypi
135     'skia_src_path': '../third_party/skia/src',
136     'skia_include_path': '../third_party/skia/include',
138     # This list will contain all defines that also need to be exported to
139     # dependent components.
140     'skia_export_defines': [
141       'SK_ENABLE_INST_COUNT=0',
142       'SK_SUPPORT_GPU=<(skia_support_gpu)',
143       'GR_GL_CUSTOM_SETUP_HEADER="GrGLConfig_chrome.h"',
144       'SK_ENABLE_LEGACY_API_ALIASING=1',
145       'SK_ATTR_DEPRECATED=SK_NOTHING_ARG1',
146       'SK_SUPPORT_LEGACY_COLORTYPE=1',
147       'GR_GL_IGNORE_ES3_MSAA=0',
148       'SK_SUPPORT_LEGACY_ONLOCKPIXELS',
149     ],
151     'default_font_cache_limit%': '(20*1024*1024)',
153     'conditions': [
154       ['OS== "android"', {
155         # Android devices are typically more memory constrained, so
156         # default to a smaller glyph cache (it may be overriden at runtime
157         # when the renderer starts up, depending on the actual device memory).
158         'default_font_cache_limit': '(1*1024*1024)',
159         'skia_export_defines': [
160           'SK_BUILD_FOR_ANDROID',
161         ],
162       }],
163     ],
164   },
166   'defines': [
167     '<@(skia_export_defines)',
169     # skia uses static initializers to initialize the serialization logic
170     # of its "pictures" library. This is currently not used in chrome; if
171     # it ever gets used the processes that use it need to call
172     # SkGraphics::Init().
173     'SK_ALLOW_STATIC_GLOBAL_INITIALIZERS=0',
175     # Forcing the unoptimized path for the offset image filter in skia until
176     # all filters used in Blink support the optimized path properly
177     'SK_DISABLE_OFFSETIMAGEFILTER_OPTIMIZATION',
179     # Disable this check because it is too strict for some Chromium-specific
180     # subclasses of SkPixelRef. See bug: crbug.com/171776.
181     'SK_DISABLE_PIXELREF_LOCKCOUNT_BALANCE_CHECK',
183     'IGNORE_ROT_AA_RECT_OPT',
185     'SK_IGNORE_BLURRED_RRECT_OPT',
187     'SK_IGNORE_QUAD_RR_CORNERS_OPT',
189     # this flag forces Skia not to use typographic metrics with GDI.
190     'SK_GDI_ALWAYS_USE_TEXTMETRICS_FOR_FONT_METRICS',
192     'SK_DEFAULT_FONT_CACHE_LIMIT=<(default_font_cache_limit)',
194     'SK_USE_DISCARDABLE_SCALEDIMAGECACHE',
195   ],
197   'direct_dependent_settings': {
198     'defines': [
199       '<@(skia_export_defines)',
200     ],
201   },
203   # We would prefer this to be direct_dependent_settings,
204   # however we currently have no means to enforce that direct dependents
205   # re-export if they include Skia headers in their public headers.
206   'all_dependent_settings': {
207     'include_dirs': [
208       '..',
209       'config',
210     ],
211   },
213   'msvs_disabled_warnings': [4244, 4267, 4341, 4345, 4390, 4554, 4748, 4800],