return el.getAttribute((u'http://www.w3.org/XML/1998/namespace', u'lang'))
+import sha
+def socks5Hash(sid, initiator, target):
+ return sha.new("%s%s%s" % (sid, initiator, target)).hexdigest()
+
+
+import urllib
+import os.path
+def getURLBits(url, assumedType=None):
+ type, rest = urllib.splittype(url)
+ if assumedType and type != assumedType:
+ return
+ hostport, path = urllib.splithost(rest)
+ host, port = urllib.splitnport(hostport, 80)
+ filename = os.path.basename(path)
+ return host, port, path, filename
+
+
try:
import Image
import StringIO
}
-def parseText(text, beExtremelyLenient=False):
- t = TextParser(beExtremelyLenient)
- t.parseString(text)
- return t.root
-
-def parseFile(filename, beExtremelyLenient=False):
- t = TextParser(beExtremelyLenient)
- t.parseFile(filename)
- return t.root
-
checkTwistedCached = None
def checkTwisted():
i += 1
-if checkTwisted():
- from twisted.xish.domish import SuxElementStream
-else:
- from tlib.domish import SuxElementStream
-class TextParser:
- """ Taken from http://xoomer.virgilio.it/dialtone/rsschannel.py """
-
- def __init__(self, beExtremelyLenient=False):
- self.root = None
- self.beExtremelyLenient = beExtremelyLenient
-
- def parseFile(self, filename):
- return self.parseString(file(filename).read())
-
- def parseString(self, data):
- es = SuxElementStream()
- es.beExtremelyLenient = self.beExtremelyLenient
- es.DocumentStartEvent = self.docStart
- es.DocumentEndEvent = self.docEnd
- es.ElementEvent = self.element
- es.parse(data)
- return self.root
-
- def docStart(self, e):
- self.root = e
-
- def docEnd(self):
- pass
-
- def element(self, e):
- self.root.addChild(e)
-