Ardupilot2/libraries/AP_Arming/AP_Arming.h
Gustavo Jose de Sousa 597562c69c AP_Arming: standardize inclusion of libaries headers
This commit changes the way libraries headers are included in source files:

 - If the header is in the same directory the source belongs to, so the
 notation '#include ""' is used with the path relative to the directory
 containing the source.

 - If the header is outside the directory containing the source, then we use
 the notation '#include <>' with the path relative to libraries folder.

Some of the advantages of such approach:

 - Only one search path for libraries headers.

 - OSs like Windows may have a better lookup time.
2015-08-11 16:28:42 +10:00

115 lines
3.4 KiB
C++

/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
#ifndef __AP_ARMING_H__
#define __AP_ARMING_H__
#include <AP_AHRS/AP_AHRS.h>
#include <AP_HAL/AP_HAL.h>
#include <AP_Param/AP_Param.h>
#include <GCS_MAVLink/GCS_MAVLink.h>
class AP_Arming {
public:
enum ArmingChecks {
ARMING_CHECK_NONE = 0x0000,
ARMING_CHECK_ALL = 0x0001,
ARMING_CHECK_BARO = 0x0002,
ARMING_CHECK_COMPASS = 0x0004,
ARMING_CHECK_GPS = 0x0008,
ARMING_CHECK_INS = 0x0010,
ARMING_CHECK_PARAMETERS = 0x0020,
ARMING_CHECK_RC = 0x0040,
ARMING_CHECK_VOLTAGE = 0x0080,
ARMING_CHECK_BATTERY = 0x0100,
ARMING_CHECK_AIRSPEED = 0x0200,
ARMING_CHECK_LOGGING = 0x0400,
};
enum ArmingMethod {
NONE = 0,
RUDDER,
MAVLINK
};
enum ArmingRequired {
NO = 0,
YES_MIN_PWM = 1,
YES_ZERO_PWM = 2
};
enum ArmingRudder {
ARMING_RUDDER_DISABLED = 0,
ARMING_RUDDER_ARMONLY = 1,
ARMING_RUDDER_ARMDISARM = 2
};
// for the hacky function pointer to gcs_send_text_p
FUNCTOR_TYPEDEF(gcs_send_t_p, void, gcs_severity, const prog_char_t *);
AP_Arming(const AP_AHRS &ahrs_ref, const AP_Baro &baro, Compass &compass,
const enum HomeState &home_set, gcs_send_t_p);
ArmingRequired arming_required();
bool arm(uint8_t method);
bool disarm();
bool is_armed();
ArmingRudder rudder_arming() const { return (ArmingRudder)rudder_arming_value.get(); }
uint16_t get_enabled_checks();
/*
pre_arm_checks() is virtual so it can be modified
in a vehicle specific subclass
*/
virtual bool pre_arm_checks(bool report);
void set_skip_gyro_cal(bool set) { skip_gyro_cal = set; }
void set_logging_available(bool set) { logging_available = set; }
//for params
static const struct AP_Param::GroupInfo var_info[];
protected:
bool armed:1;
bool logging_available:1;
bool skip_gyro_cal:1;
//Parameters
AP_Int8 require;
AP_Int8 rudder_arming_value;
//bitmask for which checks are required
AP_Int16 checks_to_perform;
//how the vehicle was armed
uint8_t arming_method;
const AP_AHRS &ahrs;
const AP_Baro &barometer;
Compass &_compass;
const enum HomeState &home_is_set;
gcs_send_t_p gcs_send_text_P;
uint32_t last_accel_pass_ms[INS_MAX_INSTANCES];
uint32_t last_gyro_pass_ms[INS_MAX_INSTANCES];
void set_enabled_checks(uint16_t);
bool barometer_checks(bool report);
bool airspeed_checks(bool report);
bool logging_checks(bool report);
bool ins_checks(bool report);
bool compass_checks(bool report);
bool gps_checks(bool report);
bool battery_checks(bool report);
bool hardware_safety_check(bool report);
bool manual_transmitter_checks(bool report);
};
#endif //__AP_ARMING_H__