Keep virtual keyboard visibility the same after enable an IME in a different extension
[chromium-blink-merge.git] / crypto / crypto.gyp
blob3cdc151f3286ee1d78df7b46e27155353c3f9c89
1 # Copyright (c) 2012 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.
6   'variables': {
7     'chromium_code': 1,
8   },
9   'includes': [
10     'crypto.gypi',
11   ],
12   'targets': [
13     {
14       'target_name': 'crypto',
15       'type': '<(component)',
16       'product_name': 'crcrypto',  # Avoid colliding with OpenSSL's libcrypto
17       'dependencies': [
18         '../base/base.gyp:base',
19         '../base/third_party/dynamic_annotations/dynamic_annotations.gyp:dynamic_annotations',
20       ],
21       'defines': [
22         'CRYPTO_IMPLEMENTATION',
23       ],
24       'msvs_disabled_warnings': [
25         4018,
26       ],
27       'conditions': [
28         [ 'os_posix == 1 and OS != "mac" and OS != "ios" and OS != "android"', {
29           'dependencies': [
30             '../build/linux/system.gyp:ssl',
31           ],
32           'export_dependent_settings': [
33             '../build/linux/system.gyp:ssl',
34           ],
35           'conditions': [
36             [ 'chromeos==1', {
37                 'sources/': [ ['include', '_chromeos\\.cc$'] ]
38               },
39             ],
40           ],
41         }, {  # os_posix != 1 or OS == "mac" or OS == "ios" or OS == "android"
42             'sources!': [
43               'hmac_win.cc',
44               'symmetric_key_win.cc',
45             ],
46         }],
47         [ 'OS != "mac" and OS != "ios"', {
48           'sources!': [
49             'apple_keychain.h',
50             'mock_apple_keychain.cc',
51             'mock_apple_keychain.h',
52           ],
53         }],
54         [ 'OS == "android"', {
55             'includes': [
56               '../build/android/cpufeatures.gypi',
57             ],
58         }],
59         [ 'os_bsd==1', {
60           'link_settings': {
61             'libraries': [
62               '-L/usr/local/lib -lexecinfo',
63               ],
64             },
65           },
66         ],
67         [ 'OS == "mac"', {
68           'link_settings': {
69             'libraries': [
70               '$(SDKROOT)/System/Library/Frameworks/Security.framework',
71             ],
72           },
73         }, {  # OS != "mac"
74           'sources!': [
75             'cssm_init.cc',
76             'cssm_init.h',
77             'mac_security_services_lock.cc',
78             'mac_security_services_lock.h',
79           ],
80         }],
81         [ 'use_openssl == 0 and (OS == "mac" or OS == "ios" or OS == "win")', {
82           'dependencies': [
83             '../third_party/nss/nss.gyp:nspr',
84             '../third_party/nss/nss.gyp:nss',
85           ],
86           'export_dependent_settings': [
87             '../third_party/nss/nss.gyp:nspr',
88             '../third_party/nss/nss.gyp:nss',
89           ],
90         }],
91         [ 'OS != "win"', {
92           'sources!': [
93             'capi_util.h',
94             'capi_util.cc',
95           ],
96         }],
97         [ 'OS == "win"', {
98           # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
99           'msvs_disabled_warnings': [4267, ],
100         }],
101         [ 'use_openssl==1', {
102             'dependencies': [
103               '../third_party/boringssl/boringssl.gyp:boringssl',
104             ],
105             # TODO(joth): Use a glob to match exclude patterns once the
106             #             OpenSSL file set is complete.
107             'sources!': [
108               'ec_private_key_nss.cc',
109               'ec_signature_creator_nss.cc',
110               'encryptor_nss.cc',
111               'hmac_nss.cc',
112               'nss_util.cc',
113               'nss_util.h',
114               'nss_util_internal.h',
115               'rsa_private_key_nss.cc',
116               'secure_hash_default.cc',
117               'signature_creator_nss.cc',
118               'signature_verifier_nss.cc',
119               'symmetric_key_nss.cc',
120               'third_party/nss/chromium-blapi.h',
121               'third_party/nss/chromium-blapit.h',
122               'third_party/nss/chromium-nss.h',
123               'third_party/nss/chromium-prtypes.h',
124               'third_party/nss/chromium-sha256.h',
125               'third_party/nss/pk11akey.cc',
126               'third_party/nss/rsawrapr.c',
127               'third_party/nss/secsign.cc',
128               'third_party/nss/sha512.cc',
129             ],
130           }, {
131             'sources!': [
132               'ec_private_key_openssl.cc',
133               'ec_signature_creator_openssl.cc',
134               'encryptor_openssl.cc',
135               'hmac_openssl.cc',
136               'openssl_bio_string.cc',
137               'openssl_bio_string.h',
138               'openssl_util.cc',
139               'openssl_util.h',
140               'rsa_private_key_openssl.cc',
141               'secure_hash_openssl.cc',
142               'signature_creator_openssl.cc',
143               'signature_verifier_openssl.cc',
144               'symmetric_key_openssl.cc',
145             ],
146         },],
147       ],
148       'sources': [
149         '<@(crypto_sources)',
150       ],
151     },
152     {
153       'target_name': 'crypto_unittests',
154       'type': 'executable',
155       'sources': [
156         'curve25519_unittest.cc',
157         'ec_private_key_unittest.cc',
158         'ec_signature_creator_unittest.cc',
159         'encryptor_unittest.cc',
160         'ghash_unittest.cc',
161         'hkdf_unittest.cc',
162         'hmac_unittest.cc',
163         'nss_util_unittest.cc',
164         'openssl_bio_string_unittest.cc',
165         'p224_unittest.cc',
166         'p224_spake_unittest.cc',
167         'random_unittest.cc',
168         'rsa_private_key_unittest.cc',
169         'rsa_private_key_nss_unittest.cc',
170         'secure_hash_unittest.cc',
171         'sha2_unittest.cc',
172         'signature_creator_unittest.cc',
173         'signature_verifier_unittest.cc',
174         'symmetric_key_unittest.cc',
175       ],
176       'dependencies': [
177         'crypto',
178         'crypto_test_support',
179         '../base/base.gyp:base',
180         '../base/base.gyp:run_all_unittests',
181         '../base/base.gyp:test_support_base',
182         '../testing/gmock.gyp:gmock',
183         '../testing/gtest.gyp:gtest',
184       ],
185       'conditions': [
186         [ 'os_posix == 1 and OS != "mac" and OS != "android" and OS != "ios"', {
187           'conditions': [
188             [ 'use_allocator!="none"', {
189                 'dependencies': [
190                   '../base/allocator/allocator.gyp:allocator',
191                 ],
192               },
193             ],
194           ],
195           'dependencies': [
196             '../build/linux/system.gyp:ssl',
197           ],
198         }, {  # os_posix != 1 or OS == "mac" or OS == "android" or OS == "ios"
199           'sources!': [
200             'rsa_private_key_nss_unittest.cc',
201           ]
202         }],
203         [ 'use_openssl == 0 and (OS == "mac" or OS == "ios" or OS == "win")', {
204           'dependencies': [
205             '../third_party/nss/nss.gyp:nspr',
206           ],
207         }],
208         [ 'OS == "win"', {
209           # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
210           'msvs_disabled_warnings': [4267, ],
211         }],
212         [ 'use_openssl==1', {
213           'dependencies': [
214             '../third_party/boringssl/boringssl.gyp:boringssl',
215           ],
216           'sources!': [
217             'nss_util_unittest.cc',
218             'rsa_private_key_nss_unittest.cc',
219           ],
220         }, {
221           'sources!': [
222             'openssl_bio_string_unittest.cc',
223           ],
224         }],
225       ],
226     },
227   ],
228   'conditions': [
229     ['OS == "win" and target_arch=="ia32"', {
230       'targets': [
231         {
232           'target_name': 'crypto_nacl_win64',
233           # We do not want nacl_helper to depend on NSS because this would
234           # require including a 64-bit copy of NSS. Thus, use the native APIs
235           # for the helper.
236           'type': '<(component)',
237           'dependencies': [
238             '../base/base.gyp:base_win64',
239             '../base/third_party/dynamic_annotations/dynamic_annotations.gyp:dynamic_annotations_win64',
240           ],
241           'sources': [
242             '<@(hmac_win64_related_sources)',
243           ],
244           'defines': [
245            'CRYPTO_IMPLEMENTATION',
246            '<@(nacl_win64_defines)',
247           ],
248           'msvs_disabled_warnings': [
249             4018,
250           ],
251           'configurations': {
252             'Common_Base': {
253               'msvs_target_platform': 'x64',
254             },
255           },
256         },
257       ],
258     }],
259     ['use_nss==1', {
260       'targets': [
261         {
262           'target_name': 'crypto_test_support',
263           'type': 'static_library',
264           'dependencies': [
265             '../base/base.gyp:base',
266             'crypto',
267           ],
268           'sources': [
269             'scoped_test_nss_db.cc',
270             'scoped_test_nss_db.h',
271             'scoped_test_nss_chromeos_user.cc',
272             'scoped_test_nss_chromeos_user.h',
273             'scoped_test_system_nss_key_slot.cc',
274             'scoped_test_system_nss_key_slot.h',
275           ],
276           'conditions': [
277             ['use_nss==0', {
278               'sources!': [
279                 'scoped_test_nss_db.cc',
280                 'scoped_test_nss_db.h',
281               ],
282             }],
283             [ 'chromeos==0', {
284               'sources!': [
285                 'scoped_test_nss_chromeos_user.cc',
286                 'scoped_test_nss_chromeos_user.h',
287                 'scoped_test_system_nss_key_slot.cc',
288                 'scoped_test_system_nss_key_slot.h',
289               ],
290             }],
291           ],
292         }
293       ]}, {  # use_nss==0
294       'targets': [
295         {
296           'target_name': 'crypto_test_support',
297           'type': 'none',
298           'sources': [],
299         }
300     ]}],
301   ],