Handling errors in short programs

suggest change

Propagating errors up to the callers is tedious. You end up with many lines looking like:

r, err := os.Open("my file")
if err != nil {
    return err

This kind of error handling diligence is crucial for writing robust software.

Sometimes you write shorter cmd-line programs where such discipline is not warranted.

You can simplify error handling with a helper functions PanicIfErr(err error, args ...interface{}):

r, err := os.Open("my file")

Implementation of such helper:

// FmtArgs formats args as a string. First argument should be format string
// and the rest are arguments to the format
func FmtArgs(args ...interface{}) string {
	if len(args) == 0 {
		return ""
	format := args[0].(string)
	if len(args) == 1 {
		return format
	return fmt.Sprintf(format, args[1:]...)

func panicWithMsg(defaultMsg string, args ...interface{}) {
	s := FmtArgs(args...)
	if s == "" {
		s = defaultMsg
	fmt.Printf("%s\n", s)

// PanicIf panics if cond is true
func PanicIf(cond bool, args ...interface{}) {
	if !cond {
	panicWithMsg("PanicIf: condition failed", args...)

// PanicIfErr panics if err is not nil
func PanicIfErr(err error, args ...interface{}) {
	if err == nil {
	panicWithMsg(err.Error(), args...)

func main() {
	PanicIfErr(nil)                              // nothing happens
	PanicIfErr(errors.New("there was an error")) // will panic
there was an error
panic: there was an error

goroutine 1 [running]:
main.panicWithMsg(0x4c5081, 0x12, 0x0, 0x0, 0x0)
	/tmp/src099150232/main.go:30 +0x126
main.PanicIfErr(0x4dc8c0, 0xc00005a1e0, 0x0, 0x0, 0x0)
	/tmp/src099150232/main.go:46 +0x6c
	/tmp/src099150232/main.go:51 +0x84
exit status 2

Feedback about page:

Optional: your email if you want me to get back to you:

Table Of Contents