Moved the main event loop out of GUI so it's not so tightly coupled to everything else.
This commit is contained in:
		
							parent
							
								
									c0ad0c8d23
								
							
						
					
					
						commit
						5ae24d9b0a
					
				
					 4 changed files with 22 additions and 23 deletions
				
			
		|  | @ -6,9 +6,17 @@ int main(int argc, char *argv[]) | ||||||
| { | { | ||||||
|   GUI gui; |   GUI gui; | ||||||
|   GameEngine game{100}; |   GameEngine game{100}; | ||||||
| 
 |   auto backend = SFMLBackend(game); | ||||||
|   auto builder = Builder(gui, game); |   auto builder = Builder(gui, game); | ||||||
|     gui.main_loop(game, builder); |  | ||||||
| 
 | 
 | ||||||
|  |   backend.startup(); | ||||||
|  | 
 | ||||||
|  |   while(backend.is_open()) { | ||||||
|  |     builder.event(BuildEvent::GO); | ||||||
|  |     gui.main_loop(backend); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   builder.event(BuildEvent::QUIT); | ||||||
|  |   backend.shutdown(); | ||||||
|   return 1; |   return 1; | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										14
									
								
								gui.cpp
									
										
									
									
									
								
							
							
						
						
									
										14
									
								
								gui.cpp
									
										
									
									
									
								
							|  | @ -31,24 +31,12 @@ void GUI::output(const string msg) { | ||||||
|   _lines.push_back(msg); |   _lines.push_back(msg); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int GUI::main_loop(GameEngine &game, Builder &builder) { | void GUI::main_loop(SFMLBackend &gui) { | ||||||
|   auto gui = SFMLBackend(game); |  | ||||||
| 
 |  | ||||||
|   gui.startup(); |  | ||||||
| 
 |  | ||||||
|   while(gui.is_open()) { |  | ||||||
|     builder.event(BuildEvent::GO); |  | ||||||
|   gui.handle_events(); |   gui.handle_events(); | ||||||
|   gui.update_entities(); |   gui.update_entities(); | ||||||
|   gui.update_log(_lines); |   gui.update_log(_lines); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|   builder.event(BuildEvent::QUIT); |  | ||||||
| 
 |  | ||||||
|   gui.shutdown(); |  | ||||||
|   return EXIT_SUCCESS; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void GUI::build_works() { | void GUI::build_works() { | ||||||
|   building_sound.stop(); |   building_sound.stop(); | ||||||
|   build_works_sound.play(); |   build_works_sound.play(); | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								gui.hpp
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								gui.hpp
									
										
									
									
									
								
							|  | @ -20,12 +20,12 @@ class GUI { | ||||||
| 
 | 
 | ||||||
|   GUI(); |   GUI(); | ||||||
| 
 | 
 | ||||||
|   // FOUND BUG: adding this found that I was accidentally copying the gui, really it shouldn't be copyable
 |   // prevent copy
 | ||||||
|   GUI(GUI &g) = delete; |   GUI(GUI &g) = delete; | ||||||
| 
 | 
 | ||||||
|   void output(const string msg); |   void output(const string msg); | ||||||
| 
 | 
 | ||||||
|   int main_loop(GameEngine &game, Builder &builder); |   void main_loop(SFMLBackend &backend); | ||||||
| 
 | 
 | ||||||
|   void build_works(); |   void build_works(); | ||||||
|   void build_failed(bool play_sound, const string &command); |   void build_failed(bool play_sound, const string &command); | ||||||
|  |  | ||||||
|  | @ -47,6 +47,9 @@ class SFMLBackend { | ||||||
| public: | public: | ||||||
|   SFMLBackend(GameEngine &g); |   SFMLBackend(GameEngine &g); | ||||||
| 
 | 
 | ||||||
|  |   // prevent copy
 | ||||||
|  |   SFMLBackend(SFMLBackend &g) = delete; | ||||||
|  | 
 | ||||||
|   void startup(); |   void startup(); | ||||||
| 
 | 
 | ||||||
|   bool is_open(); |   bool is_open(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw