5
0
mirror of https://github.com/ArduPilot/ardupilot synced 2025-01-18 22:58:32 -04:00
ardupilot/libraries/Desktop/support/main.cpp

85 lines
1.6 KiB
C++
Raw Normal View History

#include <stdio.h>
2011-10-09 06:41:03 -03:00
#include <unistd.h>
#include <time.h>
#include <sys/time.h>
#include <sched.h>
#include <wiring.h>
#include <getopt.h>
#include <signal.h>
#include <string.h>
2011-10-29 22:40:54 -03:00
#include "desktop.h"
void setup(void);
void loop(void);
// the state of the desktop simulation
struct desktop_info desktop_state;
static void usage(void)
{
printf("Options:\n");
printf("\t-s enable CLI slider switch\n");
printf("\t-w wipe eeprom and dataflash\n");
printf("\t-r RATE set SITL framerate\n");
printf("\t-H HEIGHT initial barometric height\n");
}
int main(int argc, char * const argv[])
{
int opt;
// default state
desktop_state.slider = false;
gettimeofday(&desktop_state.sketch_start_time, NULL);
while ((opt = getopt(argc, argv, "swhr:H:")) != -1) {
switch (opt) {
case 's':
desktop_state.slider = true;
break;
case 'w':
unlink("eeprom.bin");
unlink("dataflash.bin");
break;
case 'r':
desktop_state.framerate = (unsigned)atoi(optarg);
break;
case 'H':
desktop_state.initial_height = atof(optarg);
break;
default:
usage();
exit(1);
}
}
if (strcmp(SKETCH, "ArduCopter") == 0) {
desktop_state.quadcopter = true;
if (desktop_state.framerate == 0) {
desktop_state.framerate = 200;
}
} else {
if (desktop_state.framerate == 0) {
desktop_state.framerate = 50;
}
}
sitl_setup();
setup();
2011-10-09 06:41:03 -03:00
while (true) {
struct timeval tv;
2011-10-29 22:40:54 -03:00
fd_set fds;
int fd_high = 0;
FD_ZERO(&fds);
2011-10-09 06:41:03 -03:00
loop();
2011-10-29 22:40:54 -03:00
desktop_serial_select_setup(&fds, &fd_high);
tv.tv_sec = 0;
tv.tv_usec = 100;
select(fd_high+1, &fds, NULL, NULL, &tv);
2011-10-09 06:41:03 -03:00
}
return 0;
}