bdb — Framework do depurador¶
Código-fonte: Lib/bdb.py
O módulo bdb lida com funções básicas do depurador, como definir pontos de interrupção ou gerenciar a execução por meio do depurador.
A seguinte exceção é definida:
O módulo bdb também define duas classes:
- class bdb.Breakpoint(self, file, line, temporary=False, cond=None, funcname=None)¶
Esta classe implementa pontos de interrupção temporários, contagens de ignorar, desativação e (re)ativação, além de condicionais.
Os pontos de interrupção são indexados por número por meio de uma lista chamada
bpbynumbere por pares(file, line)por meio debplist. O primeiro aponta para uma única instância da classeBreakpoint. O segundo aponta para uma lista dessas instâncias, já que pode haver mais de um ponto de interrupção por linha.Ao criar um ponto de interrupção, seu
nome do arquivoassociado deve estar no formato canônico. Se umfuncnamefor definido, um ponto de interrupçãoatingidoserá contado quando a primeira linha dessa função for executada. Um ponto de interrupçãocondicionalsempre conta umatingido.As instâncias de
Breakpointtêm os seguintes métodos:- deleteMe()¶
Exclui o ponto de interrupção da lista associada a um arquivo/linha. Se for o último ponto de interrupção nessa posição, ele também excluirá a entrada do arquivo/linha.
- enable()¶
Marca o ponto de interrupção como ativado.
- disable()¶
Marca o ponto de interrupção como desativado.
- bpformat()¶
Retorna uma string com todas as informações sobre o ponto de interrupção, formatadas de maneira clara:
Número do ponto de interrupção.
Status temporário (del ou keep).
Posição do arquivo/linha.
Condição de interrupção.
Número de vezes para ignorar.
Número de vezes atingido.
Adicionado na versão 3.2.
- bpprint(out=None)¶
Exibe a saída de
bpformat()no arquivo out ou, se forNone, na saída padrão.
Instâncias
Breakpointpossuem os seguintes atributos:- file¶
Nome do arquivo do
Breakpoint.
- line¶
Número da linha do
Breakpointdentro defile.
- temporary¶
Truese umBreakpointem (file, line) for temporário.
- cond¶
Condição para avaliar um
Breakpointem (file, line).
- funcname¶
Nome da função que define se um
Breakpointé atingido ao entrar na função.
- enabled¶
TrueseBreakpointestiver ativado.
- bpbynumber¶
Índice numérico de uma única instância de
Breakpoint.
- bplist¶
Dicionário de instâncias de
Breakpointindexadas por tuplas (file,line).
- ignore¶
Número de vezes para ignorar o
Breakpoint.
- hits¶
Contagem do número de vezes que um
Breakpointfoi atingido.
- class bdb.Bdb(skip=None, backend='settrace')¶
A
Bdbatua como uma classe base genérica de depurador em Python.Esta classe cuida dos detalhes do mecanismo de rastreamento; uma classe derivada deve implementar a interação com o usuário. A classe de depuração padrão (
pdb.Pdb) é um exemplo.O argumento skip, se fornecido, deve ser um iterável de padrões de nomes de módulos no estilo glob. O depurador não entrará em frames que se originam em um módulo que corresponda a um desses padrões. Se um frame é considerado como originado em determinado módulo é determinado pelo valor de
__name__nos globals do frame.O argumento backend especifica o backend a ser usado pela
Bdb. Ele pode ser'settrace'ou'monitoring'.'settrace'usasys.settrace(), que oferece a melhor retrocompatibilidade. O backend'monitoring'usa o novosys.monitoring, introduzido no Python 3.12, que pode ser muito mais eficiente porque pode desabilitar eventos não utilizados. Estamos tentando manter interfaces idênticas para ambos os backends, mas existem algumas diferenças. Os desenvolvedores de depuradores são incentivados a usar o backend'monitoring'para obter melhor desempenho.Alterado na versão 3.1: Adicionado o parâmetro skip.
Alterado na versão 3.14: Adicionado o parâmetro backend.
Os seguintes métodos de
Bdbnormalmente não precisam ser substituídos.- canonic(filename)¶
Retorna a forma canônica de filename.
Para nomes de arquivos reais, a forma canônica é um
caminho absoluto,normalizado para distinguir maiúsculas e minúsculas, dependente do sistema operacional. Um filename com colchetes angulares, como"<stdin>"gerado no modo interativo, é retornado sem alterações.
- start_trace(self)¶
Inicia o rastreamento. Para o backend
'settrace', este método equivale asys.settrace(self.trace_dispatch)Adicionado na versão 3.14.
- stop_trace(self)¶
Para o rastreamento. Para o backend
'settrace', este método equivale asys.settrace(None)Adicionado na versão 3.14.
- reset()¶
Define os atributos
botframe,stopframe,returnframeequittingcom valores prontos para iniciar a depuração.
- trace_dispatch(frame, event, arg)¶
Esta função é instalada como a função de rastreamento dos frames depurados. Seu valor de retorno é a nova função de rastreamento (na maioria dos casos, ela própria).
A implementação padrão decide como despachar um frame, dependendo do tipo de evento (passado como string) que está prestes a ser executado. event pode ser um dos seguintes:
"line": Uma nova linha de código será executada."call": Um função está prestes a ser chamada, ou outro bloco de código foi inserido."retorno": Um função ou outro bloco de código está prestes a retornar."exception": Ocorreu uma exceção.
For all the events, specialized functions (see below) are called.
O parâmetro arg depende do evento anterior.
Consulte a documentação de
sys.settrace()para mais informações sobre a função de rastreamento. Para mais informações sobre objetos de código e de frame, consulte A hierarquia de tipos padrão.
- dispatch_line(frame)¶
Se o depurador deve parar na linha atual, invoca o método
user_line()(que deve ser substituído em subclasses). Levanta a exceçãoBdbQuitse o sinalizadorquittingestiver definido (ele pode ser definido a partir deuser_line()). Retorna uma referência ao métodotrace_dispatch()para continuar o rastreamento nesse escopo.
- dispatch_call(frame, arg)¶
Se o depurador deve parar nesta chamada de função, invoca o método
user_call()(que deve ser substituído em subclasses). Levanta a exceçãoBdbQuitse o sinalizadorquittingestiver definido (ele pode ser definido a partir deuser_call()). Retorna uma referência ao métodotrace_dispatch()para continuar o rastreamento nesse escopo.
- dispatch_return(frame, arg)¶
Se o depurador deve parar no retorno desta função, invoca o método
user_return()(que deve ser substituído em subclasses). Levanta a exceçãoBdbQuitse o sinalizadorquittingestiver definido (ele pode ser definido a partir deuser_return()). Retorna uma referência ao métodotrace_dispatch()para continuar o rastreamento nesse escopo.
- dispatch_exception(frame, arg)¶
Se o depurador deve parar nesta exceção, invoca o método
user_exception()(que deve ser substituído em subclasses). Levanta a exceçãoBdbQuitse o sinalizadorquittingestiver definido (ele pode ser definido a partir deuser_exception()). Retorna uma referência ao métodotrace_dispatch()para continuar o rastreamento nesse escopo.
Normalmente, as classes derivadas não substituem o seguinte métodos, mas podem fazê-lo se quiserem redefinir a definição de parada e de pontos de interrupção.
- is_skipped_module(module_name)¶
Retorna
Truese module_name corresponder a algum padrão de skip.
- stop_here(frame)¶
Retorna
Truese frame estiver abaixo do frame inicial na pilha.
- break_here(frame)¶
Retorna
Truese houver um ponto de interrupção efetivo para essa linha.Verifica se uma linha ou função ponto de interrupção existe e está em vigor. Exclua os pontos de interrupção temporários com base nas informações de
effective().
- break_anywhere(frame)¶
Retorna
Truese existir algum ponto de interrupção para o nome de arquivo de frame’s.
As classes derivadas devem substituir esses métodos para obter controle sobre a operação da depurador.
- user_call(frame, argument_list)¶
Chamado a partir de
dispatch_call()se um ponto de interrupção puder parar dentro da função chamada.argument_list não é mais usado e sempre será
None. O argumento é mantido por retrocompatibilidade.
- user_line(frame)¶
Chamado a partir de
dispatch_line()quandostop_here()oubreak_here()retornamTrue.
- user_return(frame, return_value)¶
Chamado a partir de
dispatch_return()quandostop_here()retornaTrue.
- user_exception(frame, exc_info)¶
Chamado a partir de
dispatch_exception()quandostop_here()retornaTrue.
- do_clear(arg)¶
Manipula como um ponto de interrupção deve ser removido quando for temporário.
Esse método deve ser implementado por classes derivadas.
As classes derivadas e os clientes podem chamar os métodos a seguir para afetar o estado de stepping.
- set_step()¶
Parar após uma linha de código.
- set_next(frame)¶
Parar na próxima linha no frame fornecido ou abaixo dele.
- set_return(frame)¶
Parar ao retornar do frame fornecido.
- set_until(frame, lineno=None)¶
Parar quando a linha com lineno maior que a atual for alcançada ou ao retornar do frame atual.
- set_trace([frame])¶
Inicia a depuração a partir de frame. Se frame não for especificado, a depuração começa a partir do frame do chamador.
Alterado na versão 3.13:
set_trace()entrará no depurador imediatamente, em vez de na próxima linha de código a ser executada.
- set_continue()¶
Pare somente nos pontos de interrupção ou quando terminar. Se não houver pontos de interrupção, defina o sistema função de rastreamento como
None.
- set_quit()¶
Defina o atributo
quittingcomoTrue. Isso levantaBdbQuitna próxima chamada de um dos métodosdispatch_*().
Classes derivadas e clientes podem chamar os métodos a seguir para manipular pontos de interrupção. Esses métodos retornam uma string contendo uma mensagem de erro se algo der errado, ou
Nonese tudo estiver correto.- set_break(filename, lineno, temporary=False, cond=None, funcname=None)¶
Define um novo ponto de interrupção. Se a linha lineno não existir para o filename passado como argumento, retorna uma mensagem de erro. O filename deve estar na forma canônica, conforme descrito no método
canonic().
- clear_break(filename, lineno)¶
Exclui os pontos de interrupção em filename e lineno. Se nenhum tiver sido definido, retorna uma mensagem de erro.
- clear_bpbynumber(arg)¶
Exclui o ponto de interrupção cujo índice é arg em
Breakpoint.bpbynumber. Se arg não for numérico ou estiver fora do intervalo, retorna uma mensagem de erro.
- clear_all_file_breaks(filename)¶
Exclui todos os pontos de interrupção em filename. Se nenhum tiver sido definido, retorna uma mensagem de erro.
- clear_all_breaks()¶
Exclui todos os pontos de interrupção existentes. Se nenhum tiver sido definido, retorna uma mensagem de erro.
- get_bpbynumber(arg)¶
Retorna o ponto de interrupção especificado pelo número fornecido. Se arg for uma string, ele será convertido para um número. Se arg for uma string não numérica, se o ponto de interrupção nunca tiver existido ou tiver sido excluído, uma
ValueErrorserá levantada.Adicionado na versão 3.2.
- get_break(filename, lineno)¶
Retorna
Truese houver um ponto de interrupção para lineno em filename.
- get_breaks(filename, lineno)¶
Retorna todos os pontos de interrupção para lineno em filename, ou uma lista vazia se nenhum estiver definido.
- get_file_breaks(filename)¶
Retorna todos os pontos de interrupção em filename, ou uma lista vazia se nenhum estiver definido.
- get_all_breaks()¶
Retorna todos os pontos de interrupção definidos.
Classes derivadas e clientes podem chamar os métodos a seguir para desabilitar e reiniciar eventos a fim de obter melhor desempenho. Esses métodos só funcionam ao usar o backend
'monitoring'.- disable_current_event()¶
Desabilita o evento atual até a próxima vez que
restart_events()for chamada. Isso é útil quando o depurador não está interessado na linha atual.Adicionado na versão 3.14.
- restart_events()¶
Reinicia todos os eventos desabilitados. Essa função é chamada automaticamente nos métodos
dispatch_*após a chamada dos métodosuser_*. Se os métodosdispatch_*não forem substituídos, os eventos desabilitados serão reiniciados após cada interação do usuário.Adicionado na versão 3.14.
Classes derivadas e clientes podem chamar os métodos a seguir para obter uma estrutura de dados que represente um stack trace (situação da pilha de execução).
- get_stack(f, t)¶
Retorna uma lista de tuplas (frame, lineno) em um stack trace e um tamanho.
O frame chamado mais recentemente é o último da lista. O tamanho é o número de frames abaixo do frame onde o depurador foi invocado.
- format_stack_entry(frame_lineno, lprefix=': ')¶
Retorna uma string com informações sobre uma entrada da pilha, que é uma tupla
(frame, lineno). A string retornada contém:O nome de arquivo canônico que contém o quadro.
O nome da função ou
"<lambda>".O argumento de entrada.
O valor de retorno.
A linha de código (se existir).
Os dois métodos a seguir podem ser chamados pelos clientes para usar um depurador e depurar uma instrução, fornecida como uma string.
- run(cmd, globals=None, locals=None)¶
Depura uma instrução executada por meio da função
exec(). globals assume por padrão__main__.__dict__, locals assume por padrão globals.
- runeval(expr, globals=None, locals=None)¶
Depura uma expressão executada por meio da função
eval(). globals e locals têm o mesmo significado que emrun().
- runcall(func, /, *args, **kwds)¶
Depura uma única chamada de função e retorna seu resultado.
Por fim, o módulo define as funções a seguir:
- bdb.checkfuncname(b, frame)¶
Retorna
Truese devemos interromper aqui, dependendo da forma como oBreakpointfoi configurado.If it was set via line number, it checks if
b.lineis the same as the one in frame. If the breakpoint was set viafunction name, we have to check we are in the right frame (the right function) and if we are on its first executable line.
- bdb.effective(file, line, frame)¶
Retorna
(active breakpoint, delete temporary flag)ou(None, None)como o ponto de interrupção sobre o qual agir.The active breakpoint is the first entry in
bplistfor the (file,line) (which must exist) that isenabled, for whichcheckfuncname()is true, and that has neither a falseconditionnor positiveignorecount. The flag, meaning that a temporary breakpoint should be deleted, isFalseonly when thecondcannot be evaluated (in which case,ignorecount is ignored).Se essa entrada não existir, será retornado
(None, None).