summaryrefslogtreecommitdiff
path: root/engine/Dynamic/Manager.go
blob: 4a5f70f7e90941d69ee6ebe5ce3d482df6df24b0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package dynamic

import (
	"fmt"
	"os"

	components "github.com/DegustatorPonos/RuinesOfRafdolon/Components"
	descriptors "github.com/DegustatorPonos/RuinesOfRafdolon/Dynamic/Descriptors"
	settings "github.com/DegustatorPonos/RuinesOfRafdolon/Settings"
	utils "github.com/DegustatorPonos/RuinesOfRafdolon/Utils"
	rl "github.com/gen2brain/raylib-go/raylib"
)

// The collection of all avaliable packages that are loaded in the system
type PackageManager struct {
	AvaliablePackages map[string]Package
}

var Manager *PackageManager = nil

func loadPackages() (*PackageManager, error) {
	var dir, dirErr = os.ReadDir(settings.Current.PackagesLocation)
	if dirErr != nil {
		return nil, dirErr
	}
	var outp = PackageManager{
		AvaliablePackages: make(map[string]Package),
	}
	for _, v := range dir {
		var packagePath = utils.JoinFileLocation(settings.Current.PackagesLocation, v.Name())
		var newPackage, packageErr = ReadPackage(v)
		if packageErr != nil {
			rl.TraceLog(rl.LogWarning, "Failed to load the module %v: %s", packagePath, packageErr.Error())
			continue
		}
		newPackage.location = packagePath

		// Do not change this order - some descriptors rely on other
		newPackage.ReadTextures()
		newPackage.ReadObjects()
		newPackage.ReadWorlds()
		newPackage.ReadMenus()

		outp.AvaliablePackages[newPackage.Description.Name] = *newPackage
		rl.TraceLog(rl.LogInfo, "Loaded the module %s", newPackage.Description.Name)
	}
	return &outp, nil
}

// Loads the packages from the specified in settings directory. Panics on serious error
func ReadPackages() {
	descriptors.InitUIParser()
	var manager, err = loadPackages()
	if err != nil {
		panic(fmt.Sprintf("Failed to load packages: %v", err.Error()))
	}
	Manager = manager
}

func (base *PackageManager) GetPackage(packageName string) (*Package, error) {
	var pack, exists = base.AvaliablePackages[packageName]
	if !exists { 
		return nil, fmt.Errorf("Failed to load package: package %s does not exist", packageName) 
	} 
	return &pack, nil
}

func (base *PackageManager) IsPackageAvaliable(PkgName string) bool {
	var _, exists = base.AvaliablePackages[PkgName]
	return exists
}

func (base *PackageManager) LoadPackage(PkgName string) error {
	var pkg, err = base.GetPackage(PkgName)
	if err != nil {
		return err
	}
	components.Resources.LoadedPackages[pkg.Description.Name] = pkg.Description.Version
	pkg.Load()
	return nil
}