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