master > master: code go - cleanup von cli + option, um checks ein+auszuschalten
This commit is contained in:
		
							parent
							
								
									8cd99c1632
								
							
						
					
					
						commit
						fce25de013
					
				| @ -64,14 +64,20 @@ func FancyBinarySearch(input_L []int, input_x int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_x) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = BinarySearch(input_L, input_x) | ||||
| @ -79,16 +85,22 @@ func FancyBinarySearch(input_L []int, input_x int) (int, error) { | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_x, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
|  | ||||
| @ -66,14 +66,20 @@ func FancyInterpolationSearch(input_L []int, input_x int, input_u int, input_v i | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_x, input_u, input_v) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = InterpolationSearch(input_L, input_x, input_u, input_v) | ||||
| @ -81,16 +87,22 @@ func FancyInterpolationSearch(input_L []int, input_x int, input_u int, input_v i | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_x, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
|  | ||||
| @ -61,14 +61,20 @@ func FancyFindIthSmallest(input_L []int, input_i int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_i) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_value = FindIthSmallest(input_L, input_i) | ||||
| @ -76,16 +82,22 @@ func FancyFindIthSmallest(input_L []int, input_i int) (int, error) { | ||||
| 			"value": output_value, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_i, output_value) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_value, err | ||||
| } | ||||
| @ -109,14 +121,20 @@ func FancyFindIthSmallestDC(input_L []int, input_i int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_i) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_value = FindIthSmallestDC(input_L, input_i) | ||||
| @ -124,16 +142,22 @@ func FancyFindIthSmallestDC(input_L []int, input_i int) (int, error) { | ||||
| 			"value": output_value, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_i, output_value) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_value, err | ||||
| } | ||||
|  | ||||
| @ -65,14 +65,20 @@ func FancyJumpSearchLinear(input_L []int, input_x int, input_m int) (int, error) | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_x, input_m) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = JumpSearchLinear(input_L, input_x, input_m) | ||||
| @ -80,16 +86,22 @@ func FancyJumpSearchLinear(input_L []int, input_x int, input_m int) (int, error) | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_x, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
| @ -113,14 +125,20 @@ func FancyJumpSearchExponentiell(input_L []int, input_x int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_x) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = JumpSearchExponentiell(input_L, input_x) | ||||
| @ -128,16 +146,22 @@ func FancyJumpSearchExponentiell(input_L []int, input_x int) (int, error) { | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_x, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
|  | ||||
| @ -59,14 +59,20 @@ func FancyFindPoison(input_L []int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = FindPoison(input_L) | ||||
| @ -74,16 +80,22 @@ func FancyFindPoison(input_L []int) (int, error) { | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
| @ -106,14 +118,20 @@ func FancyFindPoisonFast(input_L []int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = FindPoisonFast(input_L) | ||||
| @ -121,16 +139,22 @@ func FancyFindPoisonFast(input_L []int) (int, error) { | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
|  | ||||
| @ -62,14 +62,20 @@ func FancySequentialSearch(input_L []int, input_x int) (int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L, input_x) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_index = SequentialSearch(input_L, input_x) | ||||
| @ -77,16 +83,22 @@ func FancySequentialSearch(input_L []int, input_x int) (int, error) { | ||||
| 			"index": output_index, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, input_x, output_index) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_index, err | ||||
| } | ||||
|  | ||||
| @ -53,14 +53,20 @@ func FancyMaxSubSum(input_L []int) (int, int, int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_maxSum, output_indexFrom, output_indexTo = MaxSubSum(input_L) | ||||
| @ -70,16 +76,22 @@ func FancyMaxSubSum(input_L []int) (int, int, int, error) { | ||||
| 			"index_to":   output_indexTo, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, output_maxSum, output_indexFrom, output_indexTo) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_maxSum, output_indexFrom, output_indexTo, err | ||||
| } | ||||
| @ -104,14 +116,20 @@ func FancyMaxSubSumDC(input_L []int) (int, int, int, error) { | ||||
| 	do_once := true | ||||
| 	for do_once { | ||||
| 		do_once = false | ||||
| 
 | ||||
| 		// Start Message | ||||
| 		setup.DisplayStartOfAlgorithm(name, inputs) | ||||
| 
 | ||||
| 		// Metriken initialisieren | ||||
| 		metrics.RestartMetrics() | ||||
| 
 | ||||
| 		// Prechecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = preChecks(input_L) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Ausführung des Algorithmus: | ||||
| 		output_maxSum, output_indexFrom, output_indexTo = MaxSubSumDC(input_L) | ||||
| @ -121,16 +139,22 @@ func FancyMaxSubSumDC(input_L []int) (int, int, int, error) { | ||||
| 			"index_to":   output_indexTo, | ||||
| 		} | ||||
| 
 | ||||
| 		// Letzte Messages: | ||||
| 		// Metriken anzeigen | ||||
| 		if setup.AppConfigShowMetrics() { | ||||
| 			setup.DisplayMetrics() | ||||
| 		} | ||||
| 
 | ||||
| 		// End Message | ||||
| 		setup.DisplayEndOfAlgorithm(outputs) | ||||
| 
 | ||||
| 		// Postchecks: | ||||
| 		if setup.AppConfigPerformChecks() { | ||||
| 			err = postChecks(input_L, output_maxSum, output_indexFrom, output_indexTo) | ||||
| 			if err != nil { | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return output_maxSum, output_indexFrom, output_indexTo, err | ||||
| } | ||||
|  | ||||
| @ -94,3 +94,17 @@ func FormatTextBlockAsList(text string, options ...bool) []string { | ||||
| func StripAnsi(text string) string { | ||||
| 	return re.Sub(`\x1b[^m]*m`, ``, text) | ||||
| } | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * METHODS string -> bool | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| func IsTrue(text string) bool { | ||||
| 	text = strings.TrimSpace(text) | ||||
| 	return re.Matches(`(?i)(^(true|t|yes|y|1|\+|\+1)$)`, text) | ||||
| } | ||||
| 
 | ||||
| func IsFalse(text string) bool { | ||||
| 	text = strings.TrimSpace(text) | ||||
| 	return re.Matches(`(?i)(^(false|f|no|n|0|-|-1)$)`, text) | ||||
| } | ||||
|  | ||||
| @ -7,6 +7,7 @@ package endpoints | ||||
| import ( | ||||
| 	"ads/internal/core/logging" | ||||
| 	"ads/internal/setup" | ||||
| 	"ads/internal/setup/cli" | ||||
| ) | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
| @ -24,11 +25,12 @@ func Version() { | ||||
| 
 | ||||
| func Help() { | ||||
| 	logging.SetForce(true) | ||||
| 	cli.ParseCli([]string{}) // <- generiere leere Instanz für Parser, um voll Hilfsanleitug zu zeigen | ||||
| 	logging.LogPlain( | ||||
| 		"", | ||||
| 		setup.Logo(), | ||||
| 		// cli.Parser.Usage(nil), | ||||
| 		setup.Help(), | ||||
| 		// 	setup.Help(), | ||||
| 		cli.Parser.Usage(nil), | ||||
| 		"", | ||||
| 	) | ||||
| } | ||||
|  | ||||
| @ -26,6 +26,13 @@ var optionsQuiet = argparse.Options{ | ||||
| 	Default:  false, | ||||
| } | ||||
| 
 | ||||
| var optionsChecks = argparse.Options{ | ||||
| 	Help:     "Ob vor und nach Ausführung von Algorithmen Checks auf Inputs/Outputs ausgeführt werden sollen.", | ||||
| 	Required: false, | ||||
| 	// NOTE: no `Boolean` option available! | ||||
| 	Default: "false", | ||||
| } | ||||
| 
 | ||||
| var optionsDebug = argparse.Options{ | ||||
| 	Help:     "Blendet die Debugging-Befehle ein.", | ||||
| 	Required: false, | ||||
| @ -33,7 +40,7 @@ var optionsDebug = argparse.Options{ | ||||
| } | ||||
| 
 | ||||
| var optionsColour = argparse.Options{ | ||||
| 	Help:     "Ob Logging färblich angezeigt wird (default=true).", | ||||
| 	Help:     "Ob Logging färblich angezeigt wird.", | ||||
| 	Required: false, | ||||
| 	// NOTE: no `Boolean` option available! | ||||
| 	Default: "true", | ||||
| @ -58,6 +65,7 @@ func ParseCli(args []string) (*types.CliArguments, error) { | ||||
| 		Run:        Parser.NewCommand("run", "Ruft Endpunkt auf, der die Algorithmen laufen lässt."), | ||||
| 		Quiet:      Parser.Flag("q", "quiet", &optionsQuiet), | ||||
| 		Debug:      Parser.Flag("", "debug", &optionsDebug), | ||||
| 		Checks:     Parser.String("", "checks", &optionsChecks), | ||||
| 		Colour:     Parser.String("", "colour", &optionsColour), | ||||
| 		ConfigFile: Parser.String("", "config", &optionsConfigFile), | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										40
									
								
								code/golang/internal/setup/setup_appconfig.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								code/golang/internal/setup/setup_appconfig.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | ||||
| package setup | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * IMPORTS | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| import ( | ||||
| 	"ads/internal/types" | ||||
| 
 | ||||
| 	"gopkg.in/yaml.v3" | ||||
| ) | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * GLOBAL CONSTANTS | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| var AppConfig = types.AppConfig{} | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * METHODS | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| // Extrahiert Inhalte einer YAML Config und parset dies als Struktur | ||||
| func AppConfigInitialise() error { | ||||
| 	contents := AppConfigYaml() | ||||
| 	err := yaml.Unmarshal([]byte(contents), &AppConfig) | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| func AppConfigFancyMode() bool { | ||||
| 	return AppConfig.Options.Display | ||||
| } | ||||
| 
 | ||||
| func AppConfigShowMetrics() bool { | ||||
| 	return AppConfig.Options.Metrics | ||||
| } | ||||
| 
 | ||||
| func AppConfigPerformChecks() bool { | ||||
| 	return AppConfig.Options.Checks | ||||
| } | ||||
| @ -54,3 +54,7 @@ func Logo() string { | ||||
| func Version() string { | ||||
| 	return strings.Trim(ReadAsset("version"), "\n") | ||||
| } | ||||
| 
 | ||||
| func AppConfigYaml() string { | ||||
| 	return strings.Trim(ReadAsset("appconfig"), "\n") | ||||
| } | ||||
|  | ||||
							
								
								
									
										27
									
								
								code/golang/internal/types/types_appconfig.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								code/golang/internal/types/types_appconfig.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | ||||
| package types | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * IMPORTS | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| // | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
|  * YAML SCHEMES | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| type AppConfig struct { | ||||
| 	Info    *AppConfigInfo    `yaml:"info"` | ||||
| 	Options *AppConfigOptions `yaml:"options"` | ||||
| } | ||||
| 
 | ||||
| type AppConfigInfo struct { | ||||
| 	Title       *string `yaml:"title"` | ||||
| 	Description *string `yaml:"description"` | ||||
| } | ||||
| 
 | ||||
| type AppConfigOptions struct { | ||||
| 	Display bool `yaml:"display"` | ||||
| 	Checks  bool `yaml:"checks"` | ||||
| 	Metrics bool `yaml:"metrics"` | ||||
| } | ||||
| @ -5,11 +5,9 @@ package types | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| import ( | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/akamensky/argparse" | ||||
| 
 | ||||
| 	"ads/pkg/re" | ||||
| 	"ads/internal/core/utils" | ||||
| ) | ||||
| 
 | ||||
| /* ---------------------------------------------------------------- * | ||||
| @ -22,6 +20,7 @@ type CliArguments struct { | ||||
| 	Run        *argparse.Command | ||||
| 	Quiet      *bool | ||||
| 	Debug      *bool | ||||
| 	Checks     *string | ||||
| 	Colour     *string | ||||
| 	ConfigFile *string | ||||
| } | ||||
| @ -30,16 +29,22 @@ type CliArguments struct { | ||||
|  * METHODS convert string option to boolean | ||||
|  * ---------------------------------------------------------------- */ | ||||
| 
 | ||||
| func IsTrue(text string) bool { | ||||
| 	text = strings.TrimSpace(text) | ||||
| 	return re.Matches(`(?i)(^(true|t|yes|y|1|\+|\+1)$)`, text) | ||||
| func (arguments CliArguments) QuietModeOn() bool { | ||||
| 	return *arguments.Quiet | ||||
| } | ||||
| 
 | ||||
| func IsFalse(text string) bool { | ||||
| 	text = strings.TrimSpace(text) | ||||
| 	return re.Matches(`(?i)(^(false|f|no|n|0|-|-1)$)`, text) | ||||
| func (arguments CliArguments) DebugModeOn() bool { | ||||
| 	return *arguments.Debug | ||||
| } | ||||
| 
 | ||||
| func (arguments *CliArguments) ShowColour() bool { | ||||
| 	return !IsFalse(*arguments.Colour) | ||||
| func (arguments CliArguments) ShowChecks() bool { | ||||
| 	return !utils.IsFalse(*arguments.Checks) | ||||
| } | ||||
| 
 | ||||
| func (arguments CliArguments) ShowColour() bool { | ||||
| 	return !utils.IsFalse(*arguments.Colour) | ||||
| } | ||||
| 
 | ||||
| func (arguments CliArguments) GetConfigFile() string { | ||||
| 	return *arguments.ConfigFile | ||||
| } | ||||
|  | ||||
| @ -24,6 +24,7 @@ var ( | ||||
| 	//go:embed assets/* | ||||
| 	res    embed.FS | ||||
| 	assets = map[string]string{ | ||||
| 		"appconfig": "assets/config.yml", | ||||
| 		"version":   "assets/VERSION", | ||||
| 		"logo":      "assets/LOGO", | ||||
| 		"help":      "assets/HELP", | ||||
| @ -38,25 +39,34 @@ func main() { | ||||
| 	var err error | ||||
| 	var arguments *types.CliArguments | ||||
| 
 | ||||
| 	// set assets | ||||
| 	// assets festlegen | ||||
| 	setup.Res = res | ||||
| 	setup.Assets = assets | ||||
| 
 | ||||
| 	// parse cli arguments | ||||
| 	// cli arguments parsen | ||||
| 	arguments, err = cli.ParseCli(os.Args) | ||||
| 
 | ||||
| 	// initialise logging options | ||||
| 	// initialisiere basic optionen wie Logging | ||||
| 	if err == nil { | ||||
| 		logging.SetQuietMode(*arguments.Quiet) | ||||
| 		logging.SetDebugMode(*arguments.Debug) | ||||
| 		logging.SetQuietMode(arguments.QuietModeOn()) | ||||
| 		logging.SetDebugMode(arguments.DebugModeOn()) | ||||
| 		logging.SetAnsiMode(arguments.ShowColour()) | ||||
| 	} | ||||
| 
 | ||||
| 	// app config (intern) intialisieren | ||||
| 	if err == nil { | ||||
| 		err = setup.AppConfigInitialise() | ||||
| 	} | ||||
| 
 | ||||
| 	if err == nil { | ||||
| 		setup.AppConfig.Options.Checks = arguments.ShowChecks() | ||||
| 	} | ||||
| 
 | ||||
| 	if err == nil { | ||||
| 		if arguments.Version.Happened() { | ||||
| 			endpoints.Version() | ||||
| 		} else if arguments.Run.Happened() { | ||||
| 			err = endpoints.Run(*arguments.ConfigFile) | ||||
| 			err = endpoints.Run(arguments.GetConfigFile()) | ||||
| 		} else { // } else if arguments.Help.Happened() { | ||||
| 			endpoints.Help() | ||||
| 		} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user