diff options
-rw-r--r-- | usr/src/pkg/manifests/developer-build-onbld.mf | 3 | ||||
-rw-r--r-- | usr/src/tools/onbld/Scm/Ignore.py | 91 | ||||
-rw-r--r-- | usr/src/tools/onbld/Scm/Makefile | 2 | ||||
-rw-r--r-- | usr/src/tools/onbld/hgext/cdm.py | 6 | ||||
-rw-r--r-- | usr/src/tools/scripts/git-pbchk.py | 11 |
5 files changed, 103 insertions, 10 deletions
diff --git a/usr/src/pkg/manifests/developer-build-onbld.mf b/usr/src/pkg/manifests/developer-build-onbld.mf index eda7320511..6b9439f5fb 100644 --- a/usr/src/pkg/manifests/developer-build-onbld.mf +++ b/usr/src/pkg/manifests/developer-build-onbld.mf @@ -24,6 +24,7 @@ # Copyright 2010, Richard Lowe # Copyright 2012, Piotr Jasiukajtis # Copyright 2014 Garrett D'Amore <garrett@damore.org> +# Copyright (c) 2014, Joyent, Inc. # set name=pkg.fmri value=pkg:/developer/build/onbld@$(PKGVERS) @@ -170,6 +171,8 @@ file path=opt/onbld/lib/python2.6/onbld/Checks/__init__.py mode=0444 file path=opt/onbld/lib/python2.6/onbld/Checks/__init__.pyc mode=0444 file path=opt/onbld/lib/python2.6/onbld/Scm/Backup.py mode=0444 file path=opt/onbld/lib/python2.6/onbld/Scm/Backup.pyc mode=0444 +file path=opt/onbld/lib/python2.6/onbld/Scm/Ignore.py mode=0444 +file path=opt/onbld/lib/python2.6/onbld/Scm/Ignore.pyc mode=0444 file path=opt/onbld/lib/python2.6/onbld/Scm/Version.py mode=0444 file path=opt/onbld/lib/python2.6/onbld/Scm/Version.pyc mode=0444 file path=opt/onbld/lib/python2.6/onbld/Scm/WorkSpace.py mode=0444 diff --git a/usr/src/tools/onbld/Scm/Ignore.py b/usr/src/tools/onbld/Scm/Ignore.py new file mode 100644 index 0000000000..8b30473103 --- /dev/null +++ b/usr/src/tools/onbld/Scm/Ignore.py @@ -0,0 +1,91 @@ +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +# THE SOFTWARE +# +# Copyright (c) 2014, Joyent, Inc. +# + +''' +Process our ignore/exception_list file format. + +The format is broadly similar, if not identical, to .gitignore and .hgignore +files. +''' + +import re +import fnmatch + +RE_SYNTAX = re.compile(r'^syntax:\s*(.*)\s*$') + +# +# It is important that this module not rely on Mercurial +# + +def _read_ignore_file(ignorefile): + '''Read an ignore file and return an array of regular expressions + to match ignored paths.''' + + syntax = 'regex' + ignore_list = [] + lc = 0 + + with open(ignorefile, 'r') as f: + for l in f: + lc += 1 + # Remove comments and blank lines + l = l.split('#', 2)[0].strip() + if l == '': + continue + # Process "syntax:" lines + m = RE_SYNTAX.match(l) + if m: + syntax = m.group(1) + continue + # All other lines are considered patterns + if (syntax == 'glob'): + ignore_list.append(re.compile('.*' + fnmatch.translate(l))) + elif (syntax == 'regex'): + ignore_list.append(re.compile(l)) + else: + raise Exception('%s:%d: syntax "%s" is not supported' % + (ignorefile, lc, syntax)) + + return ignore_list + +def ignore(root, ignorefiles): + # If we aren't provided any ignore files, we'll never ignore + # any paths: + if (len(ignorefiles) < 1): + return lambda x: False + + ignore_list = [] + for ignorefile in ignorefiles: + ignore_list.extend(_read_ignore_file(ignorefile)) + + # If the ignore files contained no patterns, we'll never ignore + # any paths: + if (len(ignore_list) < 1): + return lambda x: False + + def _ignore_func(path): + for regex in ignore_list: + if (regex.match(path)): + return True + return False + + return _ignore_func diff --git a/usr/src/tools/onbld/Scm/Makefile b/usr/src/tools/onbld/Scm/Makefile index a31f7e5c87..a71883c297 100644 --- a/usr/src/tools/onbld/Scm/Makefile +++ b/usr/src/tools/onbld/Scm/Makefile @@ -21,6 +21,7 @@ # # Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, Joyent, Inc. # include $(SRC)/Makefile.master @@ -29,6 +30,7 @@ include ../../Makefile.tools PYSRCS = \ __init__.py \ Backup.py \ + Ignore.py \ Version.py \ WorkSpace.py diff --git a/usr/src/tools/onbld/hgext/cdm.py b/usr/src/tools/onbld/hgext/cdm.py index f92ba5a75d..28e45ed9a0 100644 --- a/usr/src/tools/onbld/hgext/cdm.py +++ b/usr/src/tools/onbld/hgext/cdm.py @@ -17,6 +17,7 @@ # Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. # Copyright 2008, 2011 Richard Lowe # Copyright 2014 Garrett D'Amore <garrett@damore.org> +# Copyright (c) 2014, Joyent, Inc. # '''OpenSolaris extensions to Mercurial @@ -93,6 +94,7 @@ sys.path.insert(1, os.path.join(os.path.dirname(__file__), "..", "..", "..", sys.path.insert(2, os.path.join(os.path.dirname(__file__), "..", "..")) from onbld.Scm import Version +from onbld.Scm import Ignore from mercurial import util try: @@ -100,7 +102,7 @@ try: except Version.VersionMismatch, badversion: raise util.Abort("Version Mismatch:\n %s\n" % badversion) -from mercurial import cmdutil, ignore, node, patch +from mercurial import cmdutil, node, patch from onbld.Scm.WorkSpace import WorkSpace, WorkList from onbld.Scm.Backup import CdmBackup @@ -168,7 +170,7 @@ def not_check(repo, cmd): ignorefiles.append(f) if ignorefiles: - ign = ignore.ignore(repo.root, ignorefiles, repo.ui.warn) + ign = Ignore.ignore(repo.root, ignorefiles) return canonified_check(ign) else: return util.never diff --git a/usr/src/tools/scripts/git-pbchk.py b/usr/src/tools/scripts/git-pbchk.py index 55d80d8f3f..fd16e109b2 100644 --- a/usr/src/tools/scripts/git-pbchk.py +++ b/usr/src/tools/scripts/git-pbchk.py @@ -18,6 +18,7 @@ # Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. # Copyright 2008, 2012 Richard Lowe # Copyright 2014 Garrett D'Amore <garrett@damore.org> +# Copyright (c) 2014, Joyent, Inc. # import getopt @@ -29,10 +30,6 @@ import tempfile from cStringIO import StringIO -# This is necessary because, in a fit of pique, we used hg-format ignore lists -# for NOT files. -from mercurial import ignore - # # Adjust the load path based on our location and the version of python into # which it is being loaded. This assumes the normal onbld directory @@ -48,6 +45,7 @@ sys.path.insert(1, os.path.join(os.path.dirname(__file__), "..", "lib", # sys.path.insert(2, os.path.join(os.path.dirname(__file__), "..")) +from onbld.Scm import Ignore from onbld.Checks import Comments, Copyright, CStyle, HdrChk from onbld.Checks import JStyle, Keywords, ManLint, Mapfile @@ -178,10 +176,7 @@ def not_check(root, cmd): ignorefiles = filter(os.path.exists, [os.path.join(root, ".git", "%s.NOT" % cmd), os.path.join(root, "exception_lists", cmd)]) - if len(ignorefiles) > 0: - return ignore.ignore(root, ignorefiles, sys.stderr.write) - else: - return lambda x: False + return Ignore.ignore(root, ignorefiles) def gen_files(root, parent, paths, exclude): |