Files
@ b4d9680cd164
Branch filter:
Location: kallithea/pylons_app/lib/timerproxy.py - annotation
b4d9680cd164
1.9 KiB
text/x-python
some code fixes templates+helpers new rfc date without tz, added timerproxy formatting
3ada2f409c1c 3ada2f409c1c a5a17000e45b a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c a5a3bcc5ee89 a5a3bcc5ee89 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c b4d9680cd164 83c7ee1b5f5c 5ba66bb4ca95 5ba66bb4ca95 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c 83c7ee1b5f5c a5a3bcc5ee89 a5a3bcc5ee89 3ada2f409c1c 3ada2f409c1c a5a17000e45b a5a17000e45b a5a17000e45b a5a17000e45b a5a17000e45b a5a17000e45b 3ada2f409c1c a5a17000e45b 3ada2f409c1c 3ada2f409c1c a5a17000e45b 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 0c22a870bb79 a5a17000e45b 0c22a870bb79 a5a17000e45b a5a17000e45b | from sqlalchemy.interfaces import ConnectionProxy
import time
from sqlalchemy import log
BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE = xrange(30, 38)
def color_sql(sql):
COLOR_SEQ = "\033[1;%dm"
COLOR_SQL = YELLOW
normal = '\x1b[0m'
return COLOR_SEQ % COLOR_SQL + sql + normal
def one_space_trim(s):
if s.find(" ") == -1:
return s
else:
s = s.replace(' ', ' ')
return one_space_trim(s)
def format_sql(sql):
sql = color_sql(sql)
sql = sql.replace('\n', '')
sql = one_space_trim(sql)
sql = sql\
.replace(',', ',\n\t')\
.replace('SELECT', '\n\tSELECT \n\t')\
.replace('UPDATE', '\n\tUPDATE \n\t')\
.replace('DELETE', '\n\tDELETE \n\t')\
.replace('FROM', '\n\tFROM')\
.replace('ORDER BY', '\n\tORDER BY')\
.replace('LIMIT', '\n\tLIMIT')\
.replace('WHERE', '\n\tWHERE')\
.replace('AND', '\n\tAND')\
.replace('LEFT', '\n\tLEFT')\
.replace('INNER', '\n\tINNER')\
.replace('INSERT', '\n\tINSERT')\
.replace('DELETE', '\n\tDELETE')
return sql
class TimerProxy(ConnectionProxy):
def __init__(self):
super(TimerProxy, self).__init__()
self.logging_name = 'timerProxy'
self.log = log.instance_logger(self, True)
def cursor_execute(self, execute, cursor, statement, parameters, context, executemany):
now = time.time()
try:
self.log.info(">>>>> STARTING QUERY >>>>>")
return execute(cursor, statement, parameters, context)
finally:
total = time.time() - now
try:
self.log.info(format_sql("Query: %s" % statement % parameters))
except TypeError:
self.log.info(format_sql("Query: %s %s" % (statement, parameters)))
self.log.info("<<<<< TOTAL TIME: %f <<<<<" % total)
|