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.
14 'target_name': 'crypto',
15 'type': '<(component)',
16 'product_name': 'crcrypto', # Avoid colliding with OpenSSL's libcrypto
18 '../base/base.gyp:base',
19 '../base/third_party/dynamic_annotations/dynamic_annotations.gyp:dynamic_annotations',
22 'CRYPTO_IMPLEMENTATION',
25 [ 'os_posix == 1 and OS != "mac" and OS != "ios" and OS != "android"', {
27 '../build/linux/system.gyp:ssl',
29 'export_dependent_settings': [
30 '../build/linux/system.gyp:ssl',
34 'sources/': [ ['include', '_chromeos\\.cc$'] ]
38 }, { # os_posix != 1 or OS == "mac" or OS == "ios" or OS == "android"
41 'symmetric_key_win.cc',
44 [ 'OS != "mac" and OS != "ios"', {
47 'mock_apple_keychain.cc',
48 'mock_apple_keychain.h',
51 [ 'OS == "android"', {
53 '../build/android/ndk.gyp:cpu_features',
59 '-L/usr/local/lib -lexecinfo',
67 '$(SDKROOT)/System/Library/Frameworks/Security.framework',
74 'mac_security_services_lock.cc',
75 'mac_security_services_lock.h',
78 [ 'use_openssl == 0 and (OS == "mac" or OS == "ios" or OS == "win")', {
80 '../third_party/nss/nss.gyp:nspr',
81 '../third_party/nss/nss.gyp:nss',
83 'export_dependent_settings': [
84 '../third_party/nss/nss.gyp:nspr',
85 '../third_party/nss/nss.gyp:nss',
95 'msvs_disabled_warnings': [
96 4267, # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
100 [ 'use_openssl==1', {
102 '../third_party/boringssl/boringssl.gyp:boringssl',
104 # TODO(joth): Use a glob to match exclude patterns once the
105 # OpenSSL file set is complete.
107 'aes_128_gcm_helpers_nss.cc',
108 'aes_128_gcm_helpers_nss.h',
109 'ec_private_key_nss.cc',
110 'ec_signature_creator_nss.cc',
113 'rsa_private_key_nss.cc',
114 'secure_hash_default.cc',
115 'signature_creator_nss.cc',
116 'signature_verifier_nss.cc',
117 'symmetric_key_nss.cc',
118 'third_party/nss/chromium-blapi.h',
119 'third_party/nss/chromium-blapit.h',
120 'third_party/nss/chromium-nss.h',
121 'third_party/nss/chromium-prtypes.h',
122 'third_party/nss/chromium-sha256.h',
123 'third_party/nss/pk11akey.cc',
124 'third_party/nss/rsawrapr.c',
125 'third_party/nss/secsign.cc',
126 'third_party/nss/sha512.cc',
132 'ec_private_key_openssl.cc',
133 'ec_signature_creator_openssl.cc',
134 'encryptor_openssl.cc',
136 'openssl_bio_string.cc',
137 'openssl_bio_string.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',
147 [ 'use_openssl==1 and use_nss_certs==0', {
148 # Some files are built when NSS is used at all, either for the
149 # internal crypto library or the platform certificate library.
155 'nss_util_internal.h',
160 '<@(crypto_sources)',
164 'target_name': 'crypto_unittests',
165 'type': 'executable',
167 'aead_openssl_unittest.cc',
168 'aes_128_gcm_helpers_nss_unittest.cc',
169 'curve25519_unittest.cc',
170 'ec_private_key_unittest.cc',
171 'ec_signature_creator_unittest.cc',
172 'encryptor_unittest.cc',
176 'nss_key_util_unittest.cc',
177 'nss_util_unittest.cc',
178 'openssl_bio_string_unittest.cc',
180 'p224_spake_unittest.cc',
181 'random_unittest.cc',
182 'rsa_private_key_unittest.cc',
183 'secure_hash_unittest.cc',
185 'signature_creator_unittest.cc',
186 'signature_verifier_unittest.cc',
187 'symmetric_key_unittest.cc',
191 'crypto_test_support',
192 '../base/base.gyp:base',
193 '../base/base.gyp:run_all_unittests',
194 '../base/base.gyp:test_support_base',
195 '../testing/gmock.gyp:gmock',
196 '../testing/gtest.gyp:gtest',
199 [ 'use_nss_certs == 1', {
201 [ 'use_allocator!="none"', {
203 '../base/allocator/allocator.gyp:allocator',
209 '../build/linux/system.gyp:ssl',
212 [ 'use_openssl == 1 and use_nss_certs == 0', {
213 # Some files are built when NSS is used at all, either for the
214 # internal crypto library or the platform certificate library.
216 'nss_key_util_unittest.cc',
217 'nss_util_unittest.cc',
220 [ 'use_openssl == 0 and (OS == "mac" or OS == "ios" or OS == "win")', {
222 '../third_party/nss/nss.gyp:nspr',
226 # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
227 'msvs_disabled_warnings': [4267, ],
229 [ 'use_openssl==1', {
231 '../third_party/boringssl/boringssl.gyp:boringssl',
234 'aes_128_gcm_helpers_nss_unittest.cc',
238 'openssl_bio_string_unittest.cc',
245 ['OS == "win" and target_arch=="ia32"', {
248 'target_name': 'crypto_nacl_win64',
249 # We do not want nacl_helper to depend on NSS because this would
250 # require including a 64-bit copy of NSS. Thus, use the native APIs
252 'type': '<(component)',
254 '../base/base.gyp:base_win64',
255 '../base/third_party/dynamic_annotations/dynamic_annotations.gyp:dynamic_annotations_win64',
258 '<@(nacl_win64_sources)',
261 'CRYPTO_IMPLEMENTATION',
262 '<@(nacl_win64_defines)',
264 'msvs_disabled_warnings': [
269 'msvs_target_platform': 'x64',
275 ['use_nss_certs==1', {
278 'target_name': 'crypto_test_support',
279 'type': 'static_library',
281 '../base/base.gyp:base',
285 'scoped_test_nss_db.cc',
286 'scoped_test_nss_db.h',
287 'scoped_test_nss_chromeos_user.cc',
288 'scoped_test_nss_chromeos_user.h',
289 'scoped_test_system_nss_key_slot.cc',
290 'scoped_test_system_nss_key_slot.h',
293 ['use_nss_certs==0', {
295 'scoped_test_nss_db.cc',
296 'scoped_test_nss_db.h',
301 'scoped_test_nss_chromeos_user.cc',
302 'scoped_test_nss_chromeos_user.h',
303 'scoped_test_system_nss_key_slot.cc',
304 'scoped_test_system_nss_key_slot.h',
309 ]}, { # use_nss_certs==0
312 'target_name': 'crypto_test_support',
317 ['test_isolation_mode != "noop"', {
320 'target_name': 'crypto_unittests_run',
326 '../build/isolate.gypi',
329 'crypto_unittests.isolate',