xref: /aosp_15_r20/external/cronet/base/PRESUBMIT.py (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker# Copyright 2012 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker# Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker# found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker"""Chromium presubmit script for src/base.
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard WorkerSee http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts
8*6777b538SAndroid Build Coastguard Workerfor more details on the presubmit API built into depot_tools.
9*6777b538SAndroid Build Coastguard Worker"""
10*6777b538SAndroid Build Coastguard Worker
11*6777b538SAndroid Build Coastguard Workerdef CheckChangeLintsClean(input_api, output_api):
12*6777b538SAndroid Build Coastguard Worker  """Makes sure that the code is cpplint clean."""
13*6777b538SAndroid Build Coastguard Worker  # lint_filters=[] stops the OFF_BY_DEFAULT_LINT_FILTERS from being disabled,
14*6777b538SAndroid Build Coastguard Worker  # finding many more issues. verbose_level=1 finds a small number of additional
15*6777b538SAndroid Build Coastguard Worker  # issues.
16*6777b538SAndroid Build Coastguard Worker  # The only valid extensions for cpplint are .cc, .h, .cpp, .cu, and .ch.
17*6777b538SAndroid Build Coastguard Worker  # Only process those extensions which are used in Chromium, in directories
18*6777b538SAndroid Build Coastguard Worker  # that currently lint clean.
19*6777b538SAndroid Build Coastguard Worker  CLEAN_CPP_FILES_ONLY = (r'base/win/.*\.(cc|h)$', )
20*6777b538SAndroid Build Coastguard Worker  source_file_filter = lambda x: input_api.FilterSourceFile(
21*6777b538SAndroid Build Coastguard Worker      x,
22*6777b538SAndroid Build Coastguard Worker      files_to_check=CLEAN_CPP_FILES_ONLY,
23*6777b538SAndroid Build Coastguard Worker      files_to_skip=input_api.DEFAULT_FILES_TO_SKIP)
24*6777b538SAndroid Build Coastguard Worker  return input_api.canned_checks.CheckChangeLintsClean(
25*6777b538SAndroid Build Coastguard Worker      input_api, output_api, source_file_filter=source_file_filter,
26*6777b538SAndroid Build Coastguard Worker      lint_filters=[], verbose_level=1)
27*6777b538SAndroid Build Coastguard Worker
28*6777b538SAndroid Build Coastguard Worker
29*6777b538SAndroid Build Coastguard Workerdef _CheckNoInterfacesInBase(input_api, output_api):
30*6777b538SAndroid Build Coastguard Worker  """Checks to make sure no files in libbase.a have |@interface|."""
31*6777b538SAndroid Build Coastguard Worker  pattern = input_api.re.compile(r'^\s*@interface', input_api.re.MULTILINE)
32*6777b538SAndroid Build Coastguard Worker  files = []
33*6777b538SAndroid Build Coastguard Worker  for f in input_api.AffectedSourceFiles(input_api.FilterSourceFile):
34*6777b538SAndroid Build Coastguard Worker    if (f.LocalPath().startswith('base/') and
35*6777b538SAndroid Build Coastguard Worker        not "/ios/" in f.LocalPath() and
36*6777b538SAndroid Build Coastguard Worker        not "/test/" in f.LocalPath() and
37*6777b538SAndroid Build Coastguard Worker        not f.LocalPath().endswith('.java') and
38*6777b538SAndroid Build Coastguard Worker        not f.LocalPath().endswith('_unittest.mm') and
39*6777b538SAndroid Build Coastguard Worker        not f.LocalPath().endswith('_spi.h')):
40*6777b538SAndroid Build Coastguard Worker      contents = input_api.ReadFile(f)
41*6777b538SAndroid Build Coastguard Worker      if pattern.search(contents):
42*6777b538SAndroid Build Coastguard Worker        files.append(f)
43*6777b538SAndroid Build Coastguard Worker
44*6777b538SAndroid Build Coastguard Worker  if len(files):
45*6777b538SAndroid Build Coastguard Worker    return [ output_api.PresubmitError(
46*6777b538SAndroid Build Coastguard Worker        'Objective-C interfaces or categories are forbidden in libbase. ' +
47*6777b538SAndroid Build Coastguard Worker        'See http://groups.google.com/a/chromium.org/group/chromium-dev/' +
48*6777b538SAndroid Build Coastguard Worker        'browse_thread/thread/efb28c10435987fd',
49*6777b538SAndroid Build Coastguard Worker        files) ]
50*6777b538SAndroid Build Coastguard Worker  return []
51*6777b538SAndroid Build Coastguard Worker
52*6777b538SAndroid Build Coastguard Worker
53*6777b538SAndroid Build Coastguard Workerdef _FindLocations(input_api, search_regexes, files_to_check, files_to_skip):
54*6777b538SAndroid Build Coastguard Worker  """Returns locations matching one of the search_regexes."""
55*6777b538SAndroid Build Coastguard Worker  def FilterFile(affected_file):
56*6777b538SAndroid Build Coastguard Worker    return input_api.FilterSourceFile(
57*6777b538SAndroid Build Coastguard Worker      affected_file,
58*6777b538SAndroid Build Coastguard Worker      files_to_check=files_to_check,
59*6777b538SAndroid Build Coastguard Worker      files_to_skip=files_to_skip)
60*6777b538SAndroid Build Coastguard Worker
61*6777b538SAndroid Build Coastguard Worker  no_presubmit = r"// no-presubmit-check"
62*6777b538SAndroid Build Coastguard Worker  locations = []
63*6777b538SAndroid Build Coastguard Worker  for f in input_api.AffectedSourceFiles(FilterFile):
64*6777b538SAndroid Build Coastguard Worker    for line_num, line in f.ChangedContents():
65*6777b538SAndroid Build Coastguard Worker      for search_regex in search_regexes:
66*6777b538SAndroid Build Coastguard Worker        if (input_api.re.search(search_regex, line) and
67*6777b538SAndroid Build Coastguard Worker            not input_api.re.search(no_presubmit, line)):
68*6777b538SAndroid Build Coastguard Worker          locations.append("    %s:%d" % (f.LocalPath(), line_num))
69*6777b538SAndroid Build Coastguard Worker          break
70*6777b538SAndroid Build Coastguard Worker  return locations
71*6777b538SAndroid Build Coastguard Worker
72*6777b538SAndroid Build Coastguard Worker
73*6777b538SAndroid Build Coastguard Workerdef _CheckNoTraceEventInclude(input_api, output_api):
74*6777b538SAndroid Build Coastguard Worker  """Verify that //base includes base_tracing.h instead of trace event headers.
75*6777b538SAndroid Build Coastguard Worker
76*6777b538SAndroid Build Coastguard Worker  Checks that files outside trace event implementation include the
77*6777b538SAndroid Build Coastguard Worker  base_tracing.h header instead of specific trace event implementation headers
78*6777b538SAndroid Build Coastguard Worker  to maintain compatibility with the gn flag "enable_base_tracing = false".
79*6777b538SAndroid Build Coastguard Worker  """
80*6777b538SAndroid Build Coastguard Worker  discouraged_includes = [
81*6777b538SAndroid Build Coastguard Worker    r'^#include "base/trace_event/(?!base_tracing\.h|base_tracing_forward\.h)',
82*6777b538SAndroid Build Coastguard Worker    r'^#include "third_party/perfetto/include/',
83*6777b538SAndroid Build Coastguard Worker  ]
84*6777b538SAndroid Build Coastguard Worker
85*6777b538SAndroid Build Coastguard Worker  files_to_check = [
86*6777b538SAndroid Build Coastguard Worker    r".*\.(h|cc|mm)$",
87*6777b538SAndroid Build Coastguard Worker  ]
88*6777b538SAndroid Build Coastguard Worker  files_to_skip = [
89*6777b538SAndroid Build Coastguard Worker    r".*/test/.*",
90*6777b538SAndroid Build Coastguard Worker    r".*/trace_event/.*",
91*6777b538SAndroid Build Coastguard Worker    r".*/tracing/.*",
92*6777b538SAndroid Build Coastguard Worker  ]
93*6777b538SAndroid Build Coastguard Worker
94*6777b538SAndroid Build Coastguard Worker  locations = _FindLocations(input_api, discouraged_includes, files_to_check,
95*6777b538SAndroid Build Coastguard Worker                             files_to_skip)
96*6777b538SAndroid Build Coastguard Worker  if locations:
97*6777b538SAndroid Build Coastguard Worker    return [ output_api.PresubmitError(
98*6777b538SAndroid Build Coastguard Worker        'Base code should include "base/trace_event/base_tracing.h" instead\n' +
99*6777b538SAndroid Build Coastguard Worker        'of trace_event implementation headers. If you need to include an\n' +
100*6777b538SAndroid Build Coastguard Worker        'implementation header, verify that "gn check" and base_unittests\n' +
101*6777b538SAndroid Build Coastguard Worker        'still pass with gn arg "enable_base_tracing = false" and add\n' +
102*6777b538SAndroid Build Coastguard Worker        '"// no-presubmit-check" after the include. \n' +
103*6777b538SAndroid Build Coastguard Worker        '\n'.join(locations)) ]
104*6777b538SAndroid Build Coastguard Worker  return []
105*6777b538SAndroid Build Coastguard Worker
106*6777b538SAndroid Build Coastguard Worker
107*6777b538SAndroid Build Coastguard Workerdef _WarnPbzeroIncludes(input_api, output_api):
108*6777b538SAndroid Build Coastguard Worker  """Warn to check enable_base_tracing=false when including a pbzero header.
109*6777b538SAndroid Build Coastguard Worker
110*6777b538SAndroid Build Coastguard Worker  Emits a warning when including a perfetto pbzero header, encouraging the
111*6777b538SAndroid Build Coastguard Worker  user to verify that //base still builds with enable_base_tracing=false.
112*6777b538SAndroid Build Coastguard Worker  """
113*6777b538SAndroid Build Coastguard Worker  warn_includes = [
114*6777b538SAndroid Build Coastguard Worker    r'^#include "third_party/perfetto/protos/',
115*6777b538SAndroid Build Coastguard Worker    r'^#include "base/tracing/protos/',
116*6777b538SAndroid Build Coastguard Worker  ]
117*6777b538SAndroid Build Coastguard Worker
118*6777b538SAndroid Build Coastguard Worker  files_to_check = [
119*6777b538SAndroid Build Coastguard Worker    r".*\.(h|cc|mm)$",
120*6777b538SAndroid Build Coastguard Worker  ]
121*6777b538SAndroid Build Coastguard Worker  files_to_skip = [
122*6777b538SAndroid Build Coastguard Worker    r".*/test/.*",
123*6777b538SAndroid Build Coastguard Worker    r".*/trace_event/.*",
124*6777b538SAndroid Build Coastguard Worker    r".*/tracing/.*",
125*6777b538SAndroid Build Coastguard Worker  ]
126*6777b538SAndroid Build Coastguard Worker
127*6777b538SAndroid Build Coastguard Worker  locations = _FindLocations(input_api, warn_includes, files_to_check,
128*6777b538SAndroid Build Coastguard Worker                             files_to_skip)
129*6777b538SAndroid Build Coastguard Worker  if locations:
130*6777b538SAndroid Build Coastguard Worker    return [ output_api.PresubmitPromptWarning(
131*6777b538SAndroid Build Coastguard Worker        'Please verify that "gn check" and base_unittests still pass with\n' +
132*6777b538SAndroid Build Coastguard Worker        'gn arg "enable_base_tracing = false" when adding typed trace\n' +
133*6777b538SAndroid Build Coastguard Worker        'events to //base. You can use "#if BUILDFLAG(ENABLE_BASE_TRACING)"\n' +
134*6777b538SAndroid Build Coastguard Worker        'to exclude pbzero headers and anything not supported by\n' +
135*6777b538SAndroid Build Coastguard Worker        '//base/trace_event/trace_event_stub.h.\n' +
136*6777b538SAndroid Build Coastguard Worker        '\n'.join(locations)) ]
137*6777b538SAndroid Build Coastguard Worker  return []
138*6777b538SAndroid Build Coastguard Worker
139*6777b538SAndroid Build Coastguard Worker
140*6777b538SAndroid Build Coastguard Workerdef _CommonChecks(input_api, output_api):
141*6777b538SAndroid Build Coastguard Worker  """Checks common to both upload and commit."""
142*6777b538SAndroid Build Coastguard Worker  results = []
143*6777b538SAndroid Build Coastguard Worker  results.extend(_CheckNoInterfacesInBase(input_api, output_api))
144*6777b538SAndroid Build Coastguard Worker  results.extend(_CheckNoTraceEventInclude(input_api, output_api))
145*6777b538SAndroid Build Coastguard Worker  results.extend(_WarnPbzeroIncludes(input_api, output_api))
146*6777b538SAndroid Build Coastguard Worker  results.extend(CheckChangeLintsClean(input_api, output_api))
147*6777b538SAndroid Build Coastguard Worker  return results
148*6777b538SAndroid Build Coastguard Worker
149*6777b538SAndroid Build Coastguard Worker
150*6777b538SAndroid Build Coastguard Workerdef CheckChangeOnUpload(input_api, output_api):
151*6777b538SAndroid Build Coastguard Worker  results = []
152*6777b538SAndroid Build Coastguard Worker  results.extend(_CommonChecks(input_api, output_api))
153*6777b538SAndroid Build Coastguard Worker  return results
154*6777b538SAndroid Build Coastguard Worker
155*6777b538SAndroid Build Coastguard Worker
156*6777b538SAndroid Build Coastguard Workerdef CheckChangeOnCommit(input_api, output_api):
157*6777b538SAndroid Build Coastguard Worker  results = []
158*6777b538SAndroid Build Coastguard Worker  results.extend(_CommonChecks(input_api, output_api))
159*6777b538SAndroid Build Coastguard Worker  return results
160