mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-26 05:15:27 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Luanti
 | |
| // SPDX-License-Identifier: LGPL-2.1-or-later
 | |
| // Copyright (C) 2024 cx384
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <memory>
 | |
| #include <string>
 | |
| #include "irr_v3d.h"
 | |
| #include "scripting_pause_menu.h"
 | |
| 
 | |
| class Client;
 | |
| class RenderingEngine;
 | |
| class InputHandler;
 | |
| class GUIFormSpecMenu;
 | |
| 
 | |
| /*
 | |
| This object intend to contain the core fromspec functionality.
 | |
| It includes:
 | |
|   - methods to show specific formspec menus
 | |
|   - storing the opened fromspec
 | |
|   - handling fromspec related callbacks
 | |
|  */
 | |
| struct GameFormSpec
 | |
| {
 | |
| 	void init(Client *client, RenderingEngine *rendering_engine, InputHandler *input);
 | |
| 
 | |
| 	~GameFormSpec() { reset(); }
 | |
| 
 | |
| 	void showFormSpec(const std::string &formspec, const std::string &formname);
 | |
| 	void showCSMFormSpec(const std::string &formspec, const std::string &formname);
 | |
| 	// Used by the Lua pause menu environment to show formspecs.
 | |
| 	// Currently only used for the in-game settings menu.
 | |
| 	void showPauseMenuFormSpec(const std::string &formspec, const std::string &formname);
 | |
| 	void showNodeFormspec(const std::string &formspec, const v3s16 &nodepos);
 | |
| 	/// If `!fs_override`: Uses `player->inventory_formspec`.
 | |
| 	/// If ` fs_override`: Uses a temporary formspec until an update is received.
 | |
| 	void showPlayerInventory(const std::string *fs_override);
 | |
| 	void showDeathFormspecLegacy();
 | |
| 	// Shows the hardcoded "main" pause menu.
 | |
| 	void showPauseMenu();
 | |
| 
 | |
| 	void update();
 | |
| 	void disableDebugView();
 | |
| 
 | |
| 	bool handleCallbacks();
 | |
| 	void reset();
 | |
| 
 | |
| #ifdef __ANDROID__
 | |
| 	// Returns false if no formspec open
 | |
| 	bool handleAndroidUIInput();
 | |
| #endif
 | |
| 
 | |
| private:
 | |
| 	Client *m_client;
 | |
| 	RenderingEngine *m_rendering_engine;
 | |
| 	InputHandler *m_input;
 | |
| 	std::unique_ptr<PauseMenuScripting> m_pause_script;
 | |
| 
 | |
| 	/// The currently open formspec that is not a submenu of the pause menu
 | |
| 	/// FIXME: Layering is already managed by `GUIModalMenu` (`g_menumgr`), hence this
 | |
| 	/// variable should be removed in long-term.
 | |
| 	GUIFormSpecMenu *m_formspec = nullptr;
 | |
| 
 | |
| 	bool handleEmptyFormspec(const std::string &formspec, const std::string &formname);
 | |
| 
 | |
| 	void deleteFormspec();
 | |
| };
 |