All checks were successful
Test / Create distribution (push) Successful in 26s
Test / Sandbox (push) Successful in 1m44s
Test / Fortify (push) Successful in 2m37s
Test / Sandbox (race detector) (push) Successful in 2m59s
Test / Fpkg (push) Successful in 3m34s
Test / Fortify (race detector) (push) Successful in 4m6s
Test / Flake checks (push) Successful in 59s
This reduces the scope of the fst package, which was growing questionably large. Signed-off-by: Ophestra <cat@gensokyo.uk>
30 lines
647 B
Go
30 lines
647 B
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
|
|
"git.gensokyo.uk/security/fortify/fst"
|
|
"git.gensokyo.uk/security/fortify/internal/app"
|
|
"git.gensokyo.uk/security/fortify/internal/app/instance"
|
|
"git.gensokyo.uk/security/fortify/internal/fmsg"
|
|
)
|
|
|
|
func mustRunApp(ctx context.Context, config *fst.Config, beforeFail func()) {
|
|
rs := new(app.RunState)
|
|
a := instance.MustNew(instance.ISetuid, ctx, std)
|
|
|
|
var code int
|
|
if sa, err := a.Seal(config); err != nil {
|
|
fmsg.PrintBaseError(err, "cannot seal app:")
|
|
code = 1
|
|
} else {
|
|
code = instance.PrintRunStateErr(instance.ISetuid, rs, sa.Run(rs))
|
|
}
|
|
|
|
if code != 0 {
|
|
beforeFail()
|
|
os.Exit(code)
|
|
}
|
|
}
|