Package Manager
Updated for version 4.0.
To understand how some functions work here read about AddFilesModule
BeardLibPackageManager class
Used to be called CustomPackageManager.
Access it using BeardLib.Managers.Package
Variables
custom_packages
A table containing custom packages. Each table has a key being the the Idstring key of the ID and table value containing dir
for directory, config
for the package data, and id
for raw ID
unload_on_restart
A table containing packages to unload after a restart. Each value in it just containing the config of the package to unload
EXT_CONVERT
A table with keys of file names that should be converted into their in-game counterparts. Example, dds is "texture" "bik" is "movie" etc
UNIT_SHORTCUTS
The table that holds the unit shortcuts. Each key being the meta of the shortcut and the value containing a table with data of what should be loaded. Inside each table you have types of files that should be loaded. Writing just {} will load by default unit, object, and model. Writing any type like "type=true" will load that type. If you need to load multiple files of the same type you write "type={"_thq"}" with the values inside being suffixes to the path
TEXTURE_SHORTCUTS
Like UNIT_SHORTCUTS
this holds shortcuts but shortcuts only for textures. Each table of a meta key holds suffixes. Example: "df_nm_cc = {"_df", "_nm", "_df_cc"}" loads path_df.texture, path_nm.texture, and path_df_cc.texture
Functions
Get
RegisterPackage(String id, String directory, Table config)
Boolean
Registers a package to be loaded using PackageManager:load
or BeardLib.Managers.Package:Load
. id
is the ID (think of the "path" for normal package), directory
the directory for the assets. Usually ModPath + "/assets" or "/Assets" the files inside the game will have the path after the defined directory, config
is the package config. Almost identical to AddFilesModule. And yes, this means that the config uses _meta values to know what file type is each table. It is recommended to use PackageModule to add custom packages
LoadPackage(String id)
Boolean
Loads a custom package. id
is the id of the package
UnloadPackage(String id)
Boolean
Unloads a custom package
PackageLoaded(String id)
Boolean
Returns a boolean determining if the package is loaded
HasPackage(String id)
Boolean
Returns a boolean if the custom package was registered
Other
LoadPackageConfig(String directory, Table config, Boolean temp)
The function that goes through config
and loads all files defined there. Pretty much to understand how it works you need to understand how AddFilesModule works. directory
is the directory of the assets and temp
will unload the files on restart
AddFileWithCheck(Idstring ext, Idstring path, String file)
Adds a file but checks if the file exists first. Calls self:Err
if the file was not found (In AddFilesModule it will call the error on the module class not BeardLib in general) That error shows up in developer mode's errors dialog
Err(...)
Calls BeardLib:Err
UnloadPackageConfig(Table config)
Called by :UnloadPackage
and unloads the files of config
Unload()
Unloads packages that unload on restart. Called by a PostHook in Setup:unload_packages
Last updated