<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[121126] branches/gsoc14-pip2port/pypi2port</title>
</head>
<body>

<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="https://trac.macports.org/changeset/121126">121126</a></dd>
<dt>Author</dt> <dd>gaurav@macports.org</dd>
<dt>Date</dt> <dd>2014-06-18 01:05:51 -0700 (Wed, 18 Jun 2014)</dd>
</dl>

<h3>Log Message</h3>
<pre>Added executable</pre>

<h3>Added Paths</h3>
<ul>
<li><a href="#branchesgsoc14pip2portpypi2port">branches/gsoc14-pip2port/pypi2port</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="branchesgsoc14pip2portpypi2port"></a>
<div class="addfile"><h4>Added: branches/gsoc14-pip2port/pypi2port (0 => 121126)</h4>
<pre class="diff"><span>
<span class="info">--- branches/gsoc14-pip2port/pypi2port                                (rev 0)
+++ branches/gsoc14-pip2port/pypi2port        2014-06-18 08:05:51 UTC (rev 121126)
</span><span class="lines">@@ -0,0 +1,407 @@
</span><ins>+#! /bin/sh
+&quot;&quot;&quot;:&quot;
+exec python $0 ${1+&quot;$@&quot;}
+&quot;&quot;&quot;
+__doc__ = &quot;&quot;&quot;...Tester Script for pypi2port...&quot;&quot;&quot;
+
+# -*- coding: utf-8 -*-
+# !/usr/bin/env python
+
+import argparse
+import sys
+import os
+import urllib2
+import hashlib
+import zipfile
+from progressbar import *
+try:
+    import xmlrpclib
+except ImportError:
+    import xmlrpc.client as xmlrpclib
+import textwrap
+import string
+import shutil
+import re
+
+client = xmlrpclib.ServerProxy('http://pypi.python.org/pypi')
+
+
+def list_all():
+    list_packages = client.list_packages()
+    for package in list_packages:
+        print package
+
+
+def search(pkg_name):
+    print &quot;\n&quot;
+    values = client.search({'name': pkg_name})
+    for value in values:
+        for key in value.keys():
+            print key, '--&gt;', value[key]
+        print &quot;\n&quot;
+
+
+def release_data(pkg_name, pkg_version):
+    print &quot;\n&quot;
+    if pkg_version:
+        values = client.release_data(pkg_name, pkg_version)
+        if values:
+            for key in values.keys():
+                print key, '--&gt;', values[key]
+        else:
+            print &quot;No such package found.&quot;
+            print &quot;Please specify the exact package name.&quot;
+        print &quot;\n&quot;
+        return
+    print &quot;\n&quot;
+    return
+
+
+def fetch(pkg_name, dict):
+    checksum_md5 = dict['md5_digest']
+    parent_dir = './sources'
+    home_dir = parent_dir + '/' + 'python'
+    src_dir = home_dir + '/' + pkg_name
+    if not os.path.exists(parent_dir):
+        os.makedirs(parent_dir)
+    if not os.path.exists(home_dir):
+        os.makedirs(home_dir)
+    if not os.path.exists(src_dir):
+        os.makedirs(src_dir)
+
+    url = dict['url']
+    file_name = src_dir + '/' + dict['filename']
+
+    u = urllib2.urlopen(url)
+    with open(file_name, 'wb') as f:
+        meta = u.info()
+        file_size = int(meta.getheaders(&quot;Content-Length&quot;)[0])
+
+        widgets = ['Fetching: ', Percentage(), ' ',
+                   Bar(marker=RotatingMarker(), left='[', right=']'),
+                   ' ', ETA(), ' ', FileTransferSpeed()]
+        pbar = ProgressBar(widgets=widgets, maxval=int(file_size))
+        pbar.start()
+
+        file_size_dl = 0
+        block_sz = 1024
+        while True:
+            buffer = u.read(block_sz)
+            if not buffer:
+                break
+
+            file_size_dl += len(buffer)
+            f.write(buffer)
+            pbar.update(file_size_dl)
+
+        pbar.finish()
+        print
+
+    checksum_md5_calc = hashlib.md5(open(file_name).read()).hexdigest()
+    if str(checksum_md5) == str(checksum_md5_calc):
+        print 'Successfully fetched\n'
+        ext = file_name.split('.')[-1]
+        if ext == 'egg':
+            zip = zipfile.ZipFile(file_name)
+            for name in zip.namelist():
+                if name.split(&quot;/&quot;)[0] == &quot;EGG-INFO&quot;:
+                    zip.extract(name, src_dir)
+        print &quot;\n&quot;
+        return file_name
+    else:
+        print 'Aborting due to inconsistency on checksums\n'
+        try:
+            os.remove(file_name)
+        except OSError, e:
+            print &quot;Error: %s - %s.&quot; % (e.filename, e.strerror)
+        print &quot;\n&quot;
+        return False
+
+
+def fetch_url(pkg_name, pkg_version, checksum=False, deps=False):
+    values = client.release_urls(pkg_name, pkg_version)
+    if checksum:
+        for value in values:
+            if value['filename'].split('.')[-1] == 'gz':
+                return fetch(pkg_name, value)
+    else:
+        print &quot;\n&quot;
+        for value in values:
+            return fetch(pkg_name, value)
+
+
+def dependencies(pkg_name, pkg_version, deps=False):
+    if not deps:
+        return
+    values = client.release_urls(pkg_name, pkg_version)
+    for value in values:
+        if not value['filename'].split('.')[-1] == 'gz':
+            fetch(pkg_name, value)
+    try:
+        with open('./sources/python/' + pkg_name + '/EGG-INFO/requires.txt') as f:
+            list = f.readlines()
+            list = [x.strip('\n') for x in list]
+        f.close()
+        try:
+#            shutil.rmtree('./sources/python/' + pkg_name + '/EGG-INFO',
+#                          ignore_errors=True)
+#            items = os.listdir('./sources/python/' + pkg_name)
+#            for item in items[:]:
+#                if not item.split('.')[-1] == 'gz':
+#                    os.remove('./sources/python/' + pkg_name + '/' + item)
+#                    items.remove(item)
+             print &quot;&quot;
+
+#            if not items:
+#                os.rmdir('./sources/python/' + pkg_name)
+        except:
+             print &quot;&quot;
+        return list
+    except:
+        try:
+#            shutil.rmtree('./sources/python/'+pkg_name+'/EGG-INFO',
+#                          ignore_errors=True)
+#            items = os.listdir('./sources/python/'+pkg_name)
+#            for item in items[:]:
+#                if not item.split('.')[-1] == 'gz':
+#                    os.remove('./sources/python/'+pkg_name+'/'+item)
+#                    items.remove(item)
+#            if not items:
+#                os.rmdir('./sources/python/'+pkg_name)
+             print &quot;&quot;
+        except:
+             print &quot;&quot;
+        return False
+
+
+def checksums(pkg_name, pkg_version):
+    file_name = fetch_url(pkg_name, pkg_version, True)
+    print file_name
+    if file_name:
+        checksums = []
+        try:
+            h = hashlib.new('ripemd160')
+            with open(file_name) as f:
+                h.update(f.read())
+                checksums.insert(0, h.hexdigest())
+                checksums.insert(1, hashlib.sha256(f.read()).hexdigest())
+            dir = '/'.join(file_name.split('/')[0:-1])
+#            os.remove(file_name)
+            try:
+#                os.rmdir(dir)
+                print
+            except OSError as ex:
+                print
+            return checksums
+        except:
+            print &quot;Error\n&quot;
+            return
+
+
+def create_portfile(dict, file_name, dict2):
+    with open(file_name, 'w') as file:
+        file.write('# -*- coding: utf-8; mode: tcl; tab-width: 4; ')
+        file.write('indent-tabs-mode: nil; c-basic-offset: 4 ')
+        file.write('-*- vim:fenc=utf-8:ft=tcl:et:sw=4:ts=4:sts=4\n')
+        file.write('# $Id$\n\n')
+        file.write('PortSystem          1.0\n')
+        file.write('PortGroup           python 1.0\n\n')
+
+        file.write('name                {0}\n'.format(dict['name']))
+        file.write('version             {0}\n'.format(dict['version']))
+
+        file.write('platforms           darwin\n')
+        license = dict['license']
+        if license and not license == &quot;UNKNOWN&quot;:
+            license = license.encode('utf-8')
+            license = license.split('\n')[0]
+            license = re.sub(r'[\[\]\{\}\;\:\$\t\&quot;\'\`\=(--)]+',' ',license)
+            license = re.sub(r'\s(\s)+',' ',license)
+            file.write('license             {0}\n'.format(license))
+        else:
+            file.write('license             {0}\n'.format(os.getenv('license','None')))
+
+        if dict['maintainer']:
+            maintainers = ' '.join(dict['maintainer'])
+            if not maintainers == &quot;UNKNOWN&quot;: 
+                file.write('maintainers         {0}\n\n'.format(maintainers))
+            else:
+                file.write('maintainers         {0}\n\n'.format(os.getenv('maintainer','nomaintainer')))
+        else:
+            file.write('maintainers         {0}\n\n'.format(os.getenv('maintainer','nomaintainer')))
+
+        summary = dict['summary']
+        if summary:
+            summary = re.sub(r'[\[\]\{\}\;\:\$\t\&quot;\'\`\=(--)]+',
+                             ' ', summary)
+            summary = re.sub(r'\s(\s)+',' ',summary)
+            sum_lines = textwrap.wrap(summary)
+            file.write('description         ')
+            for sum_line in sum_lines:
+                if sum_line:
+                    if not sum_lines.index(sum_line) == 0:
+                        file.write('                    ')
+                    if sum_line == sum_lines[-1]:
+                        file.write(&quot;{0}\n&quot;.format(sum_line))
+                    else:
+                        file.write(&quot;{0} \\\n&quot;.format(sum_line))
+        else:
+            file.write('description         None\n\n')
+        description = dict['description']
+        if description:
+            description = description.encode('utf-8')
+            description = re.sub(r'[\[\]\{\}\;\:\$\t\&quot;\'\`\=(--)]+', ' ', description)
+            description = re.sub(r'\s(\s)+', ' ', description)
+            lines = textwrap.wrap(description, width=70)
+            file.write('long_description    ')
+            for line in lines:
+                if line and lines.index(line)&lt;4:
+                    if not lines.index(line) == 0:
+                        file.write('                    ')
+                    if lines.index(line)&gt;=3:
+                        file.write(&quot;{0}...\n&quot;.format(line))
+                    elif line == lines[-1]:
+                        file.write(&quot;{0}\n&quot;.format(line))
+                    else:
+                        file.write(&quot;{0} \\\n&quot;.format(line))
+        else:
+            file.write('long_description    ${description}\n\n')
+        home_page = dict['home_page']
+        
+        if home_page and not home_page == 'UNKNOWN':
+            file.write('homepage            {0}\n'.format(home_page))
+        else:
+            file.write('homepage            {0}\n'.format(os.getenv('home_page','')))
+            
+
+        if dict2:
+            master_site = '/'.join(dict2[0]['url'].split('/')[0:-1])
+        else:
+            master_site = os.getenv('master_site','')
+        if master_site:
+            file.write('master_sites        {0}\n'.format(master_site))
+#        file.write('distname            py-{0}{1}\n\n'.format(
+#                   dict['name'], dict['version']))
+        checksums_values = checksums(dict['name'], dict['version'])
+        if checksums_values:
+            file.write('checksums           rmd160  {0} \\\n'.format(
+                       checksums_values[0]))
+            file.write('                    sha256  {0}\n\n'.format(
+                       checksums_values[1]))
+
+        python_vers = dict['requires_python']
+        if python_vers:
+            file.write('python.versions     25 26 27 {0}\n\n'.format(
+                       dict['requires_python']))
+        else:
+            file.write('python.versions     25 26 27\n\n')
+
+        file.write('if {${name} ne ${subport}} {\n')
+        file.write('    depends_build       port:')
+        file.write('py${python.version}-setuptools\n')
+        deps = dependencies(dict['name'], dict['version'], True)
+        if deps:
+            for dep in deps:
+                file.write('                        port:py-{0}\n'.format(dep))
+        file.write('\n')
+        file.write('    livecheck.type      none\n')
+        file.write('} else {\n')
+        file.write('    livecheck.type      regex\n')
+        file.write('    livecheck.url       ${master_sites}\n')
+        file.write('}\n')
+
+
+def print_portfile(pkg_name, pkg_version=None):
+    print &quot;\n&quot;
+    root_dir = os.path.abspath(&quot;./dports&quot;)
+    port_dir = os.path.join(root_dir, 'python')
+    home_dir = os.path.join(port_dir, pkg_name)
+    if not os.path.exists(root_dir):
+        os.makedirs(root_dir)
+    if not os.path.exists(port_dir):
+        os.makedirs(port_dir)
+    if not os.path.exists(home_dir):
+        os.makedirs(home_dir)
+
+    dict = client.release_data(pkg_name, pkg_version)
+    dict2 = client.release_urls(pkg_name, pkg_version)
+
+    file_name = os.path.join(home_dir, &quot;Portfile&quot;)
+    create_portfile(dict, file_name, dict2)
+    print &quot;SUCCESS\n&quot;
+
+
+def main(argv):
+    parser = argparse.ArgumentParser(description=&quot;Pypi2Port Tester&quot;)
+    parser.add_argument('-l', '--list', action='store_true', dest='list',
+                        default=False, required=False,
+                        help='List all packages')
+    parser.add_argument('-s', '--search', action='store', type=str,
+                        dest='packages_search', nargs='*', required=False,
+                        help='Search for a package')
+    parser.add_argument('-d', '--data', action='store',
+                        dest='packages_data', nargs='*', type=str,
+                        help='Releases data for a package')
+    parser.add_argument('-f', '--fetch', action='store', type=str,
+                        dest='package_fetch', nargs='*', required=False,
+                        help='Fetches distfiles for a package')
+    parser.add_argument('-p', '--portfile', action='store', type=str,
+                        dest='package_portfile', nargs='*', required=False,
+                        help='Prints the portfile for a package')
+    options = parser.parse_args()
+
+    if options.list:
+        list_all()
+        return
+
+    if options.packages_search:
+        for pkg_name in options.packages_search:
+            search(pkg_name)
+        return
+
+    if options.packages_data:
+        pkg_name = options.packages_data[0]
+        if len(options.packages_data) &gt; 1:
+            pkg_version = options.packages_data[1]
+            release_data(pkg_name, pkg_version)
+        else:
+            if client.package_releases(pkg_name):
+                pkg_version = client.package_releases(pkg_name)[0]
+                release_data(pkg_name, pkg_version)
+            else:
+                print &quot;No release found\n&quot;
+        return
+
+    if options.package_fetch:
+        pkg_name = options.package_fetch[0]
+        if len(options.package_fetch) &gt; 1:
+            pkg_version = options.package_fetch[1]
+            fetch_url(pkg_name, pkg_version)
+        else:
+            releases = client.package_releases(pkg_name)
+            if releases:
+                pkg_version = releases[0]
+                fetch_url(pkg_name, pkg_version)
+            else:
+                print &quot;No release found\n&quot;
+        return
+
+    if options.package_portfile:
+        pkg_name = options.package_portfile[0]
+        if len(options.package_portfile) &gt; 1:
+            pkg_version = options.package_portfile[1]
+            print_portfile(pkg_name, pkg_version)
+        else:
+            vers = client.package_releases(pkg_name)
+            if vers:
+                pkg_version = vers[0]
+                print_portfile(pkg_name, pkg_version)
+            else:
+                print &quot;No release found\n&quot;
+        return
+
+    parser.print_help()
+    parser.error(&quot;No input specified&quot;)
+
+if __name__ == &quot;__main__&quot;:
+    main(sys.argv[1:])
</ins><span class="cx">Property changes on: branches/gsoc14-pip2port/pypi2port
</span><span class="cx">___________________________________________________________________
</span></span></pre></div>
<a id="svnexecutable"></a>
<div class="addfile"><h4>Added: svn:executable</h4></div>
</div>

</body>
</html>