browser/locales/filter.py
author Sebastian Hengst <archaeopteryx@coole-files.de>
Mon, 22 May 2017 16:20:56 +0200
changeset 582577 c36497319158aaaf1ba7e28754e9b59b9cf3c441
parent 466600 8d9a2e5cbc2c76b469f2f406a781c8e060cdd513
child 573297 6a7fee66e9e1dd6cbea10823dab33841b6c7ff20
child 585516 8cc969aa0d37a0688b8bbf2c52050ab1844473d2
child 589323 848449c6c95344daa7c15d2ce5adf2e4ac84c78b
child 589450 59217a8c03c3f8d8c2bbe0a964820198e49a6fc1
child 589545 84b91253b66d733229ee93c06e636862105b4319
permissions -rwxr-xr-x
Backed out changeset 78e8b1f01c25 (bug 1361661) for flake8 linting failures in gen-process-{data,enum}.py and build bustage in TelemetryProcessData.h on OS X, at least. r=backout on a CLOSED TREE

# 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/.

def test(mod, path, entity = None):
  import re
  # ignore anything but Firefox
  if mod not in ("netwerk", "dom", "toolkit", "security/manager",
                 "devtools/client", "devtools/shared",
                 "browser",
                 "browser/extensions/webcompat-reporter",
                 "extensions/spellcheck",
                 "other-licenses/branding/firefox",
                 "browser/branding/official",
                 "services/sync"):
    return "ignore"
  if mod not in ("browser", "extensions/spellcheck"):
    # we only have exceptions for browser and extensions/spellcheck
    return "error"
  if not entity:
    # the only files to ignore are spell checkers
    if mod == "extensions/spellcheck":
      return "ignore"
    return "error"
  if mod == "extensions/spellcheck":
    # l10n ships en-US dictionary or something, do compare
    return "error"
  if path == "defines.inc":
    return "ignore" if entity == "MOZ_LANGPACK_CONTRIBUTORS" else "error"

  if mod == "browser" and path == "chrome/browser-region/region.properties":
    # only region.properties exceptions remain, compare all others
    return ("ignore"
            if (re.match(r"browser\.search\.order\.[1-9]", entity) or
                re.match(r"browser\.contentHandlers\.types\.[0-5]", entity) or
                re.match(r"gecko\.handlerService\.schemes\.", entity) or
                re.match(r"gecko\.handlerService\.defaultHandlersVersion", entity))
            else "error")
  return "error"