2022-02-23 22:08:50 +01:00
---
2021-04-02 19:42:19 +02:00
-- `openmw.world` is an interface to the game world for global scripts.
-- Can not be used from local scripts.
-- @module world
-- @usage local world = require('openmw.world')
2022-02-23 22:08:50 +01:00
---
2021-04-02 19:42:19 +02:00
-- List of currently active actors.
-- @field [parent=#world] openmw.core#ObjectList activeActors
2023-06-17 19:56:25 +02:00
---
-- List of players. Currently (since multiplayer is not yet implemented) always has one element.
-- @field [parent=#world] openmw.core#ObjectList players
2023-04-01 15:15:28 +02:00
---
-- Functions related to MWScript (see @{#MWScriptFunctions}).
-- @field [parent=#world] #MWScriptFunctions mwscript
---
-- Functions related to MWScript.
-- @type MWScriptFunctions
2023-11-06 21:38:40 +00:00
---
-- @type MWScriptVariables
-- @map <#string, #number>
2023-04-01 15:15:28 +02:00
---
-- Returns local mwscript on ``object``. Returns `nil` if the script doesn't exist or is not started.
-- @function [parent=#MWScriptFunctions] getLocalScript
-- @param openmw.core#GameObject object
-- @param openmw.core#GameObject player (optional) Will be used in multiplayer mode to get the script if there is a separate instance for each player. Currently has no effect.
-- @return #MWScript, #nil
2023-10-24 09:23:25 +00:00
---
-- Returns mutable global variables. In multiplayer, these may be specific to the provided player.
-- @function [parent=#MWScriptFunctions] getGlobalVariables
-- @param openmw.core#GameObject player (optional) Will be used in multiplayer mode to get the globals if there is a separate instance for each player. Currently has no effect.
2023-11-06 21:38:40 +00:00
-- @return #MWScriptVariables
2023-10-24 09:23:25 +00:00
2023-04-01 15:15:28 +02:00
---
-- Returns global mwscript with given recordId. Returns `nil` if the script doesn't exist or is not started.
-- Currently there can be only one instance of each mwscript, but in multiplayer it will be possible to have a separate instance per player.
-- @function [parent=#MWScriptFunctions] getGlobalScript
-- @param #string recordId
-- @param openmw.core#GameObject player (optional) Will be used in multiplayer mode to get the script if there is a separate instance for each player. Currently has no effect.
-- @return #MWScript, #nil
---
-- @type MWScript
-- @field #string recordId Id of the script
-- @field openmw.core#GameObject object The object the script is attached to.
-- @field openmw.core#GameObject player The player the script refers to.
-- @field #MWScriptVariables variables Local variables of the script (mutable)
-- @usage
-- for _, script in ipairs(world.mwscript.getLocalScripts(object)) do
-- -- print the value of local variable 'something' (0 if there is no such variable)
-- print(script.variables.something)
-- -- set the variable 'something' (raises an error if there is no such variable)
-- script.variables.something = 5
-- end
2022-02-23 22:08:50 +01:00
---
2021-04-02 19:42:19 +02:00
-- Loads a named cell
-- @function [parent=#world] getCellByName
-- @param #string cellName
-- @return openmw.core#Cell
2022-02-23 22:08:50 +01:00
---
2021-04-02 19:42:19 +02:00
-- Loads an exterior cell by grid indices
-- @function [parent=#world] getExteriorCell
-- @param #number gridX
-- @param #number gridY
2023-05-13 19:30:18 +02:00
-- @param #any cellOrName (optional) other cell or cell name in the same exterior world space
2021-04-02 19:42:19 +02:00
-- @return openmw.core#Cell
2023-05-13 19:30:18 +02:00
---
-- List of all cells
-- @field [parent=#world] #list<openmw.core#Cell> cells
-- @usage for i, cell in ipairs(world.cells) do print(cell) end
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- Simulation time in seconds.
-- The number of simulation seconds passed in the game world since starting a new game.
2022-06-04 13:28:04 +00:00
-- @function [parent=#world] getSimulationTime
2021-12-01 21:28:05 +01:00
-- @return #number
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- The scale of simulation time relative to real time.
2022-06-04 13:28:04 +00:00
-- @function [parent=#world] getSimulationTimeScale
2021-12-01 21:28:05 +01:00
-- @return #number
2022-07-03 12:51:28 +00:00
---
-- Set the simulation time scale.
-- @function [parent=#world] setSimulationTimeScale
-- @param #number scale
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- Game time in seconds.
2022-06-04 13:28:04 +00:00
-- @function [parent=#world] getGameTime
2021-12-01 21:28:05 +01:00
-- @return #number
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- The scale of game time relative to simulation time.
2022-06-04 13:28:04 +00:00
-- @function [parent=#world] getGameTimeScale
2021-12-01 21:28:05 +01:00
-- @return #number
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- Set the ratio of game time speed to simulation time speed.
-- @function [parent=#world] setGameTimeScale
-- @param #number ratio
2023-12-26 09:15:50 -08:00
---
-- Frame duration in seconds
-- @function [parent=#world] getRealFrameDuration
-- @return #number
2022-02-23 22:08:50 +01:00
---
2021-12-01 21:28:05 +01:00
-- Whether the world is paused (onUpdate doesn't work when the world is paused).
-- @function [parent=#world] isWorldPaused
-- @return #boolean
2021-04-02 19:42:19 +02:00
2023-08-06 16:09:41 +02:00
---
-- Pause the game starting from the next frame.
-- @function [parent=#world] pause
2023-10-04 10:36:54 +02:00
-- @param #string tag (optional, empty string by default) The game will be paused until `unpause` is called with the same tag.
2023-08-06 16:09:41 +02:00
---
-- Remove given tag from the list of pause tags. Resume the game starting from the next frame if the list became empty.
-- @function [parent=#world] unpause
2023-10-04 10:36:54 +02:00
-- @param #string tag (optional, empty string by default) Needed to undo `pause` called with this tag.
2023-08-06 16:09:41 +02:00
---
-- The tags that are currently pausing the game.
-- @function [parent=#world] getPausedTags
-- @return #table
2023-05-30 01:44:09 +02:00
---
-- Return an object by RefNum/FormId.
2023-06-07 22:20:35 +02:00
-- Note: the function always returns @{openmw.core#GameObject} and doesn't validate that
-- the object exists in the game world. If it doesn't exist or not yet loaded to memory),
-- then `obj:isValid()` will be `false`.
2023-05-30 01:44:09 +02:00
-- @function [parent=#world] getObjectByFormId
-- @param #string formId String returned by `core.getFormId`
-- @return openmw.core#GameObject
-- @usage local obj = world.getObjectByFormId(core.getFormId('Morrowind.esm', 128964))
2023-01-16 01:28:21 +01:00
---
-- Create a new instance of the given record.
-- After creation the object is in the disabled state. Use :teleport to place to the world or :moveInto to put it into a container or an inventory.
2023-09-25 21:01:32 +02:00
-- Note that dynamically created creatures, NPCs, and container inventories will not respawn.
2023-01-16 01:28:21 +01:00
-- @function [parent=#world] createObject
-- @param #string recordId Record ID in lowercase
-- @param #number count (optional, 1 by default) The number of objects in stack
-- @return openmw.core#GameObject
-- @usage -- put 100 gold on the ground at the position of `actor`
-- money = world.createObject('gold_001', 100)
-- money:teleport(actor.cell.name, actor.position)
-- @usage -- put 50 gold into the actor's inventory
-- money = world.createObject('gold_001', 50)
-- money:moveInto(types.Actor.inventory(actor))
2023-03-29 07:46:11 +00:00
---
-- Creates a custom record in the world database.
-- Eventually meant to support all records, but the current
-- set of supported types is limited to:
2023-08-18 22:55:43 +02:00
--
2023-05-25 08:00:12 +00:00
-- * @{openmw.types#PotionRecord},
-- * @{openmw.types#ArmorRecord},
-- * @{openmw.types#BookRecord},
-- * @{openmw.types#MiscellaneousRecord},
2023-08-28 21:20:12 -05:00
-- * @{openmw.types#ClothingRecord},
-- * @{openmw.types#WeaponRecord},
2024-05-13 14:14:44 +00:00
-- * @{openmw.types#ActivatorRecord},
-- * @{openmw.types#LightRecord}
2023-03-29 07:46:11 +00:00
-- @function [parent=#world] createRecord
-- @param #any record A record to be registered in the database. Must be one of the supported types.
-- @return #any A new record added to the database. The type is the same as the input's.
2021-04-02 19:42:19 +02:00
return nil