configs

package
v0.8.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 26, 2024 License: GPL-3.0 Imports: 0 Imported by: 0

Documentation

Overview

Package for ORM access to freelancer game configs data.

configs_mapped allows directly accesing config files for reading in a type safe way and writing values back code is easily extendable without need to write explicit code for reading/writing to files, everything is done by universal custom ini reader

configs_export for type safer data export that has a lot of data already combined from configs for easy usage. See examples folder for how to use library.

This library is used in projects fl-darklint and fl-darkstat.

Checking stuff.

Example (ExportingData)

ExampleExportingData demonstrating exporting freelancer folder data for comfortable usage

/*
Such code is primiarily used for fl-darkstat. You could check its code for more examples
https://github.com/darklab8/fl-darkstat
*/
package main

import (
	"fmt"
	"os"

	"github.com/darklab8/fl-configs/configs/configs_export"
	"github.com/darklab8/fl-configs/configs/configs_mapped"
	"github.com/darklab8/fl-configs/configs/settings/logus"
	"github.com/darklab8/go-utils/goutils/utils/utils_logus"
	"github.com/darklab8/go-utils/goutils/utils/utils_types"
)

var FreelancerFolder utils_types.FilePath = utils_types.FilePath(os.Getenv("CONFIGS_FREELANCER_FOLDER"))

// ExampleExportingData demonstrating exporting freelancer folder data for comfortable usage
func main() {
	configs := configs_mapped.NewMappedConfigs()
	logus.Log.Debug("scanning freelancer folder", utils_logus.FilePath(FreelancerFolder))

	// Reading to ini universal custom format and mapping to ORM objects
	// which have both reading and writing back capabilities
	configs.Read(FreelancerFolder)

	// For elegantly exporting enriched data objects with better type safety for just reading access
	exports := configs_export.NewExporter(configs)

	bases := exports.Bases(configs_export.NoNameIncluded(false))
	for _, base := range bases {
		// do smth with exported bases
		fmt.Println(base.Name)
		fmt.Println(base.Infocard)
		fmt.Println(base.System)
		fmt.Println(base.SystemNickname)
		fmt.Printf("%d\n", base.InfocardID)
		break
	}
}
Output:

Example (ModifyingConfigs)

ExampleModifyingData demononstrating how to change configs values

/*
Such code is primiarily used for fl-darklint. You could check its code for more examples
https://github.com/darklab8/fl-darklint
*/
package main

import (
	"os"
	"strings"

	"github.com/darklab8/fl-configs/configs/configs_mapped"
	"github.com/darklab8/fl-configs/configs/settings/logus"
	"github.com/darklab8/go-utils/goutils/utils/utils_logus"
	"github.com/darklab8/go-utils/goutils/utils/utils_types"
)

var Freelancerfolder utils_types.FilePath = utils_types.FilePath(os.Getenv("CONFIGS_FREELANCER_FOLDER"))

// ExampleModifyingData demononstrating how to change configs values
func main() {
	configs := configs_mapped.NewMappedConfigs()
	logus.Log.Debug("scanning freelancer folder", utils_logus.FilePath(Freelancerfolder))

	// Reading ini reading universal format
	// and mapping to ORM objects
	configs.Read(FreelancerFolder)

	// Modifying files
	for _, base := range configs.Universe_config.Bases {
		base.Nickname.Set(strings.ToLower(base.Nickname.Get()))
		base.System.Set(strings.ToLower(base.System.Get()))
		base.File.Set(strings.ToLower(base.File.Get()))
	}

	for _, system := range configs.Universe_config.Systems {
		system.Nickname.Set(strings.ToLower(system.Nickname.Get()))
		system.Msg_id_prefix.Set(strings.ToLower(system.Msg_id_prefix.Get()))

		if system.File.Get() != "" {
			system.File.Set(strings.ToLower(system.File.Get()))
		}
	}

	// Write without Dry Run for writing to files modified values back!
	configs.Write(configs_mapped.IsDruRun(true))
}
Output:

Directories

Path Synopsis
Tool to parse freelancer configs
Tool to parse freelancer configs
freelancer_mapped/data_mapped
This package is equal to DATA folder present in Freelancer Discovery.
This package is equal to DATA folder present in Freelancer Discovery.
parse universe.ini
freelancer_mapped/exe_mapped/go-binary-pack
Package binary_pack performs conversions between some Go values represented as byte slices.
Package binary_pack performs conversions between some Go values represented as byte slices.
parserutils/filefind
Package with reusable code for discovery of files and other reusable stuff like universal ini reader
Package with reusable code for discovery of files and other reusable stuff like universal ini reader
parserutils/inireader
Okay we need to create syntax.
Okay we need to create syntax.
parserutils/semantic
ORM mapper for Freelancer ini reader.
ORM mapper for Freelancer ini reader.
settings

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL