From 4e889e447ea6d9c73eac293957ce798af0c12509 Mon Sep 17 00:00:00 2001 From: Mike Nolan Date: Fri, 6 Dec 2024 14:50:30 -0600 Subject: [PATCH] tidy up tfileserver --- apps/tfileserver.cpp | 51 +++++++++++++++++++++++++++++++++++++++----- 1 file changed, 46 insertions(+), 5 deletions(-) diff --git a/apps/tfileserver.cpp b/apps/tfileserver.cpp index ae5a5eb..2235c11 100644 --- a/apps/tfileserver.cpp +++ b/apps/tfileserver.cpp @@ -6,16 +6,57 @@ using namespace Tesses::Framework::Streams; using namespace Tesses::Framework::TextStreams; using namespace Tesses::Framework::Threading; +void print_help(const char* name) +{ + printf("Tesses FileServer\nUSAGE: %s [OPTIONS] \n",name); + printf("OPTIONS:\n-p PORT, --port PORT: Change port from 10000\n-l, --listing: Enable listing\n-s, --spa: Enable SPA mode (send \"/\" body instead of not found)\n-h, --help: This Screen\n"); + exit(1); +} int main(int argc, char** argv) { TF_Init(); - if(argc < 2) + + const char* directory = "wwwroot"; + bool spa=false; + bool allowListing = false; + uint16_t port = 10000L; + + for(int i = 1; i < argc; i++) { - printf("USAGE: %s \n",argv[0]); - return 0; + if(strcmp(argv[i],"--help") == 0 || strcmp(argv[i],"-h") == 0) + { + print_help(argv[0]); + } + else if(strcmp(argv[i], "-l") == 0 || strcmp(argv[i], "--listing") == 0) + { + allowListing = true; + } + else if(strcmp(argv[i],"-s") == 0 || strcmp(argv[i],"--spa") == 0) + { + spa=true; + } + else if(strcmp(argv[i],"-p") == 0 || strcmp(argv[i],"--port") == 0) + { + if(i+1>=argc) + { + printf("ERROR: Not enough arguments for PORT\n"); + print_help(argv[0]); + } + else + { + + port = (uint16_t)std::stoul(argv[++i]); + } + } + else + { + directory = argv[i]; + } } - FileServer fs(argv[1],true,false); - HttpServer server(10000U,fs); + + + FileServer fs(directory,allowListing, spa); + HttpServer server(port,fs); server.StartAccepting(); TF_RunEventLoop(); std::cout << "Closing server" << std::endl;