Skip to content

Instantly share code, notes, and snippets.

@jantman
Forked from gmr/inventory.py
Created August 28, 2016 02:21
Show Gist options
  • Save jantman/3569df838a9241608018bb749f04cce7 to your computer and use it in GitHub Desktop.
Save jantman/3569df838a9241608018bb749f04cce7 to your computer and use it in GitHub Desktop.
#!/usr/bin/env python
"""
Process URL for intersphinx targets and emit html or text
originally retrieved from:
https://gist.github.com/gmr/11359058
fixed for python3 and pep8 compliance by jantman
"""
from sphinx.ext.intersphinx import read_inventory_v2
from posixpath import join
import pprint
import argparse
import locale
import os
import sys
import tempfile
import urllib2
def validuri(string):
return string
parser = argparse.ArgumentParser(description='Process intersphinx link library')
parser.add_argument('--url', type=validuri,
help="URL to retrieve objects.inv from")
parser.add_argument('--file', help="objects.inv format file")
group = parser.add_mutually_exclusive_group(required=False)
group.add_argument('--html', action='store_true', help="Output HTML")
group.add_argument('--terse', action='store_true',
help="Output terse text list")
group.add_argument('--rst', action='store_true',
help="Output ReStructuredText")
group.add_argument('--rewrite', action='store_true',
help="Output short form and correct form of each link.")
args = parser.parse_args()
def start_role(role):
if args.terse:
return
elif args.rewrite:
return
elif args.rst:
print(role)
else:
print("<dt>Role: {}</dt>\n<dd>\n<dl>\n".format(role))
def start_item(role, item):
if args.terse:
return
elif args.rewrite:
return
elif args.rst:
print("\t:{}:{}:".format(role, item))
elif args.html:
print("<dt>{}:{}</dt>\n".format(role, item))
print("<dd>")
print("<table>\n<tbody>")
def end_item(role, item):
if args.html:
print("</tbody></table>")
print("</dd>\n")
def print_link(role, item, domain, title):
"""Return the correct link form, if no title then extended form."""
domain = domain.lower()
if title == '' or title == '-':
linkStr = ":{}:`{} <{}:{}>`".format(role, item, domain, item)
else:
linkStr = ":{}:`{}:{}`".format(role, domain, item)
if args.terse:
print(linkStr)
if args.rewrite:
print(":{}:`{}:{}`".format(role, domain, item), "\t{}".format(linkStr))
elif args.rst:
print("\t\t:Link:\t{}".format(linkStr))
elif args.html:
print("<tr><th>Link:</th><td>{}</td></tr>".format(linkStr))
def end_role():
if args.html:
print("</dl>\n")
print("</dd>\n")
def print_meta(role, item, domain, version, url, title):
if args.terse:
return
elif args.rewrite:
return
elif args.rst:
print("\t\t:Domain:\t{}".format(domain))
print("\t\t:Version:\t{}".format(version))
print("\t\t:URL:\t{}".format(url))
print("\t\t:Title:\t{}".format(title))
elif args.html:
print("<tr><th>Domain:</th><td>{}</td></tr>".format(domain))
print("<tr><th>Version:</th><td>{}</td></tr>".format(version))
print("<tr><th>URL:</th><td>{}</td></tr>".format(url))
print("<tr><th>Title:</th><td>{}</td></tr>".format(title))
return
def fetch_data(url, inv):
f = open(inv, 'rb')
line = f.readline() # burn a line
invdata = read_inventory_v2(f, url or '', join)
if args.html:
print("<dl>")
for role in invdata:
start_role(role)
for item in invdata[role]:
(domain, version, url, title) = invdata[role][item]
start_item(role, item)
print_link(role, item, domain, title)
print_meta(role, item, domain, version, url, title)
end_item(role, item)
if args.html:
print("</dl>\n")
if __name__ == "__main__":
if args.file:
inv = args.file
else:
inv = False
if args.url:
url = args.url
else:
url = False
if inv is False and url is False:
raise Exception("need to specify a file or URL")
if inv and url != '':
fetch_data(url, inv)
elif url:
# fetch URL into inv
if url.rfind('objects.inv') > 5:
invdata = urllib2.urlopen(url)
else:
invdata = urllib2.urlopen(url + '/objects.inv')
sys.stderr.write('URL resolved to: {}\n '.format(invdata.geturl()))
f = tempfile.NamedTemporaryFile()
f.write(invdata.read())
sys.stderr.write("objects.inv written to: {}\n".format(f.name))
sys.stderr.write("Using: {} as base HREF\n".format(url))
fetch_data(url, f.name)
else:
raise Exception("You need to specify a --URL")
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment