File: PRESUBMIT.py

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (51 lines) | stat: -rw-r--r-- 2,052 bytes parent folder | download | duplicates (7)
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
# Copyright 2021 The Chromium Authors
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

"""Presubmit script for changes affecting components/omnibox/

See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts
for more details about the presubmit API built into depot_tools.
"""

import os

def _CheckPedalsHistograms(input_api, output_api):
  """Check that no `OmniboxPedalId` values were added without also
  changing enums.xml"""
  results = []
  header = next((f for f in input_api.AffectedFiles()
                 if os.path.basename(f.LocalPath()) ==
                 "omnibox_pedal_concepts.h"), None)
  if header != None:
    def count_id_enum_lines(contents):
      indices = list(index for index, element in enumerate(contents)
                     if "NONE = 0" in element or "TOTAL_COUNT" in element)
      if len(indices) == 2:
        return indices[1] - indices[0]
      else:
        return 0
    new_lines = count_id_enum_lines(header.NewContents())
    old_lines = count_id_enum_lines(header.OldContents())
    if old_lines > new_lines:
      results.append(output_api.PresubmitPromptWarning(
          ("OmniboxPedalId enum has lines removed. Ensure that no enum "
           "values were removed since the ID list is append-only.")))
    elif new_lines > old_lines:
      # User seems to have added lines within the enum.
      enums = next((x for x in input_api.change.AffectedFiles()
                    if x.LocalPath().replace(os.sep, '/') ==
                    "tools/metrics/histograms/enums.xml"), None)
      if enums == None:
        results.append(output_api.PresubmitPromptWarning(
            ("OmniboxPedalId enum changed but "
             "tools/metrics/histograms/enums.xml did not. Check that each "
             "ID has a corresponding entry in the SuggestionPedalType enum.")))

  return results

def CheckChangeOnUpload(input_api, output_api):
  results = []
  results.extend(_CheckPedalsHistograms(input_api, output_api))
  return results