* Add ServeWithOptions
This adds support for options to be added to 'Serve' and the app struct.
Options are implemented following the 'functional options' pattern
(https://dave.cheney.net/2014/10/17/functional-options-for-friendly-apis and
https://commandcenter.blogspot.co.uk/2014/01/self-referential-functions-and-design.html).
Future options can be added by creating an exported func that returns a closure
modifying the app struct, like the following:
func HaltAndCatchFire(literallyCatchFire bool) option {
return func(a *app) {
a.haltAndCatchFire = literallyCatchFire
}
}
then in user code:
gracehttp.ServeWithOptions(
[]*http.Server{ &myServer },
gracehttp.HaltAndCatchFire(true),
)
* Add 'StartupHook' option
This option attaches a callback to the application. This callback is triggered
directly before the new process is started during a graceful restart. This
allows the old process to release its hold on any resources that the new
process will need.
For example:
gracehttp.ServeWithOptions(
[]*http.Server{ &myServer },
gracehttp.StartupHook(func () error {
// release port that new process will need to start up successfully
return nil
}
)
* Rename 'StartupHook' to 'PreStartProcess'
This better indicates the timing of the callback by using terms already present
in the codebase. As part of the rename, the related constants in the tests were
fixed to follow the naming convention.