open-nomad/vendor/github.com/mitchellh/go-ps
James Nugent a69b3b0952 deps: Update github.com/mitchellh/go-ps
This update pulls in a commit adding support for Solaris.
2017-03-09 08:39:46 -05:00
..
LICENSE.md Vendoring go-ps 2016-05-28 19:51:22 -07:00
process.go Vendoring go-ps 2016-05-28 19:51:22 -07:00
process_darwin.go deps: Update github.com/mitchellh/go-ps 2017-03-09 08:39:46 -05:00
process_freebsd.go Vendoring go-ps 2016-05-28 19:51:22 -07:00
process_linux.go deps: Update github.com/mitchellh/go-ps 2017-03-09 08:39:46 -05:00
process_solaris.go deps: Update github.com/mitchellh/go-ps 2017-03-09 08:39:46 -05:00
process_unix.go deps: Update github.com/mitchellh/go-ps 2017-03-09 08:39:46 -05:00
process_windows.go Vendoring go-ps 2016-05-28 19:51:22 -07:00
README.md deps: Update github.com/mitchellh/go-ps 2017-03-09 08:39:46 -05:00
Vagrantfile Vendoring go-ps 2016-05-28 19:51:22 -07:00

Process List Library for Go

go-ps is a library for Go that implements OS-specific APIs to list and manipulate processes in a platform-safe way. The library can find and list processes on Linux, Mac OS X, Solaris, and Windows.

If you're new to Go, this library has a good amount of advanced Go educational value as well. It uses some advanced features of Go: build tags, accessing DLL methods for Windows, cgo for Darwin, etc.

How it works:

  • Darwin uses the sysctl syscall to retrieve the process table.
  • Unix uses the procfs at /proc to inspect the process tree.
  • Windows uses the Windows API, and methods such as CreateToolhelp32Snapshot to get a point-in-time snapshot of the process table.

Installation

Install using standard go get:

$ go get github.com/mitchellh/go-ps
...

TODO

Want to contribute? Here is a short TODO list of things that aren't implemented for this library that would be nice:

  • FreeBSD support
  • Plan9 support