X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fmain.c;h=a3e8647d10740e00c149574ad50f6f46b3b30970;hb=52d7763743e415b0a374a9845a7d9a67b9f8e321;hp=d6ec65bc64fb4f542cfcd51724ed07408204c074;hpb=2ba6401e39bcfaaccaa45e6b7ef780a7a15b0c48;p=oftp diff --git a/src/main.c b/src/main.c index d6ec65b..a3e8647 100644 --- a/src/main.c +++ b/src/main.c @@ -1,19 +1,41 @@ +#include +#include +#include +#include +#include +#include #include "tgfx.h" #include "input.h" +#include "util.h" #include "tui.h" #include "ftp.h" -struct ftp *ftp; -struct tui_widget *uilist; +void updateui(void); +int proc_input(void); +int keypress(int key); +int parse_args(int argc, char **argv); -int main(void) +static struct ftp *ftp; +static struct tui_widget *uilist; + +static char *host = "localhost"; +static int port = 21; + +int main(int argc, char **argv) { - union event ev; + int i, numsock, maxfd; + int ftpsock[16]; + fd_set rdset; + struct timeval tv; + + if(parse_args(argc, argv) == -1) { + return 1; + } if(!(ftp = ftp_alloc())) { return 1; } - if(ftp_connect(ftp, "192.168.0.4", 21) == -1) { + if(ftp_connect(ftp, host, port) == -1) { ftp_free(ftp); return 1; } @@ -26,31 +48,198 @@ int main(void) tg_clear(); uilist = tui_list("Remote", 0, 0, 40, 23, 0, 0); - tui_add_list_item(uilist, "first item"); - tui_add_list_item(uilist, "second item"); - tui_add_list_item(uilist, "another item"); - tui_add_list_item(uilist, "foo"); - tg_setcursor(0, 24); + tg_setcursor(0, 23); tui_draw(uilist); - while(wait_input(&ev)) { + for(;;) { + FD_ZERO(&rdset); + maxfd = 0; + + numsock = ftp_sockets(ftp, ftpsock, sizeof ftpsock); + for(i=0; i maxfd) maxfd = ftpsock[i]; + } + +#ifdef __unix__ + FD_SET(0, &rdset); + tv.tv_sec = 120; + tv.tv_usec = 0; +#else + tv.tv_sec = tv.tv_usec = 0; +#endif + + if(select(maxfd + 1, &rdset, 0, 0, &tv) == -1 && errno == EINTR) { + continue; + } + +#ifdef __unix__ + if(FD_ISSET(0, &rdset)) { + if(proc_input() == -1) { + break; + } + } +#endif + + for(i=0; imodified & FTP_MOD_REMDIR) { + tui_clear_list(uilist); + + num = ftp_num_dirent(ftp, FTP_REMOTE); + for(i=0; itype == FTP_DIR) { + sprintf(buf, "%s/", ent->name); + tui_add_list_item(uilist, buf); + } else { + tui_add_list_item(uilist, ent->name); + } + } + + tui_list_select(uilist, 0); + + ftp->modified &= ~FTP_MOD_REMDIR; + upd |= 1; + } + + if(tui_isdirty(uilist) || upd & 1) { + tui_draw(uilist); + } +} + +int proc_input(void) +{ + union event ev; + + while(poll_input(&ev)) { switch(ev.type) { case EV_KEY: - if(ev.key.key == 27) goto done; + if(keypress(ev.key.key) == -1) { + return -1; + } break; default: break; } } + return 0; +} -done: - tg_cleanup(); +int keypress(int key) +{ + int sel; + const char *name; - cleanup_input(); + switch(key) { + case 27: + case 'q': + return -1; + + case KB_UP: + tui_list_sel_prev(uilist); + break; + case KB_DOWN: + tui_list_sel_next(uilist); + break; + case KB_LEFT: + tui_list_sel_start(uilist); + break; + case KB_RIGHT: + tui_list_sel_end(uilist); + break; + + case '\n': + sel = tui_get_list_sel(uilist); + name = ftp_dirent(ftp, FTP_REMOTE, sel)->name; + ftp_queue(ftp, FTP_CHDIR, name); + break; + + case '\b': + ftp_queue(ftp, FTP_CDUP, 0); + break; + + default: + break; + } + return 0; +} + +static const char *usage = "Usage: %s [options] [hostname] [port]\n" + "Options:\n" + " -h: print usage information and exit\n"; + +int parse_args(int argc, char **argv) +{ + int i, argidx = 0; + + for(i=1; i