Files
obitools4/pkg/obioptions/options.go

178 lines
3.9 KiB
Go
Raw Normal View History

2022-01-13 23:27:39 +01:00
package obioptions
import (
"fmt"
"os"
"runtime"
2022-01-13 23:27:39 +01:00
2022-02-24 12:14:52 +01:00
log "github.com/sirupsen/logrus"
2022-01-13 23:27:39 +01:00
"github.com/DavidGamba/go-getoptions"
"net/http"
_ "net/http/pprof"
2022-01-13 23:27:39 +01:00
)
var _Debug = false
var _WorkerPerCore = 2.0
var _ReadWorkerPerCore = 1.0
2022-02-06 18:52:53 +01:00
var _MaxAllowedCPU = runtime.NumCPU()
var _BatchSize = 5000
var _Pprof = false
var _Quality_Shift_Input = 33
var _Quality_Shift_Output = 33
2022-01-13 23:27:39 +01:00
type ArgumentParser func([]string) (*getoptions.GetOpt, []string)
2022-01-13 23:27:39 +01:00
func GenerateOptionParser(optionset ...func(*getoptions.GetOpt)) ArgumentParser {
2022-01-13 23:27:39 +01:00
options := getoptions.New()
options.SetMode(getoptions.Bundling)
options.SetUnknownMode(getoptions.Fail)
2022-01-13 23:27:39 +01:00
options.Bool("help", false, options.Alias("h", "?"))
options.BoolVar(&_Debug, "debug", false)
options.BoolVar(&_Pprof, "pprof", false)
// options.IntVar(&_ParallelWorkers, "workers", _ParallelWorkers,
// options.Alias("w"),
// options.Description("Number of parallele threads computing the result"))
2022-02-06 18:52:53 +01:00
options.IntVar(&_MaxAllowedCPU, "max-cpu", _MaxAllowedCPU,
options.GetEnv("OBIMAXCPU"),
options.Description("Number of parallele threads computing the result"))
2022-01-13 23:27:39 +01:00
options.IntVar(&_BatchSize, "batch-size", _BatchSize,
options.GetEnv("OBIBATCHSIZE"),
options.Description("Number of sequence per batch for paralelle processing"))
options.Bool("solexa", false,
options.GetEnv("OBISOLEXA"),
options.Description("Decodes quality string according to the Solexa specification."))
2022-01-13 23:27:39 +01:00
for _, o := range optionset {
o(options)
}
return func(args []string) (*getoptions.GetOpt, []string) {
2022-01-13 23:27:39 +01:00
remaining, err := options.Parse(args[1:])
if options.Called("help") {
fmt.Fprint(os.Stderr, options.Help())
os.Exit(1)
}
log.SetLevel(log.InfoLevel)
if options.Called("debug") {
log.SetLevel(log.DebugLevel)
log.Debugln("Switch to debug level logging")
}
if options.Called("pprof") {
go http.ListenAndServe("localhost:8080", nil)
log.Infoln("Start a pprof server at address http://localhost:8080/debug/pprof")
}
// Handle user errors
if err != nil {
fmt.Fprintf(os.Stderr, "ERROR: %s\n\n", err)
fmt.Fprint(os.Stderr, options.Help(getoptions.HelpSynopsis))
os.Exit(1)
}
2022-02-06 18:52:53 +01:00
// Setup the maximum number of CPU usable by the program
runtime.GOMAXPROCS(_MaxAllowedCPU)
if options.Called("max-cpu") {
log.Printf("CPU number limited to %d", _MaxAllowedCPU)
}
2022-02-24 12:14:52 +01:00
if options.Called("no-singleton") {
log.Printf("No singleton option set")
}
log.Printf("Number of workers set %d", CLIParallelWorkers())
if options.Called("workers") {
}
if options.Called("solexa") {
SetInputQualityShift(64)
}
return options, remaining
2022-01-13 23:27:39 +01:00
}
}
// Predicate indicating if the debug mode is activated.
2022-02-01 17:31:28 +01:00
func CLIIsDebugMode() bool {
return _Debug
}
2022-02-01 17:31:28 +01:00
// CLIParallelWorkers returns the number of parallel workers requested by
// the command line option --workers|-w.
2022-02-01 17:31:28 +01:00
func CLIParallelWorkers() int {
return int(float64(_MaxAllowedCPU) * float64(_WorkerPerCore))
}
func CLIReadParallelWorkers() int {
return int(float64(_MaxAllowedCPU) * float64(_ReadWorkerPerCore))
}
2022-02-06 18:52:53 +01:00
// CLIParallelWorkers returns the number of parallel workers requested by
// the command line option --workers|-w.
func CLIMaxCPU() int {
return _MaxAllowedCPU
}
2022-02-01 17:31:28 +01:00
// CLIBatchSize returns the expeted size of the sequence batches
func CLIBatchSize() int {
return _BatchSize
2022-01-13 23:27:39 +01:00
}
// DebugOn sets the debug mode on.
2022-01-13 23:27:39 +01:00
func DebugOn() {
_Debug = true
2022-01-13 23:27:39 +01:00
}
// DebugOff sets the debug mode off.
2022-01-13 23:27:39 +01:00
func DebugOff() {
_Debug = false
2022-01-13 23:27:39 +01:00
}
func SetWorkerPerCore(n float64) {
_WorkerPerCore = n
}
func SetReadWorkerPerCore(n float64) {
_ReadWorkerPerCore = n
}
func WorkerPerCore() float64 {
return _WorkerPerCore
}
func ReadWorkerPerCore() float64 {
return _ReadWorkerPerCore
}
func SetBatchSize(n int) {
_BatchSize = n
}
func InputQualityShift() int {
return _Quality_Shift_Input
}
func OutputQualityShift() int {
return _Quality_Shift_Output
}
func SetInputQualityShift(n int) {
_Quality_Shift_Input = n
}
func SetOutputQualityShift(n int) {
_Quality_Shift_Output = n
}