|  | # Copyright 2022 The Dawn & Tint Authors | 
|  | # | 
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | # you may not use this file except in compliance with the License. | 
|  | # You may obtain a copy of the License at | 
|  | # | 
|  | #     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | # | 
|  | # Unless required by applicable law or agreed to in writing, software | 
|  | # distributed under the License is distributed on an "AS IS" BASIS, | 
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | # See the License for the specific language governing permissions and | 
|  | # limitations under the License. | 
|  |  | 
|  | import re | 
|  |  | 
|  | USE_PYTHON3 = True | 
|  |  | 
|  | NONINCLUSIVE_REGEXES = [ | 
|  | r"(?i)black[-_]?list", | 
|  | r"(?i)white[-_]?list", | 
|  | r"(?i)gr[ea]y[-_]?list", | 
|  | r"(?i)(first class citizen)", | 
|  | r"(?i)black[-_]?hat", | 
|  | r"(?i)white[-_]?hat", | 
|  | r"(?i)gr[ea]y[-_]?hat", | 
|  | r"(?i)master", | 
|  | r"(?i)slave", | 
|  | r"(?i)\bhim\b", | 
|  | r"(?i)\bhis\b", | 
|  | r"(?i)\bshe\b", | 
|  | r"(?i)\bher\b", | 
|  | r"(?i)\bguys\b", | 
|  | r"(?i)\bhers\b", | 
|  | r"(?i)\bman\b", | 
|  | r"(?i)\bwoman\b", | 
|  | r"(?i)\she\s", | 
|  | r"(?i)\she$", | 
|  | r"(?i)^he\s", | 
|  | r"(?i)^he$", | 
|  | r"(?i)\she['|\u2019]d\s", | 
|  | r"(?i)\she['|\u2019]d$", | 
|  | r"(?i)^he['|\u2019]d\s", | 
|  | r"(?i)^he['|\u2019]d$", | 
|  | r"(?i)\she['|\u2019]s\s", | 
|  | r"(?i)\she['|\u2019]s$", | 
|  | r"(?i)^he['|\u2019]s\s", | 
|  | r"(?i)^he['|\u2019]s$", | 
|  | r"(?i)\she['|\u2019]ll\s", | 
|  | r"(?i)\she['|\u2019]ll$", | 
|  | r"(?i)^he['|\u2019]ll\s", | 
|  | r"(?i)^he['|\u2019]ll$", | 
|  | r"(?i)grandfather", | 
|  | r"(?i)\bmitm\b", | 
|  | r"(?i)\bcrazy\b", | 
|  | r"(?i)\binsane\b", | 
|  | r"(?i)\bblind\sto\b", | 
|  | r"(?i)\bflying\sblind\b", | 
|  | r"(?i)\bblind\seye\b", | 
|  | r"(?i)\bcripple\b", | 
|  | r"(?i)\bcrippled\b", | 
|  | r"(?i)\bdumb\b", | 
|  | r"(?i)\bdummy\b", | 
|  | r"(?i)\bparanoid\b", | 
|  | r"(?i)\bsane\b", | 
|  | r"(?i)\bsanity\b", | 
|  | r"(?i)red[-_]?line", | 
|  | ] | 
|  |  | 
|  | NONINCLUSIVE_REGEX_LIST = [] | 
|  | for reg in NONINCLUSIVE_REGEXES: | 
|  | NONINCLUSIVE_REGEX_LIST.append(re.compile(reg)) | 
|  |  | 
|  | LINT_FILTERS = [] | 
|  |  | 
|  |  | 
|  | def _CheckNonInclusiveLanguage(input_api, output_api, source_file_filter=None): | 
|  | """Checks the files for non-inclusive language.""" | 
|  |  | 
|  | matches = [] | 
|  | for f in input_api.AffectedFiles(include_deletes=False, | 
|  | file_filter=source_file_filter): | 
|  | line_num = 0 | 
|  | for line in f.NewContents(): | 
|  | line_num += 1 | 
|  | for reg in NONINCLUSIVE_REGEX_LIST: | 
|  | match = reg.search(line) | 
|  | if match: | 
|  | matches.append( | 
|  | "{} ({}): found non-inclusive language: {}".format( | 
|  | f.LocalPath(), line_num, match.group(0))) | 
|  |  | 
|  | if len(matches): | 
|  | return [ | 
|  | output_api.PresubmitPromptWarning("Non-inclusive language found:", | 
|  | items=matches) | 
|  | ] | 
|  |  | 
|  | return [] | 
|  |  | 
|  |  | 
|  | def _NonInclusiveFileFilter(file): | 
|  | filter_list = [ | 
|  | "Doxyfile",  # References to main pages | 
|  | "PRESUBMIT.py",  # Non-inclusive language check data | 
|  | "PRESUBMIT.py.tint",  # Non-inclusive language check data | 
|  | "docs/dawn/debug_markers.md",  # External URL | 
|  | "docs/dawn/infra.md",  # Infra settings | 
|  | "docs/tint/spirv-input-output-variables.md",  # External URL | 
|  | "infra/config/global/generated/cr-buildbucket.cfg",  # Infra settings | 
|  | "infra/config/global/main.star",  # Infra settings | 
|  | "infra/kokoro/windows/build.bat",  # External URL | 
|  | "src/dawn/common/GPUInfo.cpp",  # External URL | 
|  | "src/dawn/native/metal/BackendMTL.mm",  # OSX Constant | 
|  | "src/dawn/native/vulkan/SamplerVk.cpp",  # External URL | 
|  | "src/dawn/native/vulkan/TextureVk.cpp",  # External URL | 
|  | "src/tools/src/cmd/run-cts/main.go",  # Terminal type name | 
|  | "src/dawn/samples/ComputeBoids.cpp",  # External URL | 
|  | "src/dawn/tests/end2end/DepthBiasTests.cpp",  # External URL | 
|  | "src/tint/transform/canonicalize_entry_point_io.cc",  # External URL | 
|  | "test/tint/samples/compute_boids.wgsl",  # External URL | 
|  | "third_party/gn/dxc/BUILD.gn",  # Third party file | 
|  | "third_party/khronos/EGL-Registry/api/KHR/khrplatform.h",  # Third party file | 
|  | "tools/roll-all",  # Branch name | 
|  | "tools/src/container/key.go",  # External URL | 
|  | "go.sum",  # External URL | 
|  | ] | 
|  | return file.LocalPath().replace('\\', '/') not in filter_list | 
|  |  | 
|  |  | 
|  | def _CheckNoStaleGen(input_api, output_api): | 
|  | results = [] | 
|  | try: | 
|  | go = input_api.os_path.join(input_api.change.RepositoryRoot(), "tools", | 
|  | "golang", "bin", "go") | 
|  | if input_api.is_windows: | 
|  | go += '.exe' | 
|  | input_api.subprocess.check_call_out( | 
|  | [go, "run", "tools/src/cmd/gen/main.go", "--check-stale"], | 
|  | stdout=input_api.subprocess.PIPE, | 
|  | stderr=input_api.subprocess.PIPE, | 
|  | cwd=input_api.change.RepositoryRoot()) | 
|  | except input_api.subprocess.CalledProcessError as e: | 
|  | if input_api.is_committing: | 
|  | results.append(output_api.PresubmitError('%s' % (e, ))) | 
|  | else: | 
|  | results.append(output_api.PresubmitPromptWarning('%s' % (e, ))) | 
|  | return results | 
|  |  | 
|  |  | 
|  | def _DoCommonChecks(input_api, output_api): | 
|  | results = [] | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckForCommitObjects(input_api, output_api)) | 
|  | results.extend(_CheckNoStaleGen(input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangedLUCIConfigs(input_api, output_api)) | 
|  |  | 
|  | result_factory = output_api.PresubmitPromptWarning | 
|  | if input_api.is_committing: | 
|  | result_factory = output_api.PresubmitError | 
|  |  | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckPatchFormatted( | 
|  | input_api, | 
|  | output_api, | 
|  | check_python=True, | 
|  | result_factory=result_factory)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeHasDescription( | 
|  | input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckGNFormatted(input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeHasNoCrAndHasOnlyOneEol( | 
|  | input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeHasNoTabs(input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeTodoHasOwner(input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeHasNoStrayWhitespace( | 
|  | input_api, output_api)) | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckDoNotSubmit(input_api, output_api)) | 
|  | # Note, the verbose_level here should match what is set in tools/lint so | 
|  | # the same set of lint errors are reported on the CQ and Kokoro bots. | 
|  | results.extend( | 
|  | input_api.canned_checks.CheckChangeLintsClean( | 
|  | input_api, output_api, lint_filters=LINT_FILTERS, verbose_level=1)) | 
|  | results.extend( | 
|  | _CheckNonInclusiveLanguage(input_api, output_api, | 
|  | _NonInclusiveFileFilter)) | 
|  | return results | 
|  |  | 
|  |  | 
|  | def CheckChangeOnUpload(input_api, output_api): | 
|  | return _DoCommonChecks(input_api, output_api) | 
|  |  | 
|  |  | 
|  | def CheckChangeOnCommit(input_api, output_api): | 
|  | return _DoCommonChecks(input_api, output_api) |