mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
hacks to get AP_Param to compile
This commit is contained in:
parent
5b842a447f
commit
497a400841
@ -38,8 +38,7 @@ typedef struct {
|
||||
#include "c++.h" // c++ additions
|
||||
//#include "AP_Vector.h"
|
||||
//#include "AP_Loop.h"
|
||||
#include "AP_Var.h"
|
||||
|
||||
#include "AP_Param.h"
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
@ -1,3 +1,5 @@
|
||||
#if 0 // we can't build this and AP_Param due to AP_Common.h conflicts
|
||||
|
||||
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||
//
|
||||
// This is free software; you can redistribute it and/or modify it under
|
||||
@ -9,8 +11,10 @@
|
||||
/// @file AP_Var.cpp
|
||||
/// @brief The AP variable store.
|
||||
|
||||
#define NO_AP_PARAM
|
||||
|
||||
#include <AP_Common.h>
|
||||
#include <AP_Var.h>
|
||||
|
||||
#include <math.h>
|
||||
#include <string.h>
|
||||
@ -821,3 +825,4 @@ AP_Var_typesetup::AP_Var_typesetup(void)
|
||||
/// Cause the AP_Var_typesetup constructor to be run.
|
||||
///
|
||||
static AP_Var_typesetup _typesetup __attribute__((used));
|
||||
#endif
|
||||
|
@ -13,133 +13,3 @@
|
||||
#include <FastSerial.h>
|
||||
#include <AP_Common.h>
|
||||
|
||||
void
|
||||
AP_Var_print(AP_Var *vp)
|
||||
{
|
||||
// try to print from variable types that we know
|
||||
if (vp->meta_type_id() == AP_Var::k_typeid_float) {
|
||||
|
||||
AP_Float *v = (AP_Float *)vp;
|
||||
Serial.printf_P(PSTR("%f"), v->get());
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_float16) {
|
||||
|
||||
AP_Float16 *v = (AP_Float16 *)vp;
|
||||
Serial.printf_P(PSTR("%f"), v->get());
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int32) {
|
||||
|
||||
AP_Int32 *v = (AP_Int32 *)vp;
|
||||
Serial.printf_P(PSTR("%ld"), v->get());
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int16) {
|
||||
|
||||
AP_Int16 *v = (AP_Int16 *)vp;
|
||||
Serial.printf_P(PSTR("%d"), v->get());
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int8) {
|
||||
|
||||
AP_Int8 *v = (AP_Int8 *)vp;
|
||||
Serial.printf_P(PSTR("%d"), v->get());
|
||||
|
||||
} else {
|
||||
Serial.print_P(PSTR("??"));
|
||||
}
|
||||
}
|
||||
|
||||
int8_t
|
||||
AP_Var_menu_set(uint8_t argc, const Menu::arg *argv)
|
||||
{
|
||||
AP_Var *vp;
|
||||
|
||||
// check argument count
|
||||
if (argc != 3) {
|
||||
Serial.println_P(PSTR("missing name or value"));
|
||||
return -1;
|
||||
}
|
||||
Serial.printf_P(PSTR("%s: "), argv[1].str);
|
||||
|
||||
// search for the variable
|
||||
vp = AP_Var::find(argv[1].str);
|
||||
if (NULL == vp) {
|
||||
Serial.println_P(PSTR("not found"));
|
||||
return -1;
|
||||
}
|
||||
|
||||
// try to assign to variable types that we know
|
||||
if (vp->meta_type_id() == AP_Var::k_typeid_float) {
|
||||
|
||||
AP_Float *v = (AP_Float *)vp;
|
||||
v->set(argv[2].f);
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_float16) {
|
||||
|
||||
AP_Float16 *v = (AP_Float16 *)vp;
|
||||
v->set(argv[2].f);
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int32) {
|
||||
|
||||
AP_Int32 *v = (AP_Int32 *)vp;
|
||||
v->set(argv[2].i);
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int16) {
|
||||
|
||||
AP_Int16 *v = (AP_Int16 *)vp;
|
||||
v->set(argv[2].i);
|
||||
|
||||
} else if (vp->meta_type_id() == AP_Var::k_typeid_int8) {
|
||||
|
||||
AP_Int8 *v = (AP_Int8 *)vp;
|
||||
v->set(argv[2].i);
|
||||
|
||||
} else {
|
||||
Serial.println_P(PSTR("unknown type"));
|
||||
return -1;
|
||||
}
|
||||
AP_Var_print(vp);
|
||||
Serial.println();
|
||||
return 0;
|
||||
}
|
||||
|
||||
int8_t
|
||||
AP_Var_menu_show(uint8_t argc, const Menu::arg *argv)
|
||||
{
|
||||
AP_Var *vp;
|
||||
|
||||
// if no arguments, show all variables
|
||||
if (argc == 1) {
|
||||
for (vp = AP_Var::first(); NULL != vp; vp = vp->next()) {
|
||||
char name_buffer[32];
|
||||
|
||||
// groups should not be displayed
|
||||
if (vp->meta_type_id() == AP_Var::k_typeid_group) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// get a displayable name for the variable
|
||||
vp->copy_name(name_buffer, sizeof(name_buffer));
|
||||
if (name_buffer[0] == 0) {
|
||||
// without a name the variable is not displayable
|
||||
continue;
|
||||
}
|
||||
|
||||
// print name and value
|
||||
Serial.printf_P(PSTR("%03u:%-32.32s: "), vp->key(), name_buffer);
|
||||
AP_Var_print(vp);
|
||||
Serial.println();
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
// show variable by name
|
||||
vp = AP_Var::find(argv[1].str);
|
||||
if (NULL == vp) {
|
||||
Serial.println_P(PSTR("not found"));
|
||||
return -1;
|
||||
}
|
||||
Serial.printf_P(PSTR("%03u:%s: "), vp->key(), argv[1].str);
|
||||
AP_Var_print(vp);
|
||||
Serial.println();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user