commit:     77ace9803734d2ba6761f17770a41af5bf7eb870
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  4 04:44:05 2016 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Wed Jan  6 04:08:24 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=77ace980

repoman: Create new EncodingCheck class plugin

 pym/repoman/modules/scan/directories/__init__.py |  8 +++++
 pym/repoman/modules/scan/directories/encoding.py | 41 ++++++++++++++++++++++++
 pym/repoman/scanner.py                           | 21 +-----------
 3 files changed, 50 insertions(+), 20 deletions(-)

diff --git a/pym/repoman/modules/scan/directories/__init__.py 
b/pym/repoman/modules/scan/directories/__init__.py
index b9daef0..548d393 100644
--- a/pym/repoman/modules/scan/directories/__init__.py
+++ b/pym/repoman/modules/scan/directories/__init__.py
@@ -26,6 +26,14 @@ module_spec = {
                        'func_kwargs': {
                        },
                },
+               'encoding-module': {
+                       'name': "encoding",
+                       'class': "EncodingCheck",
+                       'description': doc,
+                       'functions': ['check'],
+                       'func_kwargs': {
+                       },
+               },
        }
 }
 

diff --git a/pym/repoman/modules/scan/directories/encoding.py 
b/pym/repoman/modules/scan/directories/encoding.py
new file mode 100644
index 0000000..0985e16
--- /dev/null
+++ b/pym/repoman/modules/scan/directories/encoding.py
@@ -0,0 +1,41 @@
+
+import io
+
+from portage import _encodings
+from portage import _unicode_encode
+
+from repoman.checks.ebuilds.checks import run_checks
+
+
+class EncodingCheck(object):
+
+       def __init__(self, **kwargs):
+               self.qatracker = kwargs.get('qatracker')
+
+       def check(self, **kwargs):
+               ebuild = kwargs.get('ebuild')
+               pkg = kwargs.get('pkg')
+               try:
+                       # All ebuilds should have utf_8 encoding.
+                       f = io.open(
+                               _unicode_encode(ebuild.full_path, 
encoding=_encodings['fs'],
+                                       errors='strict'),
+                               mode='r', encoding=_encodings['repo.content'])
+                       try:
+                               for check_name, e in run_checks(f, pkg):
+                                       self.qatracker.add_error(
+                                               check_name, 
ebuild.relative_path + ': %s' % e)
+                       finally:
+                               f.close()
+               except UnicodeDecodeError:
+                       # A file.UTF8 failure will have already been recorded.
+                       pass
+               return {'continue': False}
+
+       @property
+       def runInPkgs(self):
+               return (False, [])
+
+       @property
+       def runInEbuilds(self):
+               return (True, [self.check])

diff --git a/pym/repoman/scanner.py b/pym/repoman/scanner.py
index 7640dca..b6d2441 100644
--- a/pym/repoman/scanner.py
+++ b/pym/repoman/scanner.py
@@ -3,7 +3,6 @@
 from __future__ import print_function, unicode_literals
 
 import copy
-import io
 import logging
 from itertools import chain
 from pprint import pformat
@@ -13,11 +12,8 @@ from _emerge.Package import Package
 import portage
 from portage import normalize_path
 from portage import os
-from portage import _encodings
-from portage import _unicode_encode
 from portage.dep import Atom
 from portage.output import green
-from repoman.checks.ebuilds.checks import run_checks
 from repoman.modules.commit import repochecks
 from repoman.profile import check_profiles, dev_profile_keywords, setup_profile
 from repoman.repos import repo_metadata
@@ -295,7 +291,7 @@ class Scanner(object):
                                ('arches', 'ArchChecks'), ('depend', 
'DependChecks'),
                                ('use_flags', 'USEFlagChecks'), ('ruby', 
'RubyEclassChecks'),
                                ('license', 'LicenseChecks'), ('restrict', 
'RestrictChecks'),
-                               ('mtime', 'MtimeChecks'),
+                               ('mtime', 'MtimeChecks'), ('encoding', 
'EncodingCheck'),
                                ]:
                                if mod[0]:
                                        mod_class = 
MODULE_CONTROLLER.get_class(mod[0])
@@ -327,21 +323,6 @@ class Scanner(object):
                        print("**** finished plugin loop, continuing...")
 
                        # Syntax Checks
-                       try:
-                               # All ebuilds should have utf_8 encoding.
-                               f = io.open(
-                                       _unicode_encode(
-                                               
dynamic_data['ebuild'].full_path, encoding=_encodings['fs'], errors='strict'),
-                                       mode='r', 
encoding=_encodings['repo.content'])
-                               try:
-                                       for check_name, e in run_checks(f, 
dynamic_data['pkg']):
-                                               self.qatracker.add_error(
-                                                       check_name, 
dynamic_data['ebuild'].relative_path + ': %s' % e)
-                               finally:
-                                       f.close()
-                       except UnicodeDecodeError:
-                               # A file.UTF8 failure will have already been 
recorded above.
-                               pass
 
                        if self.options.force:
                                # The dep_check() calls are the most expensive 
QA test. If --force

Reply via email to