"bdb" --- 디버거 프레임워크
***************************

**소스 코드:** Lib/bdb.py

======================================================================

"bdb" 모듈은 중단점 설정이나 디버거를 통한 실행 관리와 같은 기본 디버
거 기능을 처리합니다.

다음 예외가 정의됩니다:

exception bdb.BdbQuit

   디버거를 종료하기 위해 "Bdb" 클래스가 발생시키는 예외.

"bdb" 모듈은 또한 두 가지 클래스를 정의합니다:

class bdb.Breakpoint(self, file, line, temporary=0, cond=None, funcname=None)

   이 클래스는 임시 중단점, 무시 카운트, 비활성화와 (재) 활성화 및 조
   건을 구현합니다.

   중단점은 "bpbynumber"라는 리스트를 통해 번호로, "bplist"를 통해
   "(file, line)" 쌍으로 인덱싱됩니다. 전자는 "Breakpoint" 클래스의 단
   일 인스턴스를 가리킵니다. 후자는 줄당 하나 이상의 중단점이 있을 수
   있어서 이러한 인스턴스의 리스트를 가리킵니다.

   중단점을 만들 때, 연관된 파일명은 규범적 형식(canonical form)이어야
   합니다. *funcname*이 정의되면, 해당 함수의 첫 번째 줄이 실행될 때
   중단점 적중이 카운트됩니다. 조건부 중단점은 항상 적중을 카운트합니
   다.

   "Breakpoint" 인스턴스에는 다음과 같은 메서드가 있습니다:

   deleteMe()

      file/line과 관련된 리스트에서 중단점을 삭제합니다. 해당 위치의
      마지막 중단점이면, file/line의 항목도 삭제합니다.

   enable()

      중단점을 활성화된 것으로 표시합니다.

   disable()

      중단점을 비활성화된 것으로 표시합니다.

   bpformat()

      멋지게 포맷된, 중단점에 대한 모든 정보가 포함된 문자열을 반환합
      니다:

      * 중단점 번호

      * 일시적인지 아닌지.

      * file,line 위치.

      * 중단을 일으키는 조건.

      * 다음 N 번 무시해야 하는지 여부.

      * 중단점 적중 횟수.

      버전 3.2에 추가.

   bpprint(out=None)

      "bpformat()"의 출력을 파일 *out*, 또는 "None"이면 표준 출력으로
      인쇄합니다.

