expose more parameters and refactor cl

This commit is contained in:
Green Sky 2023-01-17 15:45:48 +01:00
parent 65c6398369
commit 4ee1a865aa
No known key found for this signature in database
6 changed files with 138 additions and 100 deletions

View File

@ -36,5 +36,12 @@ $ tox_ngc_ft1_tool
-U disable udp -U disable udp
-P proxy_host proxy_port -P proxy_host proxy_port
-p tox_port (bind tox to that port) -p tox_port (bind tox to that port)
FT1:
--ft_ack_per_packet
--ft_init_retry_timeout_after
--ft_sending_resend_without_ack_after
--ft_sending_give_up_after
--ft_packet_window_size
``` ```

@ -1 +1 @@
Subproject commit 5bb4349e27fda14a9e99fe17d6f59de66a00d410 Subproject commit ae9e2729d20ff5134e718a3603459b218aebf077

View File

@ -3,118 +3,133 @@
#include <charconv> #include <charconv>
#include <iostream> #include <iostream>
#include <cassert> #include <cassert>
#include <type_traits>
struct CLParser {
const size_t argc;
const char*const* argv;
size_t& i;
bool error {false};
bool parseFlag(std::string_view arg_sv, bool& flag) {
std::string_view arg0_sv{argv[i]};
if (arg0_sv != arg_sv) {
return false;
}
flag = true;
return true;
}
template<typename FN, typename Arg0, typename ...Args>
static void visit(FN&& fn, Arg0&& arg0, Args&& ...args) {
fn(arg0);
(fn(args),...);
}
template<typename Arg0, typename ...Args>
bool parseParam(std::string_view arg_sv, Arg0& arg0, Args& ...args) {
std::string_view arg0_sv{argv[i]};
if (arg0_sv != arg_sv) {
return false;
}
if (argc < 1+1+sizeof...(args)) {
std::cerr << "ERROR: " << arg_sv << " not enough parameters!\n\n";
error = true;
return true;
}
visit([this](auto& arg) {
if (error) return;
std::string_view argX_sv{argv[++i]};
using T = std::decay_t<decltype(arg)>;
if constexpr (std::is_same_v<T, std::string>) {
arg = argX_sv;
} else if constexpr (std::is_integral_v<T>) {
auto res = std::from_chars(argX_sv.data(), argX_sv.data()+argX_sv.size(), arg);
if (res.ptr != argX_sv.data() + argX_sv.size()) {
std::cerr << "ERROR: invalid parameter!\n\n";
error = true;
//PRINT_HELP_AND_BAIL;
}
} else if constexpr (std::is_same_v<T, float>) {
// HACK: wait for more charconv <.<
std::string tmp_str {argX_sv};
arg = std::stof(tmp_str);
} else {
assert(false && "invalid parameter type");
}
}, arg0, args...);
return true;
}
};
CommandLine::CommandLine(int argc, char** argv) { CommandLine::CommandLine(int argc, char** argv) {
assert(argc > 0); assert(argc > 0);
exe = argv[0]; exe = argv[0];
for (int i = 1; i < argc; i++) { for (size_t i = 1; i < size_t(argc); i++) {
std::string_view arg_sv{argv[i]}; CLParser parser{size_t(argc), argv, i};
std::string_view arg_sv{argv[i]}; // alt
#define PRINT_HELP_AND_BAIL printHelp(); _should_exit = true; return; #define PRINT_HELP_AND_BAIL printHelp(); _should_exit = true; return;
if (arg_sv == "-v") { if (parser.parseFlag("-v", version)) {
version = true;
_should_exit = true; _should_exit = true;
} else if (arg_sv == "-V") { } else if (parser.parseFlag("-V", verbose)) {
verbose = true;
} else if (arg_sv == "-h") { } else if (arg_sv == "-h") {
help = true; help = true;
printHelp(); printHelp();
_should_exit = true; _should_exit = true;
} else if (arg_sv == "-G") { } else if (parser.parseParam("-G", chat_id)) {
if (i+1 >= argc) { } else if (parser.parseParam("-F", profile_path)) {
std::cerr << "ERROR: -G missing <chat_id> parameter!\n\n"; } else if (parser.parseParam("-N", self_name)) {
PRINT_HELP_AND_BAIL; } else if (std::string tv; parser.parseParam("-a", tv)) {
} if (tv == "id1") {
chat_id = argv[++i];
} else if (arg_sv == "-F") {
if (i+1 >= argc) {
std::cerr << "ERROR: -F missing <path> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
profile_path = argv[++i];
} else if (arg_sv == "-N") {
if (i+1 >= argc) {
std::cerr << "ERROR: -N missing <self_name> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
self_name = argv[++i];
} else if (arg_sv == "-a") {
if (i+1 >= argc) {
std::cerr << "ERROR: -a missing <transfer_variant> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
std::string_view tv_sv{argv[++i]};
if (tv_sv == "id1") {
transfer_variant = TransferE::ID; transfer_variant = TransferE::ID;
} else if (tv_sv == "sha1_single") { } else if (tv == "sha1_single") {
transfer_variant = TransferE::SHA1_SINGLE; transfer_variant = TransferE::SHA1_SINGLE;
} else if (tv_sv == "sha1_info") { } else if (tv == "sha1_info") {
transfer_variant = TransferE::SHA1_INFO; transfer_variant = TransferE::SHA1_INFO;
} else { } else {
std::cerr << "ERROR: invalid <transfer_variant> parameter!\n\n"; std::cerr << "ERROR: invalid <transfer_variant> parameter!\n\n";
PRINT_HELP_AND_BAIL; PRINT_HELP_AND_BAIL;
} }
} else if (parser.parseParam("-f", send_path)) {
} else if (arg_sv == "-f") { } else if (parser.parseParam("-d", receive_dump_dir)) {
if (i+1 >= argc) { std::cout << "CL going to write to '" << receive_dump_dir << "'\n";
std::cerr << "ERROR: -f missing <path> parameter!\n\n"; } else if (parser.parseParam("-D", receive_id)) {
PRINT_HELP_AND_BAIL; } else if (parser.parseFlag("-L", tox_disable_local_discovery)) {
} std::cout << "CL disabled local discovery\n";
send_path = argv[++i]; } else if (parser.parseFlag("-U", tox_disable_udp)) {
} else if (arg_sv == "-d") { std::cout << "CL disabled udp\n";
if (i+1 >= argc) { } else if (parser.parseParam("-P", proxy_host, proxy_port)) {
std::cerr << "ERROR: -d missing <path> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
receive_dump_dir = argv[++i];
} else if (arg_sv == "-D") {
if (i+1 >= argc) {
std::cerr << "ERROR: -D missing <id/hash> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
receive_id = argv[++i];
} else if (arg_sv == "-L") {
tox_disable_local_discovery = true;
} else if (arg_sv == "-U") {
tox_disable_udp = true;
} else if (arg_sv == "-P") {
if (i+2 >= argc) {
std::cerr << "ERROR: -P missing <host> and/or <port> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
std::string_view host_sv{argv[++i]};
std::string_view port_sv{argv[++i]};
proxy_host = host_sv;
auto res = std::from_chars(port_sv.data(), port_sv.data()+port_sv.size(), proxy_port);
if (res.ptr != port_sv.data()+port_sv.size()) {
std::cerr << "ERROR: invalid <port>!\n\n";
PRINT_HELP_AND_BAIL;
}
std::cout << "CL set proxy to " << proxy_host << proxy_port << "\n"; std::cout << "CL set proxy to " << proxy_host << proxy_port << "\n";
} else if (arg_sv == "-p") { } else if (parser.parseParam("-p", tox_port)) {
if (i+1 >= argc) {
std::cerr << "ERROR: -p missing <port> parameter!\n\n";
PRINT_HELP_AND_BAIL;
}
std::string_view port_sv{argv[++i]};
auto res = std::from_chars(port_sv.data(), port_sv.data()+port_sv.size(), tox_port);
if (res.ptr != port_sv.data()+port_sv.size()) {
std::cerr << "ERROR: invalid <port>!\n\n";
PRINT_HELP_AND_BAIL;
}
std::cout << "CL set tox_port to " << tox_port << "\n"; std::cout << "CL set tox_port to " << tox_port << "\n";
} else if (parser.parseParam("--ft_ack_per_packet", ft_acks_per_packet)) {
} else if (parser.parseParam("--ft_init_retry_timeout_after", ft_init_retry_timeout_after)) {
} else if (parser.parseParam("--ft_sending_resend_without_ack_after", ft_sending_resend_without_ack_after)) {
} else if (parser.parseParam("--ft_sending_give_up_after", ft_sending_give_up_after)) {
} else if (parser.parseParam("--ft_packet_window_size", ft_packet_window_size)) {
} else { } else {
std::cerr << "ERROR: unknown parameter '" << arg_sv << "' !\n\n"; std::cerr << "ERROR: unknown parameter '" << arg_sv << "' !\n\n";
PRINT_HELP_AND_BAIL; PRINT_HELP_AND_BAIL;
} }
if (parser.error) {
PRINT_HELP_AND_BAIL;
}
} }
if (transfer_variant == TransferE::INVALID) { if (transfer_variant == TransferE::INVALID) {
@ -158,8 +173,12 @@ void CommandLine::printHelp(void) {
<< " -p tox_port (bind tox to that port)\n" << " -p tox_port (bind tox to that port)\n"
<< "\n" << "\n"
<< " FT1:\n" << " FT1:\n"
<< " TODO\n" << " --ft_ack_per_packet\n"
<< "\n" << " --ft_init_retry_timeout_after\n"
<< " --ft_sending_resend_without_ack_after\n"
<< " --ft_sending_give_up_after\n"
<< " --ft_packet_window_size\n"
<< " transfer logic:\n" << " transfer logic:\n"
<< " TODO\n" << " TODO\n"
; ;

View File

@ -55,11 +55,19 @@ struct CommandLine {
// -p port (start and end is set to the same port) // -p port (start and end is set to the same port)
uint16_t tox_port {0}; uint16_t tox_port {0};
// ---- TODO ----
// advanced FT1: // advanced FT1:
// -w packet_window_size // --ft_ack_per_packet
// TODO: all them timeouts size_t ft_acks_per_packet {5};
// --ft_init_retry_timeout_after
float ft_init_retry_timeout_after {10.f};
// --ft_sending_resend_without_ack_after
float ft_sending_resend_without_ack_after {5.f};
// --ft_sending_give_up_after
float ft_sending_give_up_after {30.f};
// --ft_packet_window_size
size_t ft_packet_window_size {5};
// ---- TODO ----
// advaced dl: // advaced dl:
// -I max_incoming_transfers (default 16) // -I max_incoming_transfers (default 16)

View File

@ -5,9 +5,6 @@
#include "./states/send_start_sha1.hpp" #include "./states/send_start_sha1.hpp"
#include "./states/receive_start_sha1.hpp" #include "./states/receive_start_sha1.hpp"
#include "ngc_ft1.h"
#include "tox/tox.h"
#include "toxcore/tox.h"
#include <memory> #include <memory>
#include <sodium.h> #include <sodium.h>
@ -124,6 +121,11 @@ ToxClient::ToxClient(const CommandLine& cl) :
_ext_ctx = NGC_EXT_new(); _ext_ctx = NGC_EXT_new();
NGC_FT1_options ft1_options {}; NGC_FT1_options ft1_options {};
ft1_options.acks_per_packet = 5;
ft1_options.init_retry_timeout_after = 10.f;
ft1_options.sending_resend_without_ack_after = 5.f;
ft1_options.sending_give_up_after = 30.f;
ft1_options.packet_window_size = 10;
_ft1_ctx = NGC_FT1_new(&ft1_options); _ft1_ctx = NGC_FT1_new(&ft1_options);
NGC_FT1_register_ext(_ft1_ctx, _ext_ctx); NGC_FT1_register_ext(_ft1_ctx, _ext_ctx);
@ -195,11 +197,13 @@ ToxClient::~ToxClient(void) {
} }
bool ToxClient::iterate(void) { bool ToxClient::iterate(void) {
tox_iterate(_tox, this);
NGC_FT1_iterate(_tox, _ft1_ctx);
// HACK: hardcoded 5ms sleep in main // HACK: hardcoded 5ms sleep in main
if (_state->iterate(0.005f)) { float time_delta {0.005f};
tox_iterate(_tox, this);
NGC_FT1_iterate(_tox, _ft1_ctx, time_delta);
if (_state->iterate(time_delta)) {
_state = _state->nextState(); _state = _state->nextState();
if (!_state) { if (!_state) {