mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AP_HAL_SITL: implement and use set_cmdline_parameters()
This commit is contained in:
parent
1c80b04544
commit
5b356953ff
@ -14,6 +14,7 @@
|
|||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#include <netinet/udp.h>
|
#include <netinet/udp.h>
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include <AP_Baro/AP_Baro.h>
|
#include <AP_Baro/AP_Baro.h>
|
||||||
#include <AP_InertialSensor/AP_InertialSensor.h>
|
#include <AP_InertialSensor/AP_InertialSensor.h>
|
||||||
@ -105,6 +106,7 @@ public:
|
|||||||
"tcp:5",
|
"tcp:5",
|
||||||
"tcp:6",
|
"tcp:6",
|
||||||
};
|
};
|
||||||
|
std::vector<struct AP_Param::defaults_table_struct> cmdline_param;
|
||||||
|
|
||||||
/* parse a home location string */
|
/* parse a home location string */
|
||||||
static bool parse_home(const char *home_str,
|
static bool parse_home(const char *home_str,
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "UARTDriver.h"
|
#include "UARTDriver.h"
|
||||||
#include <AP_HAL/utility/getopt_cpp.h>
|
#include <AP_HAL/utility/getopt_cpp.h>
|
||||||
#include <AP_Logger/AP_Logger_SITL.h>
|
#include <AP_Logger/AP_Logger_SITL.h>
|
||||||
|
#include <AP_Param/AP_Param.h>
|
||||||
|
|
||||||
#include <SITL/SIM_Multicopter.h>
|
#include <SITL/SIM_Multicopter.h>
|
||||||
#include <SITL/SIM_Helicopter.h>
|
#include <SITL/SIM_Helicopter.h>
|
||||||
@ -201,6 +202,7 @@ void SITL_State::_parse_command_line(int argc, char * const argv[])
|
|||||||
uint16_t simulator_port_in = SIM_IN_PORT;
|
uint16_t simulator_port_in = SIM_IN_PORT;
|
||||||
uint16_t simulator_port_out = SIM_OUT_PORT;
|
uint16_t simulator_port_out = SIM_OUT_PORT;
|
||||||
_irlock_port = IRLOCK_PORT;
|
_irlock_port = IRLOCK_PORT;
|
||||||
|
struct AP_Param::defaults_table_struct temp_cmdline_param{};
|
||||||
|
|
||||||
// Set default start time to the real system time.
|
// Set default start time to the real system time.
|
||||||
// This will be overwritten if argument provided.
|
// This will be overwritten if argument provided.
|
||||||
@ -280,7 +282,6 @@ void SITL_State::_parse_command_line(int argc, char * const argv[])
|
|||||||
|
|
||||||
GetOptLong gopt(argc, argv, "hwus:r:CI:P:SO:M:F:c:",
|
GetOptLong gopt(argc, argv, "hwus:r:CI:P:SO:M:F:c:",
|
||||||
options);
|
options);
|
||||||
|
|
||||||
while ((opt = gopt.getoption()) != -1) {
|
while ((opt = gopt.getoption()) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'w':
|
case 'w':
|
||||||
@ -292,9 +293,9 @@ void SITL_State::_parse_command_line(int argc, char * const argv[])
|
|||||||
break;
|
break;
|
||||||
case 's':
|
case 's':
|
||||||
speedup = strtof(gopt.optarg, nullptr);
|
speedup = strtof(gopt.optarg, nullptr);
|
||||||
char speedup_string[18];
|
temp_cmdline_param = {"SIM_SPEEDUP", speedup};
|
||||||
snprintf(speedup_string, sizeof(speedup_string), "SIM_SPEEDUP=%s", gopt.optarg);
|
cmdline_param.push_back(temp_cmdline_param);
|
||||||
_set_param_default(speedup_string);
|
printf("Setting SIM_SPEEDUP=%f\n", speedup);
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
_framerate = (unsigned)atoi(gopt.optarg);
|
_framerate = (unsigned)atoi(gopt.optarg);
|
||||||
@ -394,9 +395,9 @@ void SITL_State::_parse_command_line(int argc, char * const argv[])
|
|||||||
fprintf(stderr, "You must specify a SYSID greater than 0 and less than 256\n");
|
fprintf(stderr, "You must specify a SYSID greater than 0 and less than 256\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
char sysid_string[18];
|
temp_cmdline_param = {"SYSID_THISMAV", static_cast<float>(sysid)};
|
||||||
snprintf(sysid_string, sizeof(sysid_string), "SYSID_THISMAV=%s", gopt.optarg);
|
cmdline_param.push_back(temp_cmdline_param);
|
||||||
_set_param_default(sysid_string);
|
printf("Setting SYSID_THISMAV=%d\n", sysid);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <AP_Param/AP_Param.h>
|
||||||
|
|
||||||
#ifdef WITH_SITL_TONEALARM
|
#ifdef WITH_SITL_TONEALARM
|
||||||
HALSITL::ToneAlarm_SF HALSITL::Util::_toneAlarm;
|
HALSITL::ToneAlarm_SF HALSITL::Util::_toneAlarm;
|
||||||
@ -138,3 +139,10 @@ enum AP_HAL::Util::safety_state HALSITL::Util::safety_switch_state(void)
|
|||||||
}
|
}
|
||||||
return sitl->safety_switch_state();
|
return sitl->safety_switch_state();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HALSITL::Util::set_cmdline_parameters()
|
||||||
|
{
|
||||||
|
for (auto param: sitlState->cmdline_param) {
|
||||||
|
AP_Param::set_default_by_name(param.name, param.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -68,6 +68,7 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void set_cmdline_parameters() override;
|
||||||
private:
|
private:
|
||||||
SITL_State *sitlState;
|
SITL_State *sitlState;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user