15 __title__ =
"hubbleCast_api - XPath and XSLT functions for the HubbleCast RSS/HTML"
16 __author__=
"R.D. Vaughan"
18 This python script is intended to perform a variety of utility functions
19 for the conversion of data to the MNV standard RSS output format.
20 See this link for the specifications:
21 http://www.mythtv.org/wiki/MythNetvision_Grabber_Script_Format
29 __xpathClassList__ = [
'xpathFunctions', ]
33 __xsltExtentionList__ = []
35 import os, sys, re, time, datetime, shutil, urllib.request, urllib.parse, urllib.error, string
36 from copy
import deepcopy
40 """Wraps a stream with an encoder"""
49 """Wraps the output stream, encoding Unicode strings with the specified encoding"""
50 if isinstance(obj, str):
53 self.
out.buffer.write(obj)
58 """Delegate everything but write to the stream"""
59 return getattr(self.
out, attr)
61 if isinstance(sys.stdout, io.TextIOWrapper):
66 from io
import StringIO
67 from lxml
import etree
68 except Exception
as e:
69 sys.stderr.write(
'\n! Error - Importing the "lxml" and "StringIO" python libraries failed on error(%s)\n' % e)
77 for digit
in etree.LIBXML_VERSION:
78 version+=str(digit)+
'.'
79 version = version[:-1]
82 ! Error - The installed version of the "lxml" python library "libxml" version is too old.
83 At least "libxml" version 2.7.2 must be installed. Your version is (%s).
89 """Functions specific extending XPath
94 'atom':
"http://www.w3.org/2005/Atom",
95 'atom10':
"http://www.w3.org/2005/Atom",
96 'media':
"http://search.yahoo.com/mrss/",
97 'itunes':
"http://www.itunes.com/dtds/podcast-1.0.dtd",
98 'xhtml':
"http://www.w3.org/1999/xhtml",
99 'mythtv':
"http://www.mythtv.org/wiki/MythNetvision_Grabber_Script_Format",
100 'feedburner':
"http://rssnamespace.org/feedburner/ext/1.0",
101 'amp':
"http://www.adobe.com/amp/1.0",
112 '''Generate a link for the video.
113 Call example: 'mnvXpath:hubbleCastLinkGeneration(string(guid))'
117 index = guidURL.find(
'.m4v')
119 index2 = guidURL.rfind(
'/')
120 return '%s%s' % (common.linkWebPage(
'dummy',
'hubble'), guidURL[index2+1:index])
121 elif guidURL[len(guidURL)-1] ==
'/':
122 index2 = guidURL[:-1].rfind(
'/')
123 return '%s%s' % (common.linkWebPage(
'dummy',
'hubble'), guidURL[index2+1:-1])