Compare commits
No commits in common. "d3c0fbf8aaa91874faf3d8aa1947d4fd6102401d" and "32be1bc25bb8ed0502de86f5595010373089cc8c" have entirely different histories.
d3c0fbf8aa
...
32be1bc25b
1 changed files with 19 additions and 21 deletions
40
server.c
40
server.c
|
@ -51,7 +51,6 @@ void clear_screen(int client_fd) {
|
||||||
/* Execute a git-slides command */
|
/* Execute a git-slides command */
|
||||||
void execute_git_slides(const char *repo_path, const char *slide_command) {
|
void execute_git_slides(const char *repo_path, const char *slide_command) {
|
||||||
char command[CMD_SIZE];
|
char command[CMD_SIZE];
|
||||||
memset(command, 0, CMD_SIZE);
|
|
||||||
snprintf(command, sizeof(command), "cd %s && git-slides %s", repo_path, slide_command);
|
snprintf(command, sizeof(command), "cd %s && git-slides %s", repo_path, slide_command);
|
||||||
system(command);
|
system(command);
|
||||||
}
|
}
|
||||||
|
@ -74,19 +73,6 @@ void load_slide_content(const char *slides_path, char *output) {
|
||||||
close(fd);
|
close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Clean up client resources */
|
|
||||||
void cleanup_client(struct Client *client) {
|
|
||||||
if (client->fd != -1) {
|
|
||||||
close(client->fd);
|
|
||||||
client->fd = -1;
|
|
||||||
}
|
|
||||||
if (strlen(client->repo_path) > 0) {
|
|
||||||
char rm_command[CMD_SIZE];
|
|
||||||
snprintf(rm_command, sizeof(rm_command), "rm -rf %s", client->repo_path);
|
|
||||||
system(rm_command);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Handle client input and update slides */
|
/* Handle client input and update slides */
|
||||||
void handle_client_input(struct Client *client, char command) {
|
void handle_client_input(struct Client *client, char command) {
|
||||||
if (command == ' ') {
|
if (command == ' ') {
|
||||||
|
@ -95,7 +81,8 @@ void handle_client_input(struct Client *client, char command) {
|
||||||
execute_git_slides(client->repo_path, "prev");
|
execute_git_slides(client->repo_path, "prev");
|
||||||
} else if (command == 'q') {
|
} else if (command == 'q') {
|
||||||
clear_screen(client->fd);
|
clear_screen(client->fd);
|
||||||
cleanup_client(client);
|
close(client->fd);
|
||||||
|
client->fd = -1; /* Mark as disconnected */
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
snprintf(client->current_slide, BUFFER_SIZE, "Unknown command '%c'. Use SPACE, BACKSPACE, or Q.\n", command);
|
snprintf(client->current_slide, BUFFER_SIZE, "Unknown command '%c'. Use SPACE, BACKSPACE, or Q.\n", command);
|
||||||
|
@ -110,10 +97,22 @@ void send_welcome_message(struct Client *client) {
|
||||||
const char *welcome_msg =
|
const char *welcome_msg =
|
||||||
"Welcome to the git-slides presentation!\n"
|
"Welcome to the git-slides presentation!\n"
|
||||||
"Use SPACE (forward), BACKSPACE (back), or Q (quit).\n\n";
|
"Use SPACE (forward), BACKSPACE (back), or Q (quit).\n\n";
|
||||||
write(client->fd, client->current_slide, strlen(client->current_slide));
|
|
||||||
write(client->fd, welcome_msg, strlen(welcome_msg));
|
write(client->fd, welcome_msg, strlen(welcome_msg));
|
||||||
|
write(client->fd, client->current_slide, strlen(client->current_slide));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Clean up client resources */
|
||||||
|
void cleanup_client(struct Client *client) {
|
||||||
|
if (client->fd != -1) {
|
||||||
|
close(client->fd);
|
||||||
|
client->fd = -1;
|
||||||
|
}
|
||||||
|
if (strlen(client->repo_path) > 0) {
|
||||||
|
char rm_command[CMD_SIZE];
|
||||||
|
snprintf(rm_command, sizeof(rm_command), "rm -rf %s", client->repo_path);
|
||||||
|
system(rm_command);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
int server_fd;
|
int server_fd;
|
||||||
|
@ -152,13 +151,13 @@ int main() {
|
||||||
clients[i].fd = -1;
|
clients[i].fd = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fds[0].fd = server_fd;
|
||||||
|
fds[0].events = POLLIN;
|
||||||
|
|
||||||
printf("Server running on port %d\n", PORT);
|
printf("Server running on port %d\n", PORT);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
int num_fds = 1;
|
int num_fds = 1;
|
||||||
fds[0].fd = server_fd;
|
|
||||||
fds[0].events = POLLIN;
|
|
||||||
|
|
||||||
/* Prepare the pollfd array */
|
/* Prepare the pollfd array */
|
||||||
for (i = 0; i < MAX_CLIENTS; i++) {
|
for (i = 0; i < MAX_CLIENTS; i++) {
|
||||||
|
@ -211,17 +210,16 @@ int main() {
|
||||||
load_slide_content(client->slides_path, client->current_slide);
|
load_slide_content(client->slides_path, client->current_slide);
|
||||||
|
|
||||||
send_telnet_negotiation(client_fd);
|
send_telnet_negotiation(client_fd);
|
||||||
|
send_welcome_message(client);
|
||||||
|
|
||||||
printf("Client connected: %d\n", client_fd);
|
printf("Client connected: %d\n", client_fd);
|
||||||
/* Discard any pending input */
|
/* Discard any pending input */
|
||||||
fds[0].fd = client_fd;
|
fds[0].fd = client_fd;
|
||||||
fds[0].events = POLLIN;
|
fds[0].events = POLLIN;
|
||||||
while (poll(fds, 1, 500) > 0) {
|
while (poll(fds, 1, 20) > 0) {
|
||||||
char command;
|
char command;
|
||||||
read(client_fd, &command, 1);
|
read(client_fd, &command, 1);
|
||||||
}
|
}
|
||||||
printf("Go!\n");
|
|
||||||
send_welcome_message(client);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue