expose more parameters and refactor cl
This commit is contained in:
parent
65c6398369
commit
4ee1a865aa
@ -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
|
||||||
```
|
```
|
||||||
|
|
||||||
|
2
external/tox_ngc_ft1/tox_ngc_ft1
vendored
2
external/tox_ngc_ft1/tox_ngc_ft1
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 5bb4349e27fda14a9e99fe17d6f59de66a00d410
|
Subproject commit ae9e2729d20ff5134e718a3603459b218aebf077
|
@ -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"
|
||||||
;
|
;
|
||||||
|
@ -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)
|
||||||
|
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user