mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-12 02:48:28 -04:00
a3e2e156e7
Uusally problems evidence themsleves with stdin not working correctly - for example, "git add -p" skipping through all queries as if the user was just pressing enter.
108 lines
2.0 KiB
C++
108 lines
2.0 KiB
C++
#include <errno.h>
|
|
#include <fcntl.h>
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <signal.h>
|
|
|
|
#include <AP_HAL/AP_HAL.h>
|
|
|
|
#include "ConsoleDevice.h"
|
|
|
|
#include <AP_Vehicle/AP_Vehicle_Type.h>
|
|
|
|
ConsoleDevice::ConsoleDevice()
|
|
{
|
|
}
|
|
|
|
ConsoleDevice::~ConsoleDevice()
|
|
{
|
|
close();
|
|
}
|
|
|
|
bool ConsoleDevice::close()
|
|
{
|
|
_closed = true;
|
|
|
|
return true;
|
|
}
|
|
|
|
bool ConsoleDevice::open()
|
|
{
|
|
#if APM_BUILD_TYPE(APM_BUILD_Replay) || APM_BUILD_TYPE(APM_BUILD_UNKNOWN)
|
|
// we do not want a ConsoleDevice for Replay or any examples. It
|
|
// screws up the terminal settings and creates all sorts of
|
|
// weirdnesses in Replay's output.
|
|
return false;
|
|
#endif
|
|
|
|
_rd_fd = STDIN_FILENO;
|
|
_wr_fd = STDOUT_FILENO;
|
|
|
|
_closed = false;
|
|
|
|
if (!_set_signal_handlers()) {
|
|
close();
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool ConsoleDevice::_set_signal_handlers(void) const
|
|
{
|
|
struct sigaction sa {};
|
|
sigemptyset(&sa.sa_mask);
|
|
sa.sa_handler = SIG_IGN;
|
|
|
|
return (sigaction(SIGTTIN, &sa, nullptr) == 0);
|
|
|
|
}
|
|
|
|
ssize_t ConsoleDevice::read(uint8_t *buf, uint16_t n)
|
|
{
|
|
if (_closed) {
|
|
return -EAGAIN;
|
|
}
|
|
|
|
return ::read(_rd_fd, buf, n);
|
|
}
|
|
|
|
ssize_t ConsoleDevice::write(const uint8_t *buf, uint16_t n)
|
|
{
|
|
if (_closed) {
|
|
return -EAGAIN;
|
|
}
|
|
|
|
return ::write(_wr_fd, buf, n);
|
|
}
|
|
|
|
void ConsoleDevice::set_blocking(bool blocking)
|
|
{
|
|
int rd_flags;
|
|
int wr_flags;
|
|
|
|
rd_flags = fcntl(_rd_fd, F_GETFL, 0);
|
|
wr_flags = fcntl(_wr_fd, F_GETFL, 0);
|
|
|
|
if (blocking) {
|
|
rd_flags = rd_flags & ~O_NONBLOCK;
|
|
wr_flags = wr_flags & ~O_NONBLOCK;
|
|
} else {
|
|
rd_flags = rd_flags | O_NONBLOCK;
|
|
wr_flags = wr_flags | O_NONBLOCK;
|
|
}
|
|
|
|
if (fcntl(_rd_fd, F_SETFL, rd_flags) < 0) {
|
|
::fprintf(stderr, "Failed to set Console nonblocking %s\n", strerror(errno));
|
|
}
|
|
|
|
if (fcntl(_wr_fd, F_SETFL, wr_flags) < 0) {
|
|
::fprintf(stderr, "Failed to set Console nonblocking %s\n",strerror(errno));
|
|
}
|
|
|
|
}
|
|
|
|
void ConsoleDevice::set_speed(uint32_t baudrate)
|
|
{
|
|
}
|