#!/usr/bin/env python
# coding=utf-8
"""
calc.py - Phenny Calculator Module
Copyright 2008, Sean B. Palmer, inamidst.com
Licensed under the Eiffel Forum License 2.
http://inamidst.com/phenny/
"""
import re
import web
r_result = re.compile(r'(?i)(.*?)')
r_tag = re.compile(r'<\S+.*?>')
subs = [
(' in ', ' -> '),
(' over ', ' / '),
(u'£', 'GBP '),
(u'€', 'EUR '),
('\$', 'USD '),
(r'\bKB\b', 'kilobytes'),
(r'\bMB\b', 'megabytes'),
(r'\bGB\b', 'kilobytes'),
('kbps', '(kilobits / second)'),
('mbps', '(megabits / second)')
]
def calc(phenny, input):
"""Use the Frink online calculator."""
#q = input.group(2)
q = input.encode('utf-8')
if not q:
#return phenny.say('0?')
return '0?'
query = q[:]
for a, b in subs:
query = re.sub(a, b, query)
query = query.rstrip(' \t')
precision = 5
if query[-3:] in ('GBP', 'USD', 'EUR', 'NOK'):
precision = 2
query = web.urllib.quote(query.encode('utf-8'))
uri = 'http://futureboy.us/fsp/frink.fsp?fromVal='
bytes = web.get(uri + query)
m = r_result.search(bytes)
if m:
result = m.group(1)
result = r_tag.sub('', result) # strip span.warning tags
result = result.replace('>', '>')
result = result.replace('(undefined symbol)', '(?) ')
if '.' in result:
try: result = str(round(float(result), precision))
except ValueError: pass
if not result.strip():
result = '?'
elif ' in ' in q:
result += ' ' + q.split(' in ', 1)[1]
#phenny.say(q + ' = ' + result[:350])
return q + ' = ' + result[:350]
#else: phenny.reply("Sorry, can't calculate that.")
else: return "Sorry, can't calculate that."
#phenny.say('Note that .calc is deprecated, consider using .c')
return 'Note that .calc is deprecated, consider using .c'
calc.commands = ['calc']
calc.example = '.calc 5 + 3'
def c(phenny, input):
"""Google calculator."""
#q = input.group(2).encode('utf-8')
q = input.encode('utf-8')
q = q.replace('\xcf\x95', 'phi') # utf-8 U+03D5
q = q.replace('\xcf\x80', 'pi') # utf-8 U+03C0
#q = q.replace('\xd7', 'x') #
uri = 'http://www.google.com/ig/calculator?q='
bytes = web.get(uri + web.urllib.quote(q))
parts = bytes.split('",')
answer = [p for p in parts if p.startswith('rhs: "')][0][6:]
if answer:
answer = answer.decode('unicode-escape')
answer = ''.join(chr(ord(c)) for c in answer)
answer = answer.decode('utf-8')
answer = answer.replace(u'\xc2\xa0', ',')
answer = answer.replace(u'\xa0', ',')
answer = answer.replace(u'\xd7', 'x') # Not working!
answer = answer.replace('×', 'x') # seems to work
answer = answer.replace('', '^(')
answer = answer.replace('', ')')
answer = web.decode(answer)
#phenny.say(answer)
return answer
#else: phenny.say('Sorry, no result.')
else: return('Sorry, no result.')
c.commands = ['c']
c.example = '.c 5 + 3'
def py(phenny, input):
query = input.group(2)
uri = 'http://tumbolia.appspot.com/py/'
answer = web.get(uri + web.urllib.quote(query))
if answer:
phenny.say(answer)
else: phenny.reply('Sorry, no result.')
py.commands = ['py']
def wa(phenny, input):
query = input.group(2).encode('utf-8')
uri = 'http://tumbolia.appspot.com/wa/'
answer = web.get(uri + web.urllib.quote(query))
if answer:
phenny.say(answer)
else: phenny.reply('Sorry, no result.')
wa.commands = ['wa']
import sys
if __name__ == '__main__':
print __doc__.strip()
for arg in sys.argv:
print arg
#print calc(None, arg)
print c(None, arg)