15__title__ =
"comedycentral_api - XPath and XSLT functions for the Comedy Central RSS/HTML"
16__author__=
"R.D. Vaughan"
18This python script is intended to perform a variety of utility functions
19for the conversion of data to the MNV standard RSS output format.
20See this link for the specifications:
21http://www.mythtv.org/wiki/MythNetvision_Grabber_Script_Format
29__xpathClassList__ = [
'xpathFunctions', ]
33__xsltExtentionList__ = []
35import os, sys, re, time, datetime, shutil,
urllib.request, urllib.parse, urllib.error, string
36from 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)
61if isinstance(sys.stdout, io.TextIOWrapper):
66 from io
import StringIO
67 from lxml
import etree
69 sys.stderr.write(
'\n! Error - Importing the "lxml" and "StringIO" python libraries failed on error(%s)\n' % e)
74 """Functions specific extending XPath
88 '''Parse the item element and extract a Web link
89 Call example: 'mnvXpath:comedycentralMakeLink(.)'
90 return a URL link to the item web page
92 tmpTitle = arg[0][0].find('title').text.strip()
93 tmpVideoCode = arg[0][0].
find(
'guid').text.strip()
94 index = tmpVideoCode.rfind(
'.')
96 tmpVideoCode = tmpVideoCode[index+1:]
97 tmpLink = common.linkWebPage(
'dummy',
'comedycentral').replace(
'TITLE', urllib.parse.quote(tmpTitle)).replace(
'VIDEOCODE', tmpVideoCode)
98 return tmpLink.strip()
def __getattr__(self, attr)
def __init__(self, outstream, encoding=None)
def comedycentralMakeLink(self, context, *arg)
Start of XPath extension functions.
static pid_list_t::iterator find(const PIDInfoMap &map, pid_list_t &list, pid_list_t::iterator begin, pid_list_t::iterator end, bool find_open)