--- The Core module loads some helper functions useful in all stages -- of a mods life cycle. All modules have an __index method into core. -- @module Core -- @usage local Core = require('stdlib/core') --Global mutates require('stdlib/utils/globals') require('stdlib/utils/table') require('stdlib/utils/string') require('stdlib/utils/math') --Defines Mutates require('stdlib/defines/color') require('stdlib/defines/time') local Is = require('stdlib/utils/is') local Core = { _VERSION = '1.0.0', _DESCRIPTION = 'Factorio Lua Standard Library Project', _URL = 'https://github.com/Afforess/Factorio-Stdlib', _LICENSE = [[ MIT LICENSE Copyright (c) 2016, Afforess Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ]], _module_name = 'Core', _concat = function(lhs, rhs) --Sanitize to remove address return tostring(lhs):gsub('(%w+)%: %x+', '%1: (ADDR)') .. tostring(rhs):gsub('(%w+)%: %x+', '%1: (ADDR)') end, _classes = { string_array_mt = require('stdlib/utils/classes/string_array') } } function Core.log_and_print(msg) if game and #game.connected_players > 0 then log(msg) game.print(msg) return true end end function Core.VALID_FILTER(v) return v and v.valid end --- Sets the __call metamethod on the metatable. -- @tparam table this The object to get the metatable for -- @tparam function caller The function to set to __call -- @treturn table with metatable attached function Core.set_caller(this, caller) if getmetatable(this) then getmetatable(this).__call = caller return this else error('Metatable not found', 2) end end --- load the stdlib into globals, by default it loads everything into an ALLCAPS name. -- Alternatively you can pass a dictionary of `[global names] -> [require path]`. -- @tparam[opt] table files -- @treturn Core -- @usage -- require('stdlib/core).create_stdlib_globals() function Core.create_stdlib_globals(files) files = files or { GAME = 'stdlib/game', AREA = 'stdlib/area/area', POSITION = 'stdlib/area/position', TILE = 'stdlib/area/tile', SURFACE = 'stdlib/area/surface', CHUNK = 'stdlib/area/chunk', COLOR = 'stdlib/color/color', ENTITY = 'stdlib/entity/entity', INVENTORY = 'stdlib/entity/inventory', RESOURCE = 'stdlib/entity/resource', CONFIG = 'stdlib/config/config', LOGGER = 'stdlib/log/logger', QUEUE = 'stdlib/queue/queue', EVENT = 'stdlib/event/event', GUI = 'stdlib/event/gui', PLAYER = 'stdlib/event/player', FORCE = 'stdlib/event/force' } Is.Assert.Table(files, 'files must be a dictionary of global names -> file paths') for glob, path in pairs(files) do _G[glob] = prequire((path:gsub('%.', '/'))) -- extra () required to emulate select(1) end return Core end return Core