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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
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
17
22
"""Set of flags that enable different debug behaviour.
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.
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
* hashcache - log every time a working file is read to determine its hash
33
* hooks - trace hook execution
34
* hpss - trace smart protocol requests and responses
35
* http - trace http connections, requests and responses
36
* index - trace major index operations
37
* knit - trace knit operations
38
* lock - trace when lockdir locks are taken or released
39
* merge - emit information for debugging merges
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)