big-refactor #106
11 changed files with 137 additions and 105 deletions
3
.vscode/settings.json
vendored
3
.vscode/settings.json
vendored
|
@ -6,6 +6,7 @@
|
||||||
"game",
|
"game",
|
||||||
"core",
|
"core",
|
||||||
"scenes",
|
"scenes",
|
||||||
"utils"
|
"utils",
|
||||||
|
"birb"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,9 @@
|
||||||
|
|
||||||
function love.update(dt)
|
function love.update(dt)
|
||||||
core:update(dt)
|
core:update(dt)
|
||||||
|
if (game ~= nil) then
|
||||||
|
game:update(dt)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function love.draw()
|
function love.draw()
|
||||||
|
|
|
@ -23,8 +23,7 @@
|
||||||
|
|
||||||
local DebugSystem = Object:extend()
|
local DebugSystem = Object:extend()
|
||||||
|
|
||||||
local cwd = (...):gsub('%.debug$', '') .. "."
|
local lovebird = require "birb.libs.lovebird"
|
||||||
local lovebird = require(cwd .. "libs.lovebird")
|
|
||||||
|
|
||||||
function DebugSystem:new(controller, active)
|
function DebugSystem:new(controller, active)
|
||||||
self.controller = controller
|
self.controller = controller
|
111
sonic-radiance.love/birb/core/init.lua
Normal file
111
sonic-radiance.love/birb/core/init.lua
Normal file
|
@ -0,0 +1,111 @@
|
||||||
|
-- core/init.lua :: The main file of the core system, an object full of subsystem
|
||||||
|
-- loaded by the game to handle the main functions (like screen, translation,
|
||||||
|
-- inputs…)
|
||||||
|
|
||||||
|
--[[
|
||||||
|
Copyright © 2019 Kazhnuz
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
]]
|
||||||
|
|
||||||
|
local cwd = (...):gsub('%.init$', '') .. "."
|
||||||
|
|
||||||
|
local CoreSystem = Object:extend()
|
||||||
|
|
||||||
|
local DebugSystem = require(cwd .. "debug")
|
||||||
|
|
||||||
|
local Options = require(cwd .. "options")
|
||||||
|
local Input = require(cwd .. "input")
|
||||||
|
local Screen = require(cwd .. "screen")
|
||||||
|
local Lang = require(cwd .. "lang")
|
||||||
|
local SceneManager = require(cwd .. "scenemanager")
|
||||||
|
|
||||||
|
-- INIT FUNCTIONS
|
||||||
|
-- Initialize and configure the core object
|
||||||
|
|
||||||
|
function CoreSystem:new(isDebug)
|
||||||
|
self.debug = DebugSystem(self, isDebug)
|
||||||
|
self.options = Options(self)
|
||||||
|
self.input = Input(self)
|
||||||
|
self.screen = Screen(self)
|
||||||
|
self.scenemanager = SceneManager(self)
|
||||||
|
self.lang = Lang(self)
|
||||||
|
end
|
||||||
|
|
||||||
|
function CoreSystem:registerGameSystem(gamesystem)
|
||||||
|
self.game = gamesystem
|
||||||
|
end
|
||||||
|
|
||||||
|
-- MOUSE FUNCTIONS
|
||||||
|
-- get directly the mouse when needed
|
||||||
|
|
||||||
|
function CoreSystem:mousemoved(x, y, dx, dy)
|
||||||
|
local x, y = self.screen:project(x, y)
|
||||||
|
local dx, dy = self.screen:project(dx, dy)
|
||||||
|
self.scenemanager:mousemoved(x, y, dx, dy)
|
||||||
|
end
|
||||||
|
|
||||||
|
function CoreSystem:mousepressed( x, y, button, istouch )
|
||||||
|
local x, y = self.screen:project(x, y)
|
||||||
|
self.scenemanager:mousepressed( x, y, button, istouch )
|
||||||
|
end
|
||||||
|
|
||||||
|
-- KEYBOARD FUNCTIONS
|
||||||
|
-- get directly the keyboard when needed
|
||||||
|
|
||||||
|
function CoreSystem:keypressed( key, scancode, isrepeat )
|
||||||
|
self.scenemanager:keypressed( key, scancode, isrepeat )
|
||||||
|
end
|
||||||
|
|
||||||
|
function CoreSystem:keyreleased( key )
|
||||||
|
self.scenemanager:keyreleased( key )
|
||||||
|
end
|
||||||
|
|
||||||
|
-- UPDATE FUNCTIONS
|
||||||
|
-- Load every sytem every update functions of the scene and objects
|
||||||
|
|
||||||
|
function CoreSystem:update(dt)
|
||||||
|
-- If the frameskip is to high, prefer slowdown to frameskip
|
||||||
|
local dt = math.min(dt, 1/15)
|
||||||
|
self.debug:update(dt)
|
||||||
|
self.input:update(dt)
|
||||||
|
|
||||||
|
if (self.game ~= nil) then
|
||||||
|
self.game:update(dt)
|
||||||
|
end
|
||||||
|
|
||||||
|
self.scenemanager:update(dt)
|
||||||
|
self.screen:update(dt)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- DRAW FUNCTIONS
|
||||||
|
-- Draw the whole game
|
||||||
|
|
||||||
|
function CoreSystem:draw()
|
||||||
|
self.scenemanager:draw()
|
||||||
|
end
|
||||||
|
|
||||||
|
-- EXIT FUNCTIONS
|
||||||
|
-- Quit the game
|
||||||
|
|
||||||
|
function CoreSystem:exit()
|
||||||
|
self.options:save()
|
||||||
|
love.event.quit()
|
||||||
|
end
|
||||||
|
|
||||||
|
return CoreSystem
|
|
@ -24,8 +24,7 @@
|
||||||
|
|
||||||
local OptionsManager = Object:extend()
|
local OptionsManager = Object:extend()
|
||||||
|
|
||||||
local cwd = (...):gsub('%.options$', '') .. "."
|
local binser = require("birb.libs.binser")
|
||||||
local binser = require(cwd .. "libs.binser")
|
|
||||||
|
|
||||||
local TRANSLATION_PATH = "datas/languages/"
|
local TRANSLATION_PATH = "datas/languages/"
|
||||||
|
|
|
@ -24,8 +24,7 @@
|
||||||
|
|
||||||
local ScreenManager = Object:extend()
|
local ScreenManager = Object:extend()
|
||||||
|
|
||||||
local cwd = (...):gsub('%.screen$', '') .. "."
|
local CScreen = require("birb.libs.cscreen")
|
||||||
local CScreen = require(cwd .. "libs.cscreen")
|
|
||||||
|
|
||||||
-- INIT FUNCTIONS
|
-- INIT FUNCTIONS
|
||||||
-- Initialize and configure the screen manager
|
-- Initialize and configure the screen manager
|
|
@ -1,9 +1,7 @@
|
||||||
-- core/init.lua :: The main file of the core system, an object full of subsystem
|
-- birb :: The main birb script, loading the core and main utilities
|
||||||
-- loaded by the game to handle the main functions (like screen, translation,
|
|
||||||
-- inputs…)
|
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
Copyright © 2019 Kazhnuz
|
Copyright © 2021 Kazhnuz
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
@ -23,98 +21,31 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local cwd = (...):gsub('%.init$', '') .. "."
|
birb = {}
|
||||||
|
|
||||||
-- GLOBAL UTILS/FUNCTION LOADING
|
-- GLOBAL UTILS/FUNCTION LOADING
|
||||||
-- Load in the global namespace utilities that'll need to be reusable everywhere
|
-- Load in the global namespace utilities that'll need to be reusable everywhere
|
||||||
-- in the game
|
-- in the game
|
||||||
|
|
||||||
Object = require(cwd .. "libs.classic")
|
Object = require("birb.libs.classic")
|
||||||
utils = require(cwd .. "utils")
|
utils = require("birb.utils")
|
||||||
|
|
||||||
local CoreSystem = Object:extend()
|
birb.Core = require("birb.core")
|
||||||
|
|
||||||
local DebugSystem = require(cwd .. "debug")
|
function birb.start(gamemodule, isDebug)
|
||||||
|
birb.startCore((isDebug == true))
|
||||||
local Options = require(cwd .. "options")
|
if (gamemodule ~= nil) then
|
||||||
local Input = require(cwd .. "input")
|
birb.startGame(gamemodule)
|
||||||
local Screen = require(cwd .. "screen")
|
|
||||||
local Lang = require(cwd .. "lang")
|
|
||||||
local SceneManager = require(cwd .. "scenemanager")
|
|
||||||
|
|
||||||
require(cwd .. "callbacks")
|
|
||||||
|
|
||||||
-- INIT FUNCTIONS
|
|
||||||
-- Initialize and configure the core object
|
|
||||||
|
|
||||||
function CoreSystem:new(DEBUGMODE)
|
|
||||||
self.debug = DebugSystem(self, DEBUGMODE)
|
|
||||||
self.options = Options(self)
|
|
||||||
self.input = Input(self)
|
|
||||||
self.screen = Screen(self)
|
|
||||||
self.scenemanager = SceneManager(self)
|
|
||||||
self.lang = Lang(self)
|
|
||||||
end
|
|
||||||
|
|
||||||
function CoreSystem:registerGameSystem(gamesystem)
|
|
||||||
self.game = gamesystem
|
|
||||||
end
|
|
||||||
|
|
||||||
-- MOUSE FUNCTIONS
|
|
||||||
-- get directly the mouse when needed
|
|
||||||
|
|
||||||
function CoreSystem:mousemoved(x, y, dx, dy)
|
|
||||||
local x, y = self.screen:project(x, y)
|
|
||||||
local dx, dy = self.screen:project(dx, dy)
|
|
||||||
self.scenemanager:mousemoved(x, y, dx, dy)
|
|
||||||
end
|
|
||||||
|
|
||||||
function CoreSystem:mousepressed( x, y, button, istouch )
|
|
||||||
local x, y = self.screen:project(x, y)
|
|
||||||
self.scenemanager:mousepressed( x, y, button, istouch )
|
|
||||||
end
|
|
||||||
|
|
||||||
-- KEYBOARD FUNCTIONS
|
|
||||||
-- get directly the keyboard when needed
|
|
||||||
|
|
||||||
function CoreSystem:keypressed( key, scancode, isrepeat )
|
|
||||||
self.scenemanager:keypressed( key, scancode, isrepeat )
|
|
||||||
end
|
|
||||||
|
|
||||||
function CoreSystem:keyreleased( key )
|
|
||||||
self.scenemanager:keyreleased( key )
|
|
||||||
end
|
|
||||||
|
|
||||||
-- UPDATE FUNCTIONS
|
|
||||||
-- Load every sytem every update functions of the scene and objects
|
|
||||||
|
|
||||||
function CoreSystem:update(dt)
|
|
||||||
-- If the frameskip is to high, prefer slowdown to frameskip
|
|
||||||
local dt = math.min(dt, 1/15)
|
|
||||||
self.debug:update(dt)
|
|
||||||
self.input:update(dt)
|
|
||||||
|
|
||||||
if (self.game ~= nil) then
|
|
||||||
self.game:update(dt)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
self.scenemanager:update(dt)
|
|
||||||
self.screen:update(dt)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- DRAW FUNCTIONS
|
function birb.startCore(isDebug)
|
||||||
-- Draw the whole game
|
core = birb.Core(isDebug)
|
||||||
|
|
||||||
function CoreSystem:draw()
|
|
||||||
self.scenemanager:draw()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- EXIT FUNCTIONS
|
function birb.startGame(gamemodule)
|
||||||
-- Quit the game
|
local GameObject = require(gamemodule)
|
||||||
|
game = GameObject()
|
||||||
function CoreSystem:exit()
|
|
||||||
self.options:save()
|
|
||||||
love.event.quit()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return CoreSystem
|
require("birb.callbacks")
|
|
@ -21,22 +21,11 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Core = require "birb"
|
require "birb"
|
||||||
local Game = require "game"
|
|
||||||
|
|
||||||
scenes = require "scenes"
|
scenes = require "scenes"
|
||||||
|
|
||||||
function love.load()
|
function love.load()
|
||||||
core = Core(true)
|
birb.start("game", false)
|
||||||
game = Game()
|
|
||||||
scenes.title()
|
scenes.title()
|
||||||
end
|
end
|
||||||
|
|
||||||
function love.update(dt)
|
|
||||||
core:update(dt)
|
|
||||||
game:update(dt)
|
|
||||||
end
|
|
||||||
|
|
||||||
function love.draw()
|
|
||||||
core:draw()
|
|
||||||
end
|
|
Loading…
Reference in a new issue