закешированный к нам в целях безопасности дебаггер
Go to file
2014-11-10 12:04:09 -06:00
_fixtures Improve overall thread coordination 2014-11-07 23:45:54 -06:00
command Add goroutines to help command 2014-11-09 13:00:35 -06:00
dwarf Add command to print all goroutines info 2014-11-09 12:56:21 -06:00
goreadline fix readline support: window resizing 2014-11-10 07:06:33 -06:00
helper (Mostly) working multithreaded tracing implementation 2014-10-25 08:59:22 -05:00
proctl cleanup 2014-11-10 07:04:05 -06:00
vendor Rename project 2014-10-15 09:28:22 -05:00
.gitignore Ignore tag files 2014-09-29 20:25:45 -05:00
LICENSE Add License and README 2014-05-03 15:31:52 -05:00
main_test.go (Mostly) working multithreaded tracing implementation 2014-10-25 08:59:22 -05:00
main.go Use delve instead of dlv everywhere, for now 2014-11-10 12:04:09 -06:00
README.md Use delve instead of dlv everywhere, for now 2014-11-10 12:04:09 -06:00

Delve

What is Delve?

Delve is a Go debugger, written in Go.

Building

Currently, Delve requires the following patch, however this change is vendored until Go 1.4 lands, so the project is go get-able.

Features

  • Attach to an already running process
  • Launch a process and begin debug session
  • Set breakpoints, single step, step over functions, print variable contents

Usage

The debugger can be launched in three ways:

  • Compile, run, and attach in one step:

    $ delve -run
    
  • Provide the name of the program you want to debug, and the debugger will launch it for you.

    $ delve -proc path/to/program
    
  • Provide the pid of a currently running process, and the debugger will attach and begin the session.

    $ sudo delve -pid 44839
    

Breakpoints

Delve can insert breakpoints via the breakpoint command once inside a debug session, however for ease of debugging, you can also call runtime.Breakpoint() and Delve will handle the breakpoint and stop the program at the next source line.

Commands

Once inside a debugging session, the following commands may be used:

  • break - Set break point at the entry point of a function, or at a specific file/line. Example: break foo.go:13.

  • continue - Run until breakpoint or program termination.

  • step - Single step through program.

  • next - Step over to next source line.

  • threads - Print the status of all traced goroutines.

  • goroutines - Print status of all goroutines.

  • print $var - Evaluate a variable.

Upcoming features

  • In-scope variable setting
  • Support for OS X

License

MIT