📄 debug.py
字号:
# -*- coding: ISO8859-1 -*-## Copyright 2006 Norwegian University of Science and Technology## This file is part of Network Administration Visualized (NAV)## NAV is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or# (at your option) any later version.## NAV is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the# GNU General Public License for more details.## You should have received a copy of the GNU General Public License# along with NAV; if not, write to the Free Software# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA### $Id$# Authors: Morten Vold <morten.vold@ntnu.no>#"""This module provides some useful debugging tools for NAV developers"""from traceback import print_stackfrom cStringIO import StringIOtry: from mod_python import apacheexcept: apache = None apache_log = Noneelse: apache_loglevel = apache.APLOG_WARNING def apache_log(s): """Log s to apaches error log""" apache.log_error(s, apache_loglevel)def calltracer(function, logfunction=apache_log): """Decorator to trace function calls. Decorate any function/method with calltracer to log tracebacks of each call to the function. The logfunction parameter specifices which log function to use. The default logfunction logs to Apache's errorlog (if mod_python.apache is available), which makes this suitable for debugging the web modules of NAV. """ def tracer(*args, **kwargs): logfunction('TRACE: Call to %s, args=%s, kwargs=%s' % (repr(function), repr(args), repr(kwargs))) trace = StringIO() print_stack(file=trace) trace.seek(0) for line in trace.readlines(): logfunction('STACK: ' + line.rstrip()) return function(*args,**kwargs) if not logfunction: return function else: return tracer
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -