goodbye

package module
v0.0.0-...-a83968b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 27, 2017 License: Apache-2.0 Imports: 7 Imported by: 29

README

Goodbye

Goodbye is a Golang library that provides a standard way to execute code when a process exits normally or due to a signal.

Overview

The Goodbye library uses a sync.Once to ensure that the registered exit handlers are executed only once -- whether as a result of the process exiting normally or as a result of a received signal.

Install

Say hello to goodbye with go get github.com/thecodeteam/goodbye.

Example

There is an example program that illustrates how to use the Goodbye library:

package main

import (
	"context"
	"fmt"
	"os"
	"strings"

	"github.com/thecodeteam/goodbye"
)

func main() {
	// Create a context to use with the Goodbye library's functions.
	ctx := context.Background()

	// Always defer `goodbye.Exit` as early as possible since it is
	// safe to execute no matter what.
	defer goodbye.Exit(ctx, -1)

	// Invoke `goodbye.Notify` to begin trapping signals this process
	// might receive. The Notify function can specify which signals are
	// trapped, but if none are specified then a default list is used.
	// The default set is platform dependent. See the files
	// "goodbye_GOOS.go" for more information.
	goodbye.Notify(ctx)

	// Register two functions that will be executed when this process
	// exits.
	goodbye.Register(func(ctx context.Context, sig os.Signal) {
		fmt.Printf("1: %[1]d: %[1]s\n", sig)
	})

	goodbye.Register(func(ctx context.Context, sig os.Signal) {
		fmt.Printf("2: %[1]d: %[1]s\n", sig)
	})

	// Register a function with a priority that is higher than the two
	// handlers above. Since the default priority is 0, a priority of -1
	// will ensure this function, registered last, is executed first.
	goodbye.RegisterWithPriority(func(ctx context.Context, sig os.Signal) {

		// Use the `goodbye.IsNormalExit` function in conjunction with
		// the signal to determine if this is a signal-based exit. If it
		// is then emit a leading newline character to place the desired
		// text on a line after the `CTRL-C` if that was used to send
		// SIGINT to the process.
		//
		// Note that the extra text is being printed inside the second,
		// registered handler. This is because handlers are executed in
		// reverse order -- the earlier a handler is registered, the later
		// it is executed.
		if !goodbye.IsNormalExit(sig) {
			fmt.Println()
		}

		fmt.Printf("0: %[1]d: %[1]s\n", sig)
	}, -1)

	if len(os.Args) < 2 {
		return
	}

	// If the program's first argument is "wait" then block until the
	// program is killed with a signal -- either from the "kill" command
	// or a CTRL-C.
	if strings.EqualFold("wait", os.Args[1]) {
		c := make(chan int)
		<-c
	}
}
Example 1

This example shows how the exit handlers are invoked when the program exits normally.

$ go run example/example.go
0: 0: nosig
1: 0: nosig
2: 0: nosig

Please note that the first registered exit handler was executed last.

Example 2

This example shows how the exit handlers are executed when a signal is received:

$ go run example/example.go wait
^C
0: 2: interrupt
1: 2: interrupt
2: 2: interrupt

Documentation

Overview

Package goodbye provides a standard way to execute code when a process exits normally or due to a signal.

Index

Constants

This section is empty.

Variables

View Source
var (
	// ExitCode is the exit code used by the Exit function if it is called
	// with an exit code value of -1.
	ExitCode int
)

Functions

func Exit

func Exit(ctx context.Context, exitCode int)

Exit executes all of the registered exit handlers.

The handlers may use the IsNormalExit function and the signal provided to the handler to check if the program is exiting normally or due to a process signal.

func IsNormalExit

func IsNormalExit(sig os.Signal) bool

IsNormalExit returns true if the program is exiting as a result of the Exit function being invoked versus a process signal.

func Notify

func Notify(ctx context.Context, signals ...interface{})

Notify begins trapping the specified signals. This function should be invoked as early as possible by the executing program.

The signals argument accepts a series of os.Signal values. Any os.Signal value in the list may be succeeded with an integer to be used as the process's exit code when the associated signal is received. By default the process will exit with an exit code of zero, indicating a graceful shutdown.

The default value for the signals variadic depends on the operating system (OS):

UNIX
  SIGKILL, 1, SIGHUP, 0, SIGINT, 0, SIGQUIT, 0, SIGTERM, 0

Windows
  SIGKILL, 1, SIGHUP, 0, os.Interrupt, 0, SIGQUIT, 0, SIGTERM, 0

func Register

func Register(f ExitHandler)

Register registers a function to be invoked when this process exits normally or due to a process signal.

Handlers registered with this function are given a priority of 0.

func RegisterWithPriority

func RegisterWithPriority(f ExitHandler, priority int)

RegisterWithPriority registers a function to be invoked when this process exits normally or due to a process signal.

The priority determines when an exit handler is executed. Handlers with a lower integer value execute first and higher integer values execute later. If multiple handlers share the same priority level then the handlers are invoked in the order in which they were registered.

func Reset

func Reset()

Reset clears the list of registered exit handlers and stops trapping the signals that were trapped as a result of the Notify function.

Types

type ExitHandler

type ExitHandler func(ctx context.Context, s os.Signal)

ExitHandler is a function that is registerd with the "Register" function and is invoked when this process exits, either normally or due to a process signal.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL