13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
# NOTE: If update these, please also update the help for global-options in
19
# bzrlib/help_topics/__init__.py
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22
17
"""Set of flags that enable different debug behaviour.
24
These are set with eg ``-Dlock`` on the bzr command line.
28
* auth - show authentication sections used
29
* error - show stack traces for all top level exceptions
30
* evil - capture call sites that do expensive or badly-scaling operations.
31
* fetch - trace history copying between repositories
32
* graph - trace graph traversal information
33
* hashcache - log every time a working file is read to determine its hash
34
* hooks - trace hook execution
35
* hpss - trace smart protocol requests and responses
36
* http - trace http connections, requests and responses
37
* index - trace major index operations
38
* knit - trace knit operations
39
* lock - trace when lockdir locks are taken or released
40
* merge - emit information for debugging merges
41
* pack - emit information about pack operations
19
These are set with eg ``-Dlock`` on the bzr command line or in
20
~/.bazaar/bazaar.conf debug_flags.
22
See `bzr help debug-flags` or `bzrlib/help_topics/en/debug-flags.txt`
23
for a list of the available options.
26
from __future__ import absolute_import
31
def set_debug_flags_from_config():
32
"""Turn on debug flags based on the global configuration"""
34
from bzrlib import config
36
c = config.GlobalStack()
37
for f in c.get('debug_flags'):
42
"""Pdb using original stdin and stdout.
44
When debugging blackbox tests, sys.stdin and sys.stdout are captured for
45
test purposes and cannot be used for interactive debugging. This class uses
46
the origianl stdin/stdout to allow such use.
50
import pdb; pdb.set_trace()
54
from bzrlib import debug; debug.set_trace()
58
pdb.Pdb(stdin=sys.__stdin__, stdout=sys.__stdout__
59
).set_trace(sys._getframe().f_back)