Files
@ 52bbeb1e813f
Branch filter:
Location: kallithea/pylons_app/lib/timerproxy.py - annotation
52bbeb1e813f
1.4 KiB
text/x-python
Added universal cache invalidator for two cached functions.
added invalidation when repository was added or deleted, and another invalidation when there was a mercurial command involved.
added invalidation when repository was added or deleted, and another invalidation when there was a mercurial command involved.
3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 0c22a870bb79 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 3ada2f409c1c 0c22a870bb79 a5a3bcc5ee89 0c22a870bb79 a5a3bcc5ee89 3ada2f409c1c a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 a5a3bcc5ee89 | from sqlalchemy.interfaces import ConnectionProxy
import time
import logging
log = logging.getLogger('timerproxy')
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 format_sql(sql):
sql = color_sql(sql)
sql = sql.replace('SELECT', '\n SELECT \n\t')\
.replace('FROM', '\n FROM')\
.replace('ORDER BY', '\n ORDER BY')\
.replace('LIMIT', '\n LIMIT')\
.replace('WHERE', '\n WHERE')\
.replace('AND', '\n AND')\
.replace('LEFT', '\n LEFT')\
.replace('INNER', '\n INNER')\
.replace('INSERT', '\n INSERT')\
.replace('DELETE', '\n DELETE')
return sql
class TimerProxy(ConnectionProxy):
def cursor_execute(self, execute, cursor, statement, parameters, context, executemany):
now = time.time()
try:
log.info(">>>>> STARTING QUERY >>>>>")
return execute(cursor, statement, parameters, context)
finally:
total = time.time() - now
try:
log.info(format_sql("Query: %s" % statement % parameters))
except TypeError:
log.info(format_sql("Query: %s %s" % (statement, parameters)))
log.info("<<<<< TOTAL TIME: %f <<<<<" % total)
|