mirror of https://github.com/ARMmbed/mbed-os.git
Refactor mbedignore behaivor into an object
parent
4ef12ccdbc
commit
ff05e3ebd5
|
|
@ -41,6 +41,8 @@ from os import walk, sep
|
|||
from os.path import (join, splitext, dirname, relpath, basename, split, normcase,
|
||||
abspath, exists)
|
||||
|
||||
from .ignore import MbedIgnoreSet, IGNORE_FILENAME
|
||||
|
||||
# Support legacy build conventions: the original mbed build system did not have
|
||||
# standard labels for the "TARGET_" and "TOOLCHAIN_" specific directories, but
|
||||
# had the knowledge of a list of these directories to be ignored.
|
||||
|
|
@ -143,10 +145,7 @@ class Resources(object):
|
|||
# Path seperator style (defaults to OS-specific seperator)
|
||||
self._sep = sep
|
||||
|
||||
# Ignore patterns from .mbedignore files and add_ignore_patters
|
||||
self._ignore_patterns = []
|
||||
self._ignore_regex = re.compile("$^")
|
||||
|
||||
self._ignoreset = MbedIgnoreSet()
|
||||
|
||||
def ignore_dir(self, directory):
|
||||
if self._collect_ignores:
|
||||
|
|
@ -241,27 +240,9 @@ class Resources(object):
|
|||
self._legacy_ignore_dirs -= set(
|
||||
[toolchain.target.name, LEGACY_TOOLCHAIN_NAMES[toolchain.name]])
|
||||
|
||||
def is_ignored(self, file_path):
|
||||
"""Check if file path is ignored by any .mbedignore thus far"""
|
||||
return self._ignore_regex.match(normcase(file_path))
|
||||
|
||||
def add_ignore_patterns(self, root, base_path, patterns):
|
||||
"""Add a series of patterns to the ignored paths
|
||||
|
||||
Positional arguments:
|
||||
root - the directory containing the ignore file
|
||||
base_path - the location that the scan started from
|
||||
patterns - the list of patterns we will ignore in the future
|
||||
"""
|
||||
real_base = relpath(root, base_path)
|
||||
if real_base == ".":
|
||||
self._ignore_patterns.extend(normcase(p) for p in patterns)
|
||||
else:
|
||||
self._ignore_patterns.extend(
|
||||
normcase(join(real_base, pat)) for pat in patterns)
|
||||
if self._ignore_patterns:
|
||||
self._ignore_regex = re.compile("|".join(
|
||||
fnmatch.translate(p) for p in self._ignore_patterns))
|
||||
self._ignoreset.add_ignore_patterns(real_base, patterns)
|
||||
|
||||
def _not_current_label(self, dirname, label_type):
|
||||
return (dirname.startswith(label_type + "_") and
|
||||
|
|
@ -405,15 +386,13 @@ class Resources(object):
|
|||
|
||||
for root, dirs, files in walk(path, followlinks=True):
|
||||
# Check if folder contains .mbedignore
|
||||
if ".mbedignore" in files:
|
||||
with open (join(root,".mbedignore"), "r") as f:
|
||||
lines=f.readlines()
|
||||
lines = [l.strip() for l in lines
|
||||
if l.strip() != "" and not l.startswith("#")]
|
||||
self.add_ignore_patterns(root, base_path, lines)
|
||||
if IGNORE_FILENAME in files:
|
||||
real_base = relpath(root, base_path)
|
||||
self._ignoreset.add_mbedignore(
|
||||
real_base, join(root, IGNORE_FILENAME))
|
||||
|
||||
root_path =join(relpath(root, base_path))
|
||||
if self.is_ignored(join(root_path,"")):
|
||||
if self._ignoreset.is_ignored(join(root_path,"")):
|
||||
self.ignore_dir(root_path)
|
||||
dirs[:] = []
|
||||
continue
|
||||
|
|
@ -430,7 +409,7 @@ class Resources(object):
|
|||
self.ignore_dir(dir_path)
|
||||
dirs.remove(d)
|
||||
elif (d.startswith('.') or d in self._legacy_ignore_dirs or
|
||||
self.is_ignored(join(root_path, d, ""))):
|
||||
self._ignoreset.is_ignored(join(root_path, d, ""))):
|
||||
self.ignore_dir(dir_path)
|
||||
dirs.remove(d)
|
||||
|
||||
|
|
@ -472,7 +451,7 @@ class Resources(object):
|
|||
scanning starting as base_path
|
||||
"""
|
||||
|
||||
if (self.is_ignored(relpath(file_path, base_path)) or
|
||||
if (self._ignoreset.is_ignored(relpath(file_path, base_path)) or
|
||||
basename(file_path).startswith(".")):
|
||||
self.ignore_dir(relpath(file_path, base_path))
|
||||
return
|
||||
|
|
@ -550,3 +529,4 @@ class Resources(object):
|
|||
self.add_directory(path)
|
||||
config.load_resources(self)
|
||||
return self
|
||||
|
||||
|
|
|
|||
|
|
@ -0,0 +1,69 @@
|
|||
# mbed SDK
|
||||
# Copyright (c) 2011-2013 ARM Limited
|
||||
#
|
||||
# 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 fnmatch
|
||||
import re
|
||||
from os.path import normcase, join
|
||||
|
||||
|
||||
IGNORE_FILENAME = ".mbedignore"
|
||||
|
||||
|
||||
class MbedIgnoreSet(object):
|
||||
"""
|
||||
# The mbedignore rules as an object
|
||||
|
||||
A project in Mbed OS contains metadata files that exclude files from a build.
|
||||
These rules are stored as `fnmatch` patterns in text in a files named `.mbedignore`.
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self._ignore_patterns = []
|
||||
self._ignore_regex = re.compile("$^")
|
||||
|
||||
def is_ignored(self, file_path):
|
||||
"""Check if file path is ignored by any .mbedignore thus far"""
|
||||
return self._ignore_regex.match(normcase(file_path))
|
||||
|
||||
def add_ignore_patterns(self, in_name, patterns):
|
||||
"""Ignore all files and directories matching the paterns in
|
||||
directories named by in_name.
|
||||
|
||||
Positional arguments:
|
||||
in_name - the filename prefix that this ignore will apply to
|
||||
patterns - the list of patterns we will ignore in the future
|
||||
"""
|
||||
if in_name == ".":
|
||||
self._ignore_patterns.extend(normcase(p) for p in patterns)
|
||||
else:
|
||||
self._ignore_patterns.extend(
|
||||
normcase(join(in_name, pat)) for pat in patterns)
|
||||
if self._ignore_patterns:
|
||||
self._ignore_regex = re.compile("|".join(
|
||||
fnmatch.translate(p) for p in self._ignore_patterns))
|
||||
|
||||
def add_mbedignore(self, in_name, filepath):
|
||||
"""Add a series of patterns to the ignored paths
|
||||
|
||||
Positional arguments:
|
||||
in_name - the filename prefix that this ignore will apply to
|
||||
patterns - the list of patterns we will ignore in the future
|
||||
"""
|
||||
with open (filepath) as f:
|
||||
patterns = [l.strip() for l in f
|
||||
if l.strip() != "" and not l.startswith("#")]
|
||||
self.add_ignore_patterns(in_name, patterns)
|
||||
|
||||
|
||||
Loading…
Reference in New Issue