| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | """distutils.command.check
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Implements the Distutils 'check' command. | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | from distutils.core import Command | 
					
						
							|  |  |  | from distutils.errors import DistutilsSetupError | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     # docutils is installed | 
					
						
							|  |  |  |     from docutils.utils import Reporter | 
					
						
							|  |  |  |     from docutils.parsers.rst import Parser | 
					
						
							|  |  |  |     from docutils import frontend | 
					
						
							|  |  |  |     from docutils import nodes | 
					
						
							| 
									
										
										
										
											2010-10-03 14:18:09 +00:00
										 |  |  |     from io import StringIO | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     class SilentReporter(Reporter): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def __init__(self, source, report_level, halt_level, stream=None, | 
					
						
							|  |  |  |                      debug=0, encoding='ascii', error_handler='replace'): | 
					
						
							|  |  |  |             self.messages = [] | 
					
						
							|  |  |  |             Reporter.__init__(self, source, report_level, halt_level, stream, | 
					
						
							|  |  |  |                               debug, encoding, error_handler) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def system_message(self, level, message, *children, **kwargs): | 
					
						
							|  |  |  |             self.messages.append((level, message, children, kwargs)) | 
					
						
							| 
									
										
										
										
											2012-12-08 22:41:11 -05:00
										 |  |  |             return nodes.system_message(message, level=level, | 
					
						
							|  |  |  |                                         type=self.levels[level], | 
					
						
							|  |  |  |                                         *children, **kwargs) | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     HAS_DOCUTILS = True | 
					
						
							| 
									
										
											  
											
												Merged revisions 70912,70944,70968,71033,71041,71208,71263,71286,71395-71396,71405-71406,71485,71492,71494 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r70912 | georg.brandl | 2009-03-31 17:35:46 -0500 (Tue, 31 Mar 2009) | 1 line
  #5617: add a handy function to print a unicode string to gdbinit.
........
  r70944 | georg.brandl | 2009-03-31 23:32:39 -0500 (Tue, 31 Mar 2009) | 1 line
  #5631: add upload to list of possible commands, which is presented in --help-commands.
........
  r70968 | michael.foord | 2009-04-01 13:25:38 -0500 (Wed, 01 Apr 2009) | 1 line
  Adding Wing project file
........
  r71033 | brett.cannon | 2009-04-01 22:34:53 -0500 (Wed, 01 Apr 2009) | 3 lines
  Fix two issues introduced by issue #71031 by changing the signature of
  PyImport_AppendInittab() to take a const char *.
........
  r71041 | jesse.noller | 2009-04-02 00:17:26 -0500 (Thu, 02 Apr 2009) | 1 line
  Add custom initializer argument to multiprocess.Manager*, courtesy of lekma
........
  r71208 | michael.foord | 2009-04-04 20:15:01 -0500 (Sat, 04 Apr 2009) | 4 lines
  Change the way unittest.TestSuite use their tests to always access them through iteration. Non behavior changing, this allows you to create custom subclasses that override __iter__.
  Issue #5693
........
  r71263 | michael.foord | 2009-04-05 14:19:28 -0500 (Sun, 05 Apr 2009) | 4 lines
  Adding assertIs and assertIsNot methods to unittest.TestCase
  Issue #2578
........
  r71286 | tarek.ziade | 2009-04-05 17:04:38 -0500 (Sun, 05 Apr 2009) | 1 line
  added a simplest test to distutils.spawn._nt_quote_args
........
  r71395 | benjamin.peterson | 2009-04-08 08:27:29 -0500 (Wed, 08 Apr 2009) | 1 line
  these must be installed to correctly run tests
........
  r71396 | benjamin.peterson | 2009-04-08 08:29:41 -0500 (Wed, 08 Apr 2009) | 1 line
  fix syntax
........
  r71405 | andrew.kuchling | 2009-04-09 06:22:47 -0500 (Thu, 09 Apr 2009) | 1 line
  Add items
........
  r71406 | andrew.kuchling | 2009-04-09 06:23:36 -0500 (Thu, 09 Apr 2009) | 1 line
  Typo fixes
........
  r71485 | andrew.kuchling | 2009-04-11 11:12:23 -0500 (Sat, 11 Apr 2009) | 1 line
  Add various items
........
  r71492 | georg.brandl | 2009-04-11 13:19:27 -0500 (Sat, 11 Apr 2009) | 1 line
  Take credit for a patch of mine.
........
  r71494 | benjamin.peterson | 2009-04-11 14:31:00 -0500 (Sat, 11 Apr 2009) | 1 line
  ignore py3_test_grammar when compiling the library
........
											
										 
											2009-04-11 20:45:40 +00:00
										 |  |  | except Exception: | 
					
						
							|  |  |  |     # Catch all exceptions because exceptions besides ImportError probably | 
					
						
							|  |  |  |     # indicate that docutils is not ported to Py3k. | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |     HAS_DOCUTILS = False | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class check(Command): | 
					
						
							|  |  |  |     """This command checks the meta-data of the package.
 | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     description = ("perform some checks on the package") | 
					
						
							|  |  |  |     user_options = [('metadata', 'm', 'Verify meta-data'), | 
					
						
							|  |  |  |                     ('restructuredtext', 'r', | 
					
						
							|  |  |  |                      ('Checks if long string meta-data syntax ' | 
					
						
							|  |  |  |                       'are reStructuredText-compliant')), | 
					
						
							|  |  |  |                     ('strict', 's', | 
					
						
							|  |  |  |                      'Will exit with an error if a check fails')] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     boolean_options = ['metadata', 'restructuredtext', 'strict'] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def initialize_options(self): | 
					
						
							|  |  |  |         """Sets default values for options.""" | 
					
						
							|  |  |  |         self.restructuredtext = 0 | 
					
						
							|  |  |  |         self.metadata = 1 | 
					
						
							|  |  |  |         self.strict = 0 | 
					
						
							|  |  |  |         self._warnings = 0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def finalize_options(self): | 
					
						
							|  |  |  |         pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def warn(self, msg): | 
					
						
							|  |  |  |         """Counts the number of warnings that occurs.""" | 
					
						
							|  |  |  |         self._warnings += 1 | 
					
						
							|  |  |  |         return Command.warn(self, msg) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def run(self): | 
					
						
							|  |  |  |         """Runs the command.""" | 
					
						
							|  |  |  |         # perform the various tests | 
					
						
							|  |  |  |         if self.metadata: | 
					
						
							|  |  |  |             self.check_metadata() | 
					
						
							|  |  |  |         if self.restructuredtext: | 
					
						
							| 
									
										
										
										
											2009-04-11 15:17:04 +00:00
										 |  |  |             if HAS_DOCUTILS: | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |                 self.check_restructuredtext() | 
					
						
							|  |  |  |             elif self.strict: | 
					
						
							|  |  |  |                 raise DistutilsSetupError('The docutils package is needed.') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # let's raise an error in strict mode, if we have at least | 
					
						
							|  |  |  |         # one warning | 
					
						
							| 
									
										
										
										
											2009-04-17 14:34:49 +00:00
										 |  |  |         if self.strict and self._warnings > 0: | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |             raise DistutilsSetupError('Please correct your package.') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def check_metadata(self): | 
					
						
							|  |  |  |         """Ensures that all required elements of meta-data are supplied.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         name, version, URL, (author and author_email) or | 
					
						
							|  |  |  |         (maintainer and maintainer_email)). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Warns if any are missing. | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         metadata = self.distribution.metadata | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         missing = [] | 
					
						
							|  |  |  |         for attr in ('name', 'version', 'url'): | 
					
						
							|  |  |  |             if not (hasattr(metadata, attr) and getattr(metadata, attr)): | 
					
						
							|  |  |  |                 missing.append(attr) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if missing: | 
					
						
							| 
									
										
											  
											
												Merged revisions 75149,75260-75263,75265-75267,75292,75300,75376,75405,75429-75433,75437,75445,75501,75551,75572,75589-75591,75657,75742,75868,75952-75957,76057,76105,76139,76143,76162,76223 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r75149 | gregory.p.smith | 2009-09-29 16:56:31 -0500 (Tue, 29 Sep 2009) | 3 lines
  Mention issue6972 in extractall docs about overwriting things outside of
  the supplied path.
........
  r75260 | andrew.kuchling | 2009-10-05 16:24:20 -0500 (Mon, 05 Oct 2009) | 1 line
  Wording fix
........
  r75261 | andrew.kuchling | 2009-10-05 16:24:35 -0500 (Mon, 05 Oct 2009) | 1 line
  Fix narkup
........
  r75262 | andrew.kuchling | 2009-10-05 16:25:03 -0500 (Mon, 05 Oct 2009) | 1 line
  Document 'skip' parameter to constructor
........
  r75263 | andrew.kuchling | 2009-10-05 16:25:35 -0500 (Mon, 05 Oct 2009) | 1 line
  Note side benefit of socket.create_connection()
........
  r75265 | andrew.kuchling | 2009-10-05 17:31:11 -0500 (Mon, 05 Oct 2009) | 1 line
  Reword sentence
........
  r75266 | andrew.kuchling | 2009-10-05 17:32:48 -0500 (Mon, 05 Oct 2009) | 1 line
  Use standard comma punctuation; reword some sentences in the docs
........
  r75267 | andrew.kuchling | 2009-10-05 17:42:56 -0500 (Mon, 05 Oct 2009) | 1 line
  Backport r73983: Document the thousands separator.
........
  r75292 | benjamin.peterson | 2009-10-08 22:11:36 -0500 (Thu, 08 Oct 2009) | 1 line
  death to old CVS keyword
........
  r75300 | benjamin.peterson | 2009-10-09 16:48:14 -0500 (Fri, 09 Oct 2009) | 1 line
  fix some coding style
........
  r75376 | benjamin.peterson | 2009-10-11 20:26:07 -0500 (Sun, 11 Oct 2009) | 1 line
  platform we don't care about
........
  r75405 | neil.schemenauer | 2009-10-14 12:17:14 -0500 (Wed, 14 Oct 2009) | 4 lines
  Issue #1754094: Improve the stack depth calculation in the compiler.
  There should be no other effect than a small decrease in memory use.
  Patch by Christopher Tur Lesniewski-Laas.
........
  r75429 | benjamin.peterson | 2009-10-14 20:47:28 -0500 (Wed, 14 Oct 2009) | 1 line
  pep8ify if blocks
........
  r75430 | benjamin.peterson | 2009-10-14 20:49:37 -0500 (Wed, 14 Oct 2009) | 1 line
  use floor division and add a test that exercises the tabsize codepath
........
  r75431 | benjamin.peterson | 2009-10-14 20:56:25 -0500 (Wed, 14 Oct 2009) | 1 line
  change test to what I intended
........
  r75432 | benjamin.peterson | 2009-10-14 22:05:39 -0500 (Wed, 14 Oct 2009) | 1 line
  some cleanups
........
  r75433 | benjamin.peterson | 2009-10-14 22:06:55 -0500 (Wed, 14 Oct 2009) | 1 line
  make inspect.isabstract() always return a boolean; add a test for it, too #7069
........
  r75437 | benjamin.peterson | 2009-10-15 10:44:46 -0500 (Thu, 15 Oct 2009) | 1 line
  only clear a module's __dict__ if the module is the only one with a reference to it #7140
........
  r75445 | vinay.sajip | 2009-10-16 09:06:44 -0500 (Fri, 16 Oct 2009) | 1 line
  Issue #7120: logging: Removed import of multiprocessing which is causing crash in GAE.
........
  r75501 | antoine.pitrou | 2009-10-18 13:37:11 -0500 (Sun, 18 Oct 2009) | 3 lines
  Add a comment about unreachable code, and fix a typo
........
  r75551 | benjamin.peterson | 2009-10-19 22:14:10 -0500 (Mon, 19 Oct 2009) | 1 line
  use property api
........
  r75572 | benjamin.peterson | 2009-10-20 16:55:17 -0500 (Tue, 20 Oct 2009) | 1 line
  clarify buffer arg #7178
........
  r75589 | benjamin.peterson | 2009-10-21 21:26:47 -0500 (Wed, 21 Oct 2009) | 1 line
  whitespace
........
  r75590 | benjamin.peterson | 2009-10-21 21:36:47 -0500 (Wed, 21 Oct 2009) | 1 line
  rewrite to be nice to other implementations
........
  r75591 | benjamin.peterson | 2009-10-21 21:50:38 -0500 (Wed, 21 Oct 2009) | 4 lines
  rewrite for style, clarify, and comments
  Also, use the hasattr() like scheme of allowing BaseException exceptions through.
........
  r75657 | antoine.pitrou | 2009-10-24 07:41:27 -0500 (Sat, 24 Oct 2009) | 3 lines
  Fix compilation error in debug mode.
........
  r75742 | benjamin.peterson | 2009-10-26 17:51:16 -0500 (Mon, 26 Oct 2009) | 1 line
  use 'is' instead of id()
........
  r75868 | benjamin.peterson | 2009-10-27 15:59:18 -0500 (Tue, 27 Oct 2009) | 1 line
  test expect base classes
........
  r75952 | georg.brandl | 2009-10-29 15:38:32 -0500 (Thu, 29 Oct 2009) | 1 line
  Use the correct function name in docstring.
........
  r75953 | georg.brandl | 2009-10-29 15:39:50 -0500 (Thu, 29 Oct 2009) | 1 line
  Remove mention of the old -X command line switch.
........
  r75954 | georg.brandl | 2009-10-29 15:53:00 -0500 (Thu, 29 Oct 2009) | 1 line
  Use constants instead of magic integers for test result.  Do not re-run with --verbose3 for environment changing tests.
........
  r75955 | georg.brandl | 2009-10-29 15:54:03 -0500 (Thu, 29 Oct 2009) | 1 line
  Use a single style for all the docstrings in the math module.
........
  r75956 | georg.brandl | 2009-10-29 16:16:34 -0500 (Thu, 29 Oct 2009) | 1 line
  I do not think the "railroad" program mentioned is still available.
........
  r75957 | georg.brandl | 2009-10-29 16:44:56 -0500 (Thu, 29 Oct 2009) | 1 line
  Fix constant name.
........
  r76057 | benjamin.peterson | 2009-11-02 09:06:45 -0600 (Mon, 02 Nov 2009) | 1 line
  prevent a rather unlikely segfault
........
  r76105 | georg.brandl | 2009-11-04 01:38:12 -0600 (Wed, 04 Nov 2009) | 1 line
  #7259: show correct equivalent for operator.i* operations in docstring; fix minor issues in operator docs.
........
  r76139 | benjamin.peterson | 2009-11-06 19:04:38 -0600 (Fri, 06 Nov 2009) | 1 line
  spelling
........
  r76143 | georg.brandl | 2009-11-07 02:26:07 -0600 (Sat, 07 Nov 2009) | 1 line
  #7271: fix typo.
........
  r76162 | benjamin.peterson | 2009-11-08 22:10:53 -0600 (Sun, 08 Nov 2009) | 1 line
  discuss how to use -p
........
  r76223 | georg.brandl | 2009-11-12 02:29:46 -0600 (Thu, 12 Nov 2009) | 1 line
  Give the profile module a module directive.
........
											
										 
											2009-11-13 02:25:08 +00:00
										 |  |  |             self.warn("missing required meta-data: %s"  % ', '.join(missing)) | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |         if metadata.author: | 
					
						
							|  |  |  |             if not metadata.author_email: | 
					
						
							|  |  |  |                 self.warn("missing meta-data: if 'author' supplied, " + | 
					
						
							|  |  |  |                           "'author_email' must be supplied too") | 
					
						
							|  |  |  |         elif metadata.maintainer: | 
					
						
							|  |  |  |             if not metadata.maintainer_email: | 
					
						
							|  |  |  |                 self.warn("missing meta-data: if 'maintainer' supplied, " + | 
					
						
							|  |  |  |                           "'maintainer_email' must be supplied too") | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.warn("missing meta-data: either (author and author_email) " + | 
					
						
							|  |  |  |                       "or (maintainer and maintainer_email) " + | 
					
						
							|  |  |  |                       "must be supplied") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def check_restructuredtext(self): | 
					
						
							|  |  |  |         """Checks if the long string fields are reST-compliant.""" | 
					
						
							|  |  |  |         data = self.distribution.get_long_description() | 
					
						
							|  |  |  |         for warning in self._check_rst_data(data): | 
					
						
							|  |  |  |             line = warning[-1].get('line') | 
					
						
							|  |  |  |             if line is None: | 
					
						
							|  |  |  |                 warning = warning[1] | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 warning = '%s (line %s)' % (warning[1], line) | 
					
						
							|  |  |  |             self.warn(warning) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def _check_rst_data(self, data): | 
					
						
							|  |  |  |         """Returns warnings when the provided data doesn't compile.""" | 
					
						
							|  |  |  |         source_path = StringIO() | 
					
						
							|  |  |  |         parser = Parser() | 
					
						
							| 
									
										
										
										
											2015-01-14 23:56:35 -05:00
										 |  |  |         settings = frontend.OptionParser(components=(Parser,)).get_default_values() | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |         settings.tab_width = 4 | 
					
						
							|  |  |  |         settings.pep_references = None | 
					
						
							|  |  |  |         settings.rfc_references = None | 
					
						
							|  |  |  |         reporter = SilentReporter(source_path, | 
					
						
							|  |  |  |                           settings.report_level, | 
					
						
							|  |  |  |                           settings.halt_level, | 
					
						
							|  |  |  |                           stream=settings.warning_stream, | 
					
						
							|  |  |  |                           debug=settings.debug, | 
					
						
							|  |  |  |                           encoding=settings.error_encoding, | 
					
						
							|  |  |  |                           error_handler=settings.error_encoding_error_handler) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         document = nodes.document(settings, reporter, source=source_path) | 
					
						
							|  |  |  |         document.note_source(source_path, -1) | 
					
						
							|  |  |  |         try: | 
					
						
							|  |  |  |             parser.parse(data, document) | 
					
						
							| 
									
										
										
										
											2015-01-14 23:56:35 -05:00
										 |  |  |         except AttributeError as e: | 
					
						
							|  |  |  |             reporter.messages.append( | 
					
						
							|  |  |  |                 (-1, 'Could not finish the parsing: %s.' % e, '', {})) | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return reporter.messages |