2021-12-13 23:39:01 +00:00
|
|
|
---
|
|
|
|
-- `openmw.storage` contains functions to work with permanent Lua storage.
|
|
|
|
-- @module storage
|
|
|
|
-- @usage
|
|
|
|
-- local storage = require('openmw.storage')
|
|
|
|
-- local myModData = storage.globalSection('MyModExample')
|
|
|
|
-- myModData:set("someVariable", 1.0)
|
|
|
|
-- myModData:set("anotherVariable", { exampleStr='abc', exampleBool=true })
|
2022-04-23 13:37:08 +00:00
|
|
|
-- local async = require('openmw.async')
|
|
|
|
-- myModData:subscribe(async:callback(function(section, key)
|
|
|
|
-- if key then
|
|
|
|
-- print('Value is changed:', key, '=', myModData:get(key))
|
|
|
|
-- else
|
|
|
|
-- print('All values are changed')
|
2021-12-13 23:39:01 +00:00
|
|
|
-- end
|
2022-04-23 13:37:08 +00:00
|
|
|
-- end))
|
2021-12-13 23:39:01 +00:00
|
|
|
|
2024-02-24 11:57:11 +00:00
|
|
|
--- Possible @{#LifeTime} values
|
|
|
|
-- @field [parent=#storage] #LifeTime LIFE_TIME
|
|
|
|
|
|
|
|
--- `storage.LIFE_TIME`
|
|
|
|
-- @type LifeTime
|
|
|
|
-- @field #number Persistent "0" Data is stored for the whole game session and remains on disk after quitting the game
|
|
|
|
-- @field #number GameSession "1" Data is stored for the whole game session
|
|
|
|
-- @field #number Temporary "2" Data is stored until script context reset
|
|
|
|
|
2021-12-13 23:39:01 +00:00
|
|
|
---
|
|
|
|
-- Get a section of the global storage; can be used by any script, but only global scripts can change values.
|
2024-01-09 20:25:26 +00:00
|
|
|
-- Menu scripts can only access it when a game is running.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- Creates the section if it doesn't exist.
|
|
|
|
-- @function [parent=#storage] globalSection
|
|
|
|
-- @param #string sectionName
|
|
|
|
-- @return #StorageSection
|
|
|
|
|
|
|
|
---
|
2024-01-09 20:25:26 +00:00
|
|
|
-- Get a section of the player storage; can only be used by player and menu scripts.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- Creates the section if it doesn't exist.
|
|
|
|
-- @function [parent=#storage] playerSection
|
|
|
|
-- @param #string sectionName
|
|
|
|
-- @return #StorageSection
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Get all global sections as a table; can be used by global scripts only.
|
|
|
|
-- Note that adding/removing items to the returned table doesn't create or remove sections.
|
|
|
|
-- @function [parent=#storage] allGlobalSections
|
|
|
|
-- @return #table
|
|
|
|
|
|
|
|
---
|
2024-01-09 20:25:26 +00:00
|
|
|
-- Get all player sections as a table; can only be used by player and menu scripts.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- Note that adding/removing items to the returned table doesn't create or remove sections.
|
|
|
|
-- @function [parent=#storage] allPlayerSections
|
|
|
|
-- @return #table
|
|
|
|
|
|
|
|
---
|
|
|
|
-- A map `key -> value` that represents a storage section.
|
|
|
|
-- @type StorageSection
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Get value by a string key; if value is a table makes it readonly.
|
|
|
|
-- @function [parent=#StorageSection] get
|
|
|
|
-- @param self
|
|
|
|
-- @param #string key
|
2023-01-30 10:13:26 +00:00
|
|
|
-- @return #any
|
2021-12-13 23:39:01 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
-- Get value by a string key; if value is a table returns a copy.
|
|
|
|
-- @function [parent=#StorageSection] getCopy
|
|
|
|
-- @param self
|
|
|
|
-- @param #string key
|
2023-01-30 10:13:26 +00:00
|
|
|
-- @return #any
|
2021-12-13 23:39:01 +00:00
|
|
|
|
|
|
|
---
|
2022-04-23 13:37:08 +00:00
|
|
|
-- Subscribe to changes in this section.
|
|
|
|
-- First argument of the callback is the name of the section (so one callback can be used for different sections).
|
|
|
|
-- The second argument is the changed key (or `nil` if `reset` was used and all values were changed at the same time)
|
|
|
|
-- @function [parent=#StorageSection] subscribe
|
2021-12-13 23:39:01 +00:00
|
|
|
-- @param self
|
2022-04-23 13:37:08 +00:00
|
|
|
-- @param openmw.async#Callback callback
|
2021-12-13 23:39:01 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
-- Copy all values and return them as a table.
|
|
|
|
-- @function [parent=#StorageSection] asTable
|
|
|
|
-- @param self
|
|
|
|
-- @return #table
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Remove all existing values and assign values from given (the arg is optional) table.
|
2022-04-23 13:37:08 +00:00
|
|
|
-- This function can not be used for a global storage section from a local script.
|
|
|
|
-- Note: `section:reset()` removes the section.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- @function [parent=#StorageSection] reset
|
|
|
|
-- @param self
|
|
|
|
-- @param #table values (optional) New values
|
|
|
|
|
|
|
|
---
|
2024-02-24 11:57:11 +00:00
|
|
|
-- (DEPRECATED, use `setLifeTime(openmw.storage.LIFE_TIME.Temporary)`) Make the whole section temporary: will be removed on exit or when load a save.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- Temporary sections have the same interface to get/set values, the only difference is they will not
|
|
|
|
-- be saved to the permanent storage on exit.
|
2024-02-24 11:57:11 +00:00
|
|
|
-- This function can be used for a global storage section from a global script or for a player storage section from a player or menu script.
|
2021-12-13 23:39:01 +00:00
|
|
|
-- @function [parent=#StorageSection] removeOnExit
|
|
|
|
-- @param self
|
2024-02-24 11:57:11 +00:00
|
|
|
-- @usage
|
|
|
|
-- local storage = require('openmw.storage')
|
|
|
|
-- local myModData = storage.globalSection('MyModExample')
|
|
|
|
-- myModData:removeOnExit()
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Set the life time of given storage section.
|
|
|
|
-- New sections initially have a Persistent life time.
|
|
|
|
-- This function can be used for a global storage section from a global script or for a player storage section from a player or menu script.
|
|
|
|
-- @function [parent=#StorageSection] setLifeTime
|
|
|
|
-- @param self
|
|
|
|
-- @param #LifeTime lifeTime Section life time
|
|
|
|
-- @usage
|
|
|
|
-- local storage = require('openmw.storage')
|
|
|
|
-- local myModData = storage.globalSection('MyModExample')
|
|
|
|
-- myModData:setLifeTime(storage.LIFE_TIME.Temporary)
|
2021-12-13 23:39:01 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
-- Set value by a string key; can not be used for global storage from a local script.
|
|
|
|
-- @function [parent=#StorageSection] set
|
|
|
|
-- @param self
|
|
|
|
-- @param #string key
|
|
|
|
-- @param #any value
|
|
|
|
|
|
|
|
return nil
|