File: global_payload.py

package info (click to toggle)
mozjs78 78.15.0-7
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 739,892 kB
  • sloc: javascript: 1,344,214; cpp: 1,215,708; python: 526,544; ansic: 433,835; xml: 118,736; sh: 26,176; asm: 16,664; makefile: 11,537; yacc: 4,486; perl: 2,564; ada: 1,681; lex: 1,414; pascal: 1,139; cs: 879; exp: 499; java: 164; ruby: 68; sql: 45; csh: 35; sed: 18; lisp: 2
file content (35 lines) | stat: -rw-r--r-- 1,339 bytes parent folder | download | duplicates (6)
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
# 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/.

from mozlint import result
from mozpack.files import FileFinder
import mozpack.path as mozpath

from external import external


def global_payload(config, **lintargs):
    # A global linter that runs the external linter to actually lint.
    finder = FileFinder(lintargs['root'])
    files = [mozpath.join(lintargs['root'], p) for p, _ in finder.find('files/**')]
    issues = external(files, config, **lintargs)
    for issue in issues:
        # Make issue look like it comes from this linter.
        issue.linter = 'global_payload'
    return issues


def global_skipped(config, **lintargs):
    # A global linter that always registers a lint error.  Absence of
    # this error shows that the path exclusion mechanism can cause
    # global lint payloads to not be invoked at all.  In particular,
    # the `extensions` field means that nothing under `files/**` will
    # match.

    finder = FileFinder(lintargs['root'])
    files = [mozpath.join(lintargs['root'], p) for p, _ in finder.find('files/**')]

    issues = []
    issues.append(result.from_config(
        config, path=files[0], lineno=1, column=1, rule="not-skipped"))