class bdb.Bdb(skip=None)

   "Bdb" 클래스는 범용 파이썬 디버거 베이스 클래스 역할을 합니다.

   이 클래스는 추적 기능의 세부 사항을 처리합니다; 파생 클래스는 사용
   자 상호 작용을 구현해야 합니다. 표준 디버거 클래스 ("pdb.Pdb")가 예
   입니다.

   *skip* 인자는, 주어지면, glob 스타일 모듈 이름 패턴의 이터러블 이어
   야 합니다. 디버거는 이러한 패턴 중 하나와 일치하는 모듈에서 시작되
   는 프레임으로 들어가지 않습니다. 프레임을 특정 모듈에서 시작된 것으
   로 간주하는지는 프레임 전역의 "__name__"에 의해 결정됩니다.

   버전 3.1에 추가: *skip* 인자

   "Bdb"의 다음 메서드는 일반적으로 재정의할 필요가 없습니다.

   canonic(filename)

      파일명을 규범적 형식, 즉 주변 화살 괄호(angle brackets)를 제거한
      케이스 정규화된(case-normalized) (대소 문자를 구분하지 않는 파일
      시스템에서) 절대 경로로 얻는 보조 메서드.

   reset()

      디버깅을 시작할 준비가 된 값으로 "botframe", "stopframe",
      "returnframe" 및 "quitting" 어트리뷰트를 설정합니다.

   trace_dispatch(frame, event, arg)

      이 함수는 디버그되는 프레임의 추적 함수(trace function)로 설치됩
      니다. 반환 값은 새로운 추적 함수(대부분 자체)입니다.

      기본 구현은 실행되려고 하는 (문자열로 전달된) 이벤트의 유형에 따
      라 프레임을 디스패치 하는 방법을 결정합니다. *event*는 다음 중
      하나일 수 있습니다:

      * ""line"": 새로운 코드 줄이 실행되려고 합니다.

      * ""call"": 함수가 호출되거나, 다른 코드 블록에 진입하려고 합니
        다.

      * ""return"": 함수나 다른 코드 블록이 반환하려고 합니다.

      * ""exception"": 예외가 발생했습니다.

      * ""c_call"": C 함수가 호출되려고 합니다.

      * ""c_return"": C 함수가 반환했습니다.

      * ""c_exception"": C 함수가 예외를 발생시켰습니다.

      파이썬 이벤트의 경우, 특수 함수(아래를 참조하세요)가 호출됩니다.
      C 이벤트의 경우, 아무런 액션도 취하지 않습니다.

      *arg* 매개 변수는 앞의 이벤트에 따라 다릅니다.

      추적 함수에 대한 자세한 내용은 "sys.settrace()" 설명서를 참조하
      십시오. 코드와 프레임 객체에 대한 자세한 내용은 표준형 계층을 참
      조하십시오.

   dispatch_line(frame)

      디버거가 현재 행에서 중지해야 하면, "user_line()" 메서드를 호출
      하십시오 (서브 클래스에서 재정의되어야 합니다). "Bdb.quitting"
      플래그가 설정되면 ("user_line()"에서 설정할 수 있습니다)
      "BdbQuit" 예외를 발생시킵니다. 해당 스코프에서 추가 추적을 위해
      "trace_dispatch()" 메서드에 대한 참조를 반환합니다.

   dispatch_call(frame, arg)

      디버거가 이 함수 호출에서 중지해야 하면, "user_call()" 메서드를
      호출하십시오 (서브 클래스에서 재정의되어야 합니다).
      "Bdb.quitting" 플래그가 설정되면 ("user_call()"에서 설정할 수 있
      습니다) "BdbQuit" 예외를 발생시킵니다. 해당 스코프에서 추가 추적
      을 위해 "trace_dispatch()" 메서드에 대한 참조를 반환합니다.

   dispatch_return(frame, arg)

      디버거가 이 함수 반환에서 중지해야 하면, "user_return()" 메서드
      를 호출하십시오 (서브 클래스에서 재정의되어야 합니다).
      "Bdb.quitting" 플래그가 설정되면 ("user_return()"에서 설정할 수
      있습니다) "BdbQuit" 예외를 발생시킵니다. 해당 스코프에서 추가 추
      적을 위해 "trace_dispatch()" 메서드에 대한 참조를 반환합니다.

   dispatch_exception(frame, arg)

      디버거가 이 예외에서 중지해야 하면, "user_exception()" 메서드를
      호출하십시오 (서브 클래스에서 재정의되어야 합니다).
      "Bdb.quitting" 플래그가 설정되면 ("user_exception()"에서 설정할
      수 있습니다) "BdbQuit" 예외를 발생시킵니다. 해당 스코프에서 추가
      추적을 위해 "trace_dispatch()" 메서드에 대한 참조를 반환합니다.

   일반적으로 파생된 클래스는 다음 메서드를 재정의하지 않지만, 중지와
   중단점의 정의를 재정의하려고 하면 그럴 수 있습니다.

   stop_here(frame)

      이 메서드는 *frame*이 호출 스택에서 "botframe" 아래 어딘가에 있
      는지 확인합니다. "botframe"은 디버깅이 시작된 프레임입니다.

   break_here(frame)

      이 메서드는 *frame*에 속하는 파일명과 줄에, 또는 적어도 현재 함
      수에 중단점이 있는지 확인합니다. 중단점이 일시적이면 이 메서드는
      그것을 삭제합니다.

   break_anywhere(frame)

      이 메서드는 현재 프레임의 파일명에 중단점이 있는지 확인합니다.

   파생 클래스는 디버거 연산을 제어하기 위해 이 메서드를 재정의해야 합
   니다.

   user_call(frame, argument_list)

      이 메서드는 호출된 함수 내부 어디에서나 중단이 필요할 수 있을 때
      "dispatch_call()"에서 호출됩니다.

   user_line(frame)

      이 메서드는 "stop_here()"나 "break_here()"가 "True"를 산출할 때
      "dispatch_line()"에서 호출됩니다.

   user_return(frame, return_value)

      이 메서드는 "stop_here()"가 "True"를 산출할 때
      "dispatch_return()"에서 호출됩니다.

   user_exception(frame, exc_info)

      이 메서드는 "stop_here()"가 "True"를 산출할 때
      "dispatch_exception()"에서 호출됩니다.

   do_clear(arg)

      중단점이 일시적일 때 중단점을 제거하는 방법을 처리합니다.

      이 메서드는 파생 클래스에서 구현해야 합니다.

   파생 클래스와 클라이언트는 다음 메서드를 호출하여 스테핑(stepping)
   상태에 영향을 줄 수 있습니다.

   set_step()

      한 줄의 코드 후에 멈춥니다.

   set_next(frame)

      주어진 프레임 내 또는 아래의 다음 줄에서 멈춥니다.

   set_return(frame)

      주어진 프레임에서 반환할 때 멈춥니다.

   set_until(frame)

      현재 줄보다 크지 않은 줄에 도달하거나 현재 프레임에서 반환할 때
      멈춥니다.

   set_trace([frame])

      *frame*에서 디버깅을 시작합니다. *frame*을 지정하지 않으면 호출
      자의 프레임에서 디버깅을 시작합니다.

   set_continue()

      중단점에서나 완료 시에만 멈춥니다. 중단점이 없으면, 시스템 추적
      함수를 "None"으로 설정합니다.

   set_quit()

      "quitting" 어트리뷰트를 "True"로 설정합니다. 다음에
      "dispatch_*()" 메서드 중 하나를 호출할 때 "BdbQuit"가 발생합니다
      .

   파생 클래스와 클라이언트는 다음 메서드를 호출하여 중단점을 조작할
   수 있습니다. 이 메서드는 문제가 발생하면 에러 메시지가 포함된 문자
   열을 반환하고, 모두 정상이면 "None"을 반환합니다.

   set_break(filename, lineno, temporary=0, cond, funcname)

      새로운 중단점을 설정합니다. 인자로 전달된 *filename*에 *lineno*
      줄이 없으면 에러 메시지를 반환합니다. "canonic()" 메서드에 설명
      된 대로 *filename*은 규범적 형식이어야 합니다.

   clear_break(filename, lineno)

      *filename*과 *lineno*에서 중단점을 삭제합니다. 설정되지 않았으면
      , 에러 오류 메시지가 반환됩니다.

   clear_bpbynumber(arg)

      "Breakpoint.bpbynumber"에서 인덱스 *arg*인 중단점을 삭제합니다.
      *arg*가 숫자가 아니거나 범위를 벗어나면, 에러 메시지를 반환합니
      다.

   clear_all_file_breaks(filename)

      *filename*에서 모든 중단점을 삭제합니다. 설정되지 않았으면, 에러
      메시지가 반환됩니다.

   clear_all_breaks()

      기존 중단점을 모두 삭제합니다.

   get_bpbynumber(arg)

      주어진 숫자로 지정된 중단점을 반환합니다. *arg*가 문자열이면, 숫
      자로 변환됩니다. *arg*가 숫자가 아닌 문자열이면, 지정된 중단점이
      존재하지 않거나 삭제되었으면, "ValueError"가 발생합니다.

      버전 3.2에 추가.

   get_break(filename, lineno)

      *filename*의 *lineno*에 중단점이 있는지 확인합니다.

   get_breaks(filename, lineno)

      *filename*의 *lineno*에 있는 모든 중단점을 반환하거나, 없으면 빈
      리스트를 반환합니다.

   get_file_breaks(filename)

      *filename*의 모든 중단점을 반환하거나, 없으면 빈 리스트를 반환합
      니다.

   get_all_breaks()

      설정된 모든 중단점을 반환합니다.

   파생 클래스와 클라이언트는 다음 메서드를 호출하여 스택 추적을 나타
   내는 데이터 구조를 얻을 수 있습니다.

   get_stack(f, t)

      프레임과 모든 상위(호출하는)와 하위 프레임에 대한 레코드 리스트
      와 상위 부분의 크기를 가져옵니다.

   format_stack_entry(frame_lineno, lprefix=': ')

      "(frame, lineno)" 튜플로 식별되는 스택 항목에 대한 정보가 포함된
      문자열을 반환합니다.:

      * 프레임을 포함하는 파일명의 규범적 형식.

      * 함수 이름, 또는 ""<lambda>"".

      * 입력 인자.

      * 반환 값.

      * 코드 줄 (있으면).

   클라이언트가 문자열로 지정된 *statement*를 디버깅하기 위해 디버거를
   사용하려면 다음 두 가지 메서드를 호출할 수 있습니다.

   run(cmd, globals=None, locals=None)

      "exec()" 함수를 통해 실행된 문장을 디버그합니다. *globals*의 기
      본값은 "__main__.__dict__"이고, *locals*의 기본값은 *globals*입
      니다.

   runeval(expr, globals=None, locals=None)

      "eval()" 함수를 통해 실행된 표현식을 디버그합니다. *globals*와
      *locals*는 "run()"과 같은 의미입니다.

   runctx(cmd, globals, locals)

      이전 버전과의 호환성을 위해. "run()" 메서드를 호출합니다.

   runcall(func, /, *args, **kwds)

      단일 함수 호출을 디버그하고, 결과를 반환합니다.

마지막으로, 모듈은 다음과 같은 함수를 정의합니다:

bdb.checkfuncname(b, frame)

   중단점 *b*가 설정된 방식에 따라, 우리가 여기서 중단해야 하는지를 확
   인합니다.

   줄 번호를 통해 설정되었으면, "b.line"이 인자로 전달된 프레임의 것과
   같은지 확인합니다. 함수 이름을 통해 중단점이 설정되었으면, 우리는
   올바른 프레임(올바른 함수)에 있는지와 그것의 첫 번째 실행 가능한 줄
   에 있는지 확인해야 합니다.

bdb.effective(file, line, frame)

   이 코드 줄에 유효 (활성) 중단점이 있는지 확인합니다. 중단점과 임시
   중단점을 삭제해도 좋은지를 나타내는 불리언의 튜플을 반환합니다. 일
   치하는 중단점이 없으면 "(None, None)"을 반환합니다.

bdb.set_trace()

   호출자의 프레임에서 "Bdb" 인스턴스로 디버깅을 시작합니다.
