Commit 3eb783e7 authored by Tarek Ziadé's avatar Tarek Ziadé

Issue #7457: added a read_pkg_file method to...

Issue #7457: added a read_pkg_file method to distutils.dist.DistributionMetadata so we can read back PKG-INFO files
parent c9eb6ca2
...@@ -7,6 +7,7 @@ being built/installed/distributed. ...@@ -7,6 +7,7 @@ being built/installed/distributed.
__revision__ = "$Id$" __revision__ = "$Id$"
import sys, os, re import sys, os, re
import rfc822
try: try:
import warnings import warnings
...@@ -1006,6 +1007,20 @@ Common commands: (see '--help-commands' for more) ...@@ -1006,6 +1007,20 @@ Common commands: (see '--help-commands' for more)
# to self.metadata.get_XXX. The actual code is in the # to self.metadata.get_XXX. The actual code is in the
# DistributionMetadata class, below. # DistributionMetadata class, below.
class _MetadataMessage(rfc822.Message):
def read_field(self, name):
value = self[name]
if value == 'UNKNOWN':
return None
return value
def getheaders(self, name, default):
values = rfc822.Message.getheaders(self, name)
if values == []:
return None
return values
class DistributionMetadata: class DistributionMetadata:
"""Dummy class to hold the distribution meta-data: name, version, """Dummy class to hold the distribution meta-data: name, version,
author, and so forth. author, and so forth.
...@@ -1021,7 +1036,10 @@ class DistributionMetadata: ...@@ -1021,7 +1036,10 @@ class DistributionMetadata:
"provides", "requires", "obsoletes", "provides", "requires", "obsoletes",
) )
def __init__ (self): def __init__(self, path=None):
if path is not None:
self.read_pkg_file(open(path))
else:
self.name = None self.name = None
self.version = None self.version = None
self.author = None self.author = None
...@@ -1041,6 +1059,45 @@ class DistributionMetadata: ...@@ -1041,6 +1059,45 @@ class DistributionMetadata:
self.requires = None self.requires = None
self.obsoletes = None self.obsoletes = None
def read_pkg_file(self, file):
"""Reads the metadata values from a file object."""
msg = _MetadataMessage(file)
metadata_version = msg['metadata-version']
self.name = msg.read_field('name')
self.version = msg.read_field('version')
self.description = msg.read_field('summary')
# we are filling author only.
self.author = msg.read_field('author')
self.maintainer = None
self.author_email = msg.read_field('author-email')
self.maintainer_email = None
self.url = msg.read_field('home-page')
self.license = msg.read_field('license')
if 'download-url' in msg:
self.download_url = msg.read_field('download-url')
else:
self.download_url = None
self.long_description = msg.read_field('description')
self.description = msg.read_field('summary')
if 'keywords' in msg:
self.keywords = msg.read_field('keywords').split(',')
self.platforms = msg.getheaders('platform', None)
self.classifiers = msg.getheaders('classifier', None)
# PEP 314 - these fields only exist in 1.1
if metadata_version == '1.1':
self.requires = msg.getheaders('requires', None)
self.provides = msg.getheaders('provides', None)
self.obsoletes = msg.getheaders('obsoletes', None)
else:
self.requires = None
self.provides = None
self.obsoletes = None
def write_pkg_info(self, base_dir): def write_pkg_info(self, base_dir):
"""Write the PKG-INFO file into the release tree. """Write the PKG-INFO file into the release tree.
""" """
......
...@@ -8,10 +8,9 @@ import unittest ...@@ -8,10 +8,9 @@ import unittest
import warnings import warnings
import textwrap import textwrap
from distutils.dist import Distribution, fix_help_options from distutils.dist import Distribution, fix_help_options, DistributionMetadata
from distutils.cmd import Command from distutils.cmd import Command
import distutils.dist import distutils.dist
from test.test_support import TESTFN, captured_stdout from test.test_support import TESTFN, captured_stdout
from distutils.tests import support from distutils.tests import support
...@@ -239,6 +238,7 @@ class DistributionTestCase(support.TempdirManager, ...@@ -239,6 +238,7 @@ class DistributionTestCase(support.TempdirManager,
# make sure --no-user-cfg disables the user cfg file # make sure --no-user-cfg disables the user cfg file
self.assertEquals(len(all_files)-1, len(files)) self.assertEquals(len(all_files)-1, len(files))
class MetadataTestCase(support.TempdirManager, support.EnvironGuard, class MetadataTestCase(support.TempdirManager, support.EnvironGuard,
unittest.TestCase): unittest.TestCase):
...@@ -397,6 +397,33 @@ class MetadataTestCase(support.TempdirManager, support.EnvironGuard, ...@@ -397,6 +397,33 @@ class MetadataTestCase(support.TempdirManager, support.EnvironGuard,
meta = meta.replace('\n' + 8 * ' ', '\n') meta = meta.replace('\n' + 8 * ' ', '\n')
self.assertTrue(long_desc in meta) self.assertTrue(long_desc in meta)
def test_read_metadata(self):
attrs = {"name": "package",
"version": "1.0",
"long_description": "desc",
"description": "xxx",
"download_url": "http://example.com",
"keywords": ['one', 'two'],
"requires": ['foo']}
dist = Distribution(attrs)
metadata = dist.metadata
# write it then reloads it
PKG_INFO = StringIO.StringIO()
metadata.write_pkg_file(PKG_INFO)
PKG_INFO.seek(0)
metadata.read_pkg_file(PKG_INFO)
self.assertEquals(metadata.name, "package")
self.assertEquals(metadata.version, "1.0")
self.assertEquals(metadata.description, "xxx")
self.assertEquals(metadata.download_url, 'http://example.com')
self.assertEquals(metadata.keywords, ['one', 'two'])
self.assertEquals(metadata.platforms, ['UNKNOWN'])
self.assertEquals(metadata.obsoletes, None)
self.assertEquals(metadata.requires, ['foo'])
def test_suite(): def test_suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(DistributionTestCase)) suite.addTest(unittest.makeSuite(DistributionTestCase))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment