Now have a working config manager that can exist in the world properly.
This commit is contained in:
		
							parent
							
								
									f6ddf4b03b
								
							
						
					
					
						commit
						ddf1ba955c
					
				
					 5 changed files with 46 additions and 6 deletions
				
			
		
							
								
								
									
										18
									
								
								assets/config.json
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								assets/config.json
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,18 @@ | ||||||
|  | { | ||||||
|  |   "map": { | ||||||
|  |     "WALL_TILE": "█", | ||||||
|  |     "FLOOR_TILE": "\u2849", | ||||||
|  |     "PLAYER_TILE": "♣", | ||||||
|  |     "ENEMY_TILE": "Ω", | ||||||
|  |     "BG_TILE": "█" | ||||||
|  |   }, | ||||||
|  |   "enemies": { | ||||||
|  | 
 | ||||||
|  |   }, | ||||||
|  |   "player": { | ||||||
|  | 
 | ||||||
|  |   }, | ||||||
|  |   "type": { | ||||||
|  |     "TEST": 1234 | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										3
									
								
								main.cpp
									
										
									
									
									
								
							
							
						
						
									
										3
									
								
								main.cpp
									
										
									
									
									
								
							|  | @ -54,6 +54,9 @@ void configure_world(DinkyECS::World &world, Map &game_map) { | ||||||
| int main() { | int main() { | ||||||
|   DinkyECS::World world; |   DinkyECS::World world; | ||||||
| 
 | 
 | ||||||
|  |   Config config("./assets/config.json"); | ||||||
|  |   world.set_the<Config>(config); | ||||||
|  | 
 | ||||||
|   Map game_map(GAME_MAP_X, GAME_MAP_Y); |   Map game_map(GAME_MAP_X, GAME_MAP_Y); | ||||||
|   game_map.generate(); |   game_map.generate(); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -44,6 +44,7 @@ roguish = executable('roguish', [ | ||||||
|   'systems.cpp', |   'systems.cpp', | ||||||
|   'ansi_parser.cpp', |   'ansi_parser.cpp', | ||||||
|   'render.cpp', |   'render.cpp', | ||||||
|  |   'config.cpp', | ||||||
|   ], |   ], | ||||||
|   dependencies: dependencies) |   dependencies: dependencies) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -12,7 +12,6 @@ | ||||||
| #include <ftxui/screen/screen.hpp>      // for Full, Screen
 | #include <ftxui/screen/screen.hpp>      // for Full, Screen
 | ||||||
| #include <ftxui/screen/terminal.hpp>  // for ColorSupport, Color, Palette16, Palette256, TrueColor
 | #include <ftxui/screen/terminal.hpp>  // for ColorSupport, Color, Palette16, Palette256, TrueColor
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| using namespace fmt; | using namespace fmt; | ||||||
| using namespace ftxui; | using namespace ftxui; | ||||||
| 
 | 
 | ||||||
|  | @ -56,12 +55,12 @@ TEST_CASE("test out ragel parser", "[gui]") { | ||||||
|   sf::Color default_bg(100,100,100); |   sf::Color default_bg(100,100,100); | ||||||
| 
 | 
 | ||||||
|   // this sets the Truecolor so need to do it first
 |   // this sets the Truecolor so need to do it first
 | ||||||
|   ANSIParser parser(default_fg, default_bg); |   ANSIParser ansi(default_fg, default_bg); | ||||||
|   std::string colors = generate_colors(); |   std::string colors = generate_colors(); | ||||||
|   std::cout << colors; |   std::cout << colors; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   bool good = parser.parse(colors, [&](sf::Color bgcolor, sf::Color color, wchar_t ch) { |   bool good = ansi.parse(colors, [&](sf::Color bgcolor, sf::Color color, wchar_t ch) { | ||||||
|       bool correct_char = ch == '#' || ch == ' ' || ch == '\n' || ch == '\r'; |       bool correct_char = ch == '#' || ch == ' ' || ch == '\n' || ch == '\r'; | ||||||
|       REQUIRE(correct_char); |       REQUIRE(correct_char); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  | @ -33,11 +33,30 @@ TEST_CASE("basic configuration system", "[config]") { | ||||||
|   REQUIRE(test_obj["name"] == "Zed"); |   REQUIRE(test_obj["name"] == "Zed"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void test_func(Config &ref) { | void test_can_ref(Config &ref) { | ||||||
|   REQUIRE(ref["types"]["OBJECT"]["name"] == "Zed"); |   REQUIRE(ref["types"]["OBJECT"]["name"] == "Zed"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| TEST_CASE("store config in any", "[config]") { | TEST_CASE("can get references of config", "[config]") { | ||||||
|   Config config("./tests/config.json"); |   Config config("./tests/config.json"); | ||||||
|   test_func(config); |   test_can_ref(config); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | TEST_CASE("store config in any", "[config]") { | ||||||
|  |   auto as_any = std::make_any<Config>("./tests/config.json"); | ||||||
|  | 
 | ||||||
|  |   Config &cfg = std::any_cast<Config &>(as_any); | ||||||
|  |   REQUIRE(cfg["types"]["NUMBER"] == 1234); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void test_will_live(DinkyECS::World &world) { | ||||||
|  |   Config config("./tests/config.json"); | ||||||
|  |   world.set_the<Config>(config); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | TEST_CASE("can go into a world", "[config]") { | ||||||
|  |   DinkyECS::World world; | ||||||
|  |   test_will_live(world); | ||||||
|  |   Config &cfg = world.get_the<Config>(); | ||||||
|  |   REQUIRE(cfg["types"]["NUMBER"] == 1234); | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw