Started working on better error handling, by throwing exceptions and displaying error messages in the GUI
This commit is contained in:
@@ -1,38 +1,32 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include "includes/easysock.hpp"
|
#include "includes/easysock.h"
|
||||||
#include "includes/connect_code.hpp"
|
#include "includes/connect_code.hpp"
|
||||||
#include "includes/server.hpp"
|
#include "includes/server.hpp"
|
||||||
#include "includes/client.hpp"
|
#include "includes/client.hpp"
|
||||||
#include "includes/check_input.hpp"
|
#include "includes/check_input.hpp"
|
||||||
#include "includes/raygui/raygui.h"
|
#include "includes/raygui/raygui.h"
|
||||||
#include "includes/exception_consts.hpp"
|
#include "includes/exception_consts.hpp"
|
||||||
|
#include "includes/raygui_helpers.hpp"
|
||||||
#include "includes/timer.h"
|
#include "includes/timer.h"
|
||||||
|
|
||||||
/* Display the given text, centered on the screen, as a label */
|
|
||||||
void display_text_centered(std::string to_disp) {
|
|
||||||
const char* to_disp_cstr = to_disp.c_str();
|
|
||||||
Vector2 label_size = MeasureTextEx(GetFontDefault(), to_disp_cstr, GuiGetStyle(DEFAULT, TEXT_SIZE)+1, GuiGetStyle(DEFAULT, TEXT_SPACING)+1); // The '+1' is there to account for any rounding errors
|
|
||||||
|
|
||||||
BeginDrawing();
|
|
||||||
ClearBackground(BLACK);
|
|
||||||
GuiLabel(Rectangle{(GetScreenWidth()/2) - (label_size.x/2), (GetScreenHeight()/2) - (label_size.y/2), label_size.x, label_size.y}, to_disp_cstr);
|
|
||||||
EndDrawing();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
GameType check_server(char* ip_text, char* port_text) {
|
GameType check_server(char* ip_text, char* port_text) {
|
||||||
GameType type;
|
GameType type;
|
||||||
std::string addr;
|
std::string addr;
|
||||||
uint16_t port;
|
uint16_t port;
|
||||||
|
|
||||||
|
/* Check if IP address and port are in valid forms */
|
||||||
|
if (check_ip_ver(ip_text) < 0) {
|
||||||
|
throw std::invalid_argument("Invalid IP address");
|
||||||
|
}
|
||||||
|
if (port_to_num(port_text) < 0) {
|
||||||
|
throw std::invalid_argument("Invalid port");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* From here on, we assume that the IP and port are valid */
|
||||||
|
|
||||||
addr = std::string(ip_text);
|
addr = std::string(ip_text);
|
||||||
port = std::stoi(std::string(port_text));
|
port = std::stoi(std::string(port_text));
|
||||||
|
|
||||||
/* Check if IP is valid */
|
|
||||||
if (check_ip_ver(addr.data()) < 0) {
|
|
||||||
throw EXCEPT_INVALIDIP;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string code = connect_code::encode(addr, std::to_string(port));
|
std::string code = connect_code::encode(addr, std::to_string(port));
|
||||||
|
|
||||||
/* Create server socket and wait for client to connect */
|
/* Create server socket and wait for client to connect */
|
||||||
|
17
main.cpp
17
main.cpp
@@ -26,11 +26,12 @@
|
|||||||
#include "includes/paddle.hpp"
|
#include "includes/paddle.hpp"
|
||||||
#include "includes/ball.hpp"
|
#include "includes/ball.hpp"
|
||||||
#include "includes/connect_code.hpp"
|
#include "includes/connect_code.hpp"
|
||||||
#include "includes/easysock.hpp"
|
|
||||||
#include "includes/client.hpp"
|
#include "includes/client.hpp"
|
||||||
#include "includes/server.hpp"
|
#include "includes/server.hpp"
|
||||||
#include "includes/exception_consts.hpp"
|
#include "includes/exception_consts.hpp"
|
||||||
#include "includes/check_input.hpp"
|
#include "includes/check_input.hpp"
|
||||||
|
#include "includes/raygui_helpers.hpp"
|
||||||
|
#include "includes/easysock.h"
|
||||||
#include "includes/serialization.h"
|
#include "includes/serialization.h"
|
||||||
#include "includes/timer.h"
|
#include "includes/timer.h"
|
||||||
|
|
||||||
@@ -272,7 +273,7 @@ int main(int argc, char** argv) {
|
|||||||
/* Server mode, ask user to input IP address and port */
|
/* Server mode, ask user to input IP address and port */
|
||||||
if (selected_item == M_SERVER) {
|
if (selected_item == M_SERVER) {
|
||||||
button_pressed = false; // Whether submit button is pressed
|
button_pressed = false; // Whether submit button is pressed
|
||||||
char* ip_text = (char *)calloc(100, sizeof(char)); // Holds input of IP text box
|
char* ip_text = (char *)calloc(150, sizeof(char)); // Holds input of IP text box
|
||||||
char* port_text = (char *)calloc(20, sizeof(char)); // Holds input of port text box
|
char* port_text = (char *)calloc(20, sizeof(char)); // Holds input of port text box
|
||||||
const char* ip_label = "Local IP address";
|
const char* ip_label = "Local IP address";
|
||||||
const char* port_label = "Port number (1024 - 65535)";
|
const char* port_label = "Port number (1024 - 65535)";
|
||||||
@@ -303,14 +304,22 @@ int main(int argc, char** argv) {
|
|||||||
EndDrawing();
|
EndDrawing();
|
||||||
}
|
}
|
||||||
|
|
||||||
type = check_server(ip_text, port_text);
|
try {
|
||||||
|
type = check_server(ip_text, port_text);
|
||||||
|
} catch (std::invalid_argument& inv) {
|
||||||
|
display_text_centered(std::string(inv.what()) + "\nClosing game...");
|
||||||
|
Timer timer = timer_init(2); // Wait for two seconds
|
||||||
|
while (!timer_done(timer));
|
||||||
|
CloseWindow(); // Close and exit
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
free(ip_text);
|
free(ip_text);
|
||||||
free(port_text);
|
free(port_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (selected_item == M_CLIENT) {
|
if (selected_item == M_CLIENT) {
|
||||||
button_pressed = false; // Whether submit button is pressed
|
button_pressed = false; // Whether submit button is pressed
|
||||||
char* code_text = (char *)calloc(100, sizeof(char)); // Holds the connect code
|
char* code_text = (char *)calloc(150, sizeof(char)); // Holds the connect code
|
||||||
const char* code_label = "Enter code:";
|
const char* code_label = "Enter code:";
|
||||||
bool editing_code = false; // Indicates whether the port text box is being edited
|
bool editing_code = false; // Indicates whether the port text box is being edited
|
||||||
while (button_pressed == false || ((strlen(code_text) == 0))) {
|
while (button_pressed == false || ((strlen(code_text) == 0))) {
|
||||||
|
Reference in New Issue
Block a user