summaryrefslogtreecommitdiff
path: root/src/client/jetc.cpp
diff options
context:
space:
mode:
authorJuan Manuel Tomás <jtomas1815@gmail.com>2020-07-20 01:50:14 -0300
committerJuan Manuel Tomás <jtomas1815@gmail.com>2020-07-20 01:50:14 -0300
commit8693eef8febde4df90b7fbd1fb9ac813b132fa50 (patch)
tree088258d6333d54a6b90f331d3b723ae824110679 /src/client/jetc.cpp
parent7620a0b1c080f7b6315e796d29e324bdca98484b (diff)
downloadjet-8693eef8febde4df90b7fbd1fb9ac813b132fa50.tar.gz
jet-8693eef8febde4df90b7fbd1fb9ac813b132fa50.zip
Wrap external functionality into classes
Diffstat (limited to 'src/client/jetc.cpp')
-rw-r--r--src/client/jetc.cpp59
1 files changed, 6 insertions, 53 deletions
diff --git a/src/client/jetc.cpp b/src/client/jetc.cpp
index 8d31d72..2dd6074 100644
--- a/src/client/jetc.cpp
+++ b/src/client/jetc.cpp
@@ -1,57 +1,22 @@
#include <stdio.h>
#include <string.h>
-#include <cursesw.h>
-
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/ip.h>
-#include <arpa/inet.h>
-#include <unistd.h>
#include <common/ipc.cpp>
+#include <common/socket.cpp>
#include <client/window.cpp>
-#include <client/cursor.cpp>
#define NORMAL_MODE 0
#define INSERT_MODE 1
-#define PORT 6969
int main(int argc, char *argv[]) {
- initscr();
- cbreak();
- noecho();
- intrflush(stdscr, FALSE);
- keypad(stdscr, TRUE);
-
Window window;
- getmaxyx(stdscr, window.height, window.width);
- window.init();
-
- int s = socket(AF_INET, SOCK_STREAM, 0);
- sockaddr_in addr = { AF_INET, htons(PORT), htonl(INADDR_LOOPBACK) };
- connect(s, (sockaddr *) &addr, sizeof(sockaddr_in));
int mode = NORMAL_MODE;
- Cursor cursor = { 0, 0, &window };
int quit = 0;
while (!quit) {
- clear();
+ window.redraw();
- int8_t msg[5];
- msg[0] = OP_SHOW;
- encode2(window.width, msg, 1);
- encode2(window.height, msg, 3);
- write(s, msg, 5);
- read(s, window.view, window.width * window.height);
- for (int i = 0; i < window.width * window.height; i++) {
- printw("%c", window.view[i]);
- }
- move(cursor.y, cursor.x);
-
- int8_t mov[2];
- int8_t del[1];
- int8_t ins[2];
int input = getch();
if (mode == NORMAL_MODE) {
switch (input) {
@@ -62,16 +27,10 @@ int main(int argc, char *argv[]) {
mode = INSERT_MODE;
break;
case 'h':
- mov[0] = OP_MOVE1;
- mov[1] = -1;
- write(s, mov, 2);
- cursor.move_left();
+ window.move_left();
break;
case 'l':
- mov[0] = OP_MOVE1;
- mov[1] = 1;
- write(s, mov, 2);
- cursor.move_right();
+ window.move_right();
break;
}
} else {
@@ -80,19 +39,13 @@ int main(int argc, char *argv[]) {
mode = NORMAL_MODE;
break;
case KEY_BACKSPACE:
- del[0] = OP_DELETE;
- write(s, del, 1);
+ window.delete_element();
break;
default:
- ins[0] = OP_INSERT;
- ins[1] = input;
- write(s, ins, 2);
+ window.insert_element(input);
}
}
}
- close(s);
-
- endwin();
return 0;
}