1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
# -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
# vim: set filetype=python:
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
with Files("**"):
BUG_COMPONENT = ("Core", "Security: PSM")
UNIFIED_SOURCES += [
"AppSignatureVerification.cpp",
"AppTrustDomain.cpp",
]
include("/ipc/chromium/chromium-config.mozbuild")
FINAL_LIBRARY = "xul"
LOCAL_INCLUDES += [
"/security/certverifier",
"/security/manager/ssl",
"/third_party/rust/cose-c/include",
]
DEFINES["NSS_ENABLE_ECC"] = "True"
for var in ("DLL_PREFIX", "DLL_SUFFIX"):
DEFINES[var] = '"%s"' % CONFIG[var]
if CONFIG["CC_TYPE"] in ("clang", "gcc"):
CXXFLAGS += [
"-Wextra",
]
# Gecko headers aren't warning-free enough for us to enable these warnings.
CXXFLAGS += [
"-Wno-unused-parameter",
]
test_ssl_path = "/security/manager/ssl/tests/unit"
headers_arrays_certs = [
(
"xpcshell.inc",
"xpcshellRoot",
test_ssl_path + "/test_signed_apps/xpcshellTestRoot.der",
),
("addons-public.inc", "addonsPublicRoot", "addons-public.crt"),
(
"addons-public-intermediate.inc",
"addonsPublicIntermediate",
"addons-public-intermediate.crt",
),
("addons-stage.inc", "addonsStageRoot", "addons-stage.crt"),
]
for header, array_name, cert in headers_arrays_certs:
GeneratedFile(
header, script="gen_cert_header.py", entry_point=array_name, inputs=[cert]
)
|