// auto generated bindings, don't manually edit #include "lua_generated_bindings.h" #include #include #include #include #include #include int new_Vector2f(lua_State *L) { Vector2f *ud = (Vector2f *)lua_newuserdata(L, sizeof(Vector2f)); new (ud) Vector2f(); luaL_getmetatable(L, "Vector2f"); lua_setmetatable(L, -2); return 1; } int new_Vector3f(lua_State *L) { Vector3f *ud = (Vector3f *)lua_newuserdata(L, sizeof(Vector3f)); new (ud) Vector3f(); luaL_getmetatable(L, "Vector3f"); lua_setmetatable(L, -2); return 1; } int new_Location(lua_State *L) { Location *ud = (Location *)lua_newuserdata(L, sizeof(Location)); new (ud) Location(); luaL_getmetatable(L, "Location"); lua_setmetatable(L, -2); return 1; } Vector2f * check_Vector2f(lua_State *L, int arg) { void *data = luaL_checkudata(L, arg, "Vector2f"); return (Vector2f *)data; } Vector3f * check_Vector3f(lua_State *L, int arg) { void *data = luaL_checkudata(L, arg, "Vector3f"); return (Vector3f *)data; } Location * check_Location(lua_State *L, int arg) { void *data = luaL_checkudata(L, arg, "Location"); return (Location *)data; } static int Vector2f_y(lua_State *L) { Vector2f *ud = check_Vector2f(L, 1); switch(lua_gettop(L)) { case 1: lua_pushnumber(L, ud->y); return 1; case 2: { const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "y out of range"); const float data_2 = raw_data_2; ud->y = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Vector2f_x(lua_State *L) { Vector2f *ud = check_Vector2f(L, 1); switch(lua_gettop(L)) { case 1: lua_pushnumber(L, ud->x); return 1; case 2: { const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "x out of range"); const float data_2 = raw_data_2; ud->x = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Vector3f_z(lua_State *L) { Vector3f *ud = check_Vector3f(L, 1); switch(lua_gettop(L)) { case 1: lua_pushnumber(L, ud->z); return 1; case 2: { const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "z out of range"); const float data_2 = raw_data_2; ud->z = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Vector3f_y(lua_State *L) { Vector3f *ud = check_Vector3f(L, 1); switch(lua_gettop(L)) { case 1: lua_pushnumber(L, ud->y); return 1; case 2: { const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "y out of range"); const float data_2 = raw_data_2; ud->y = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Vector3f_x(lua_State *L) { Vector3f *ud = check_Vector3f(L, 1); switch(lua_gettop(L)) { case 1: lua_pushnumber(L, ud->x); return 1; case 2: { const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "x out of range"); const float data_2 = raw_data_2; ud->x = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_loiter_xtrack(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->loiter_xtrack); return 1; case 2: { const bool data_2 = static_cast(lua_toboolean(L, 2)); ud->loiter_xtrack = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_origin_alt(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->origin_alt); return 1; case 2: { const bool data_2 = static_cast(lua_toboolean(L, 2)); ud->origin_alt = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_terrain_alt(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->terrain_alt); return 1; case 2: { const bool data_2 = static_cast(lua_toboolean(L, 2)); ud->terrain_alt = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_relative_alt(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->relative_alt); return 1; case 2: { const bool data_2 = static_cast(lua_toboolean(L, 2)); ud->relative_alt = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_lng(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->lng); return 1; case 2: { const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-1800000000, INT32_MIN)) && (raw_data_2 <= MIN(1800000000, INT32_MAX))), 2, "lng out of range"); const int32_t data_2 = raw_data_2; ud->lng = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Location_lat(lua_State *L) { Location *ud = check_Location(L, 1); switch(lua_gettop(L)) { case 1: lua_pushinteger(L, ud->lat); return 1; case 2: { const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-900000000, INT32_MIN)) && (raw_data_2 <= MIN(900000000, INT32_MAX))), 2, "lat out of range"); const int32_t data_2 = raw_data_2; ud->lat = data_2; return 0; } default: return luaL_argerror(L, lua_gettop(L), "too many arguments"); } } static int Vector2f_is_zero(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector2f"); Vector2f * ud = check_Vector2f(L, 1); ud->is_zero( ); return 0; } static int Vector2f_is_inf(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector2f"); Vector2f * ud = check_Vector2f(L, 1); ud->is_inf( ); return 0; } static int Vector2f_is_nan(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector2f"); Vector2f * ud = check_Vector2f(L, 1); ud->is_nan( ); return 0; } static int Vector2f_normalize(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector2f"); Vector2f * ud = check_Vector2f(L, 1); ud->normalize( ); return 0; } static int Vector2f_length(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector2f"); Vector2f * ud = check_Vector2f(L, 1); const float data = ud->length( ); lua_pushnumber(L, data); return 1; } static int Vector3f_is_zero(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector3f"); Vector3f * ud = check_Vector3f(L, 1); ud->is_zero( ); return 0; } static int Vector3f_is_inf(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector3f"); Vector3f * ud = check_Vector3f(L, 1); ud->is_inf( ); return 0; } static int Vector3f_is_nan(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector3f"); Vector3f * ud = check_Vector3f(L, 1); ud->is_nan( ); return 0; } static int Vector3f_normalize(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector3f"); Vector3f * ud = check_Vector3f(L, 1); ud->normalize( ); return 0; } static int Vector3f_length(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Vector3f"); Vector3f * ud = check_Vector3f(L, 1); const float data = ud->length( ); lua_pushnumber(L, data); return 1; } static int Location_get_vector_from_origin_NEU(lua_State *L) { // 1 Vector3f 14 : 6 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Location"); Location * ud = check_Location(L, 1); Vector3f & data_2 = *check_Vector3f(L, 2); const bool data = ud->get_vector_from_origin_NEU( data_2); lua_pushboolean(L, data); return 1; } static int Location_offset(lua_State *L) { // 1 float 13 : 8 // 2 float 13 : 11 const int args = lua_gettop(L); if (args > 5) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 5) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Location"); Location * ud = check_Location(L, 1); const float raw_data_2 = luaL_checknumber(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_2 <= MIN(FLT_MAX, INFINITY))), 2, "argument out of range"); const float data_2 = raw_data_2; const float raw_data_3 = luaL_checknumber(L, 3); luaL_argcheck(L, ((raw_data_3 >= MAX(-FLT_MAX, -INFINITY)) && (raw_data_3 <= MIN(FLT_MAX, INFINITY))), 3, "argument out of range"); const float data_3 = raw_data_3; ud->offset( data_2, data_3); return 0; } static int Location_get_distance(lua_State *L) { // 1 Location 12 : 6 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "Location"); Location * ud = check_Location(L, 1); Location & data_2 = *check_Location(L, 2); const float data = ud->get_distance( data_2); lua_pushnumber(L, data); return 1; } const luaL_Reg Vector2f_meta[] = { {"y", Vector2f_y}, {"x", Vector2f_x}, {"is_zero", Vector2f_is_zero}, {"is_inf", Vector2f_is_inf}, {"is_nan", Vector2f_is_nan}, {"normalize", Vector2f_normalize}, {"length", Vector2f_length}, {NULL, NULL} }; const luaL_Reg Vector3f_meta[] = { {"z", Vector3f_z}, {"y", Vector3f_y}, {"x", Vector3f_x}, {"is_zero", Vector3f_is_zero}, {"is_inf", Vector3f_is_inf}, {"is_nan", Vector3f_is_nan}, {"normalize", Vector3f_normalize}, {"length", Vector3f_length}, {NULL, NULL} }; const luaL_Reg Location_meta[] = { {"loiter_xtrack", Location_loiter_xtrack}, {"origin_alt", Location_origin_alt}, {"terrain_alt", Location_terrain_alt}, {"relative_alt", Location_relative_alt}, {"lng", Location_lng}, {"lat", Location_lat}, {"get_vector_from_origin_NEU", Location_get_vector_from_origin_NEU}, {"offset", Location_offset}, {"get_distance", Location_get_distance}, {NULL, NULL} }; static int RangeFinder_num_sensors(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "rangefinder"); RangeFinder * ud = RangeFinder::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "rangefinder not supported on this firmware"); } const uint8_t data = ud->num_sensors( ); lua_pushinteger(L, data); return 1; } static int AP_Notify_play_tune(lua_State *L) { // 1 string 90 : 6 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "AP_Notify"); AP_Notify * ud = AP_Notify::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "AP_Notify not supported on this firmware"); } const char * data_2 = luaL_checkstring(L, 2); ud->play_tune( data_2); return 0; } static int AP_GPS_first_unconfigured_gps(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const uint8_t data = ud->first_unconfigured_gps( ); lua_pushinteger(L, data); return 1; } static int AP_GPS_all_configured(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const bool data = ud->all_configured( ); lua_pushboolean(L, data); return 1; } static int AP_GPS_get_antenna_offset(lua_State *L) { // 1 uint8_t 65 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const Vector3f &data = ud->get_antenna_offset( data_2); new_Vector3f(L); *check_Vector3f(L, -1) = data; return 1; } static int AP_GPS_have_vertical_velocity(lua_State *L) { // 1 uint8_t 64 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const bool data = ud->have_vertical_velocity( data_2); lua_pushboolean(L, data); return 1; } static int AP_GPS_get_vdop(lua_State *L) { // 1 uint8_t 63 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const uint16_t data = ud->get_vdop( data_2); lua_pushinteger(L, data); return 1; } static int AP_GPS_get_hdop(lua_State *L) { // 1 uint8_t 62 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const uint16_t data = ud->get_hdop( data_2); lua_pushinteger(L, data); return 1; } static int AP_GPS_num_sats(lua_State *L) { // 1 uint8_t 61 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const uint8_t data = ud->num_sats( data_2); lua_pushinteger(L, data); return 1; } static int AP_GPS_ground_course(lua_State *L) { // 1 uint8_t 60 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const float data = ud->ground_course( data_2); lua_pushnumber(L, data); return 1; } static int AP_GPS_ground_speed(lua_State *L) { // 1 uint8_t 59 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const float data = ud->ground_speed( data_2); lua_pushnumber(L, data); return 1; } static int AP_GPS_velocity(lua_State *L) { // 1 uint8_t 58 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const Vector3f &data = ud->velocity( data_2); new_Vector3f(L); *check_Vector3f(L, -1) = data; return 1; } static int AP_GPS_vertical_accuracy(lua_State *L) { // 1 uint8_t 57 : 8 // 2 float 57 : 9 const int args = lua_gettop(L); if (args > 4) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 4) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); float data_5003 = {}; const bool data = ud->vertical_accuracy( data_2, data_5003); if (data) { lua_pushnumber(L, data_5003); } else { lua_pushnil(L); } return 1; } static int AP_GPS_horizontal_accuracy(lua_State *L) { // 1 uint8_t 56 : 8 // 2 float 56 : 9 const int args = lua_gettop(L); if (args > 4) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 4) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); float data_5003 = {}; const bool data = ud->horizontal_accuracy( data_2, data_5003); if (data) { lua_pushnumber(L, data_5003); } else { lua_pushnil(L); } return 1; } static int AP_GPS_speed_accuracy(lua_State *L) { // 1 uint8_t 55 : 8 // 2 float 55 : 9 const int args = lua_gettop(L); if (args > 4) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 4) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); float data_5003 = {}; const bool data = ud->speed_accuracy( data_2, data_5003); if (data) { lua_pushnumber(L, data_5003); } else { lua_pushnil(L); } return 1; } static int AP_GPS_location(lua_State *L) { // 1 uint8_t 54 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const Location &data = ud->location( data_2); new_Location(L); *check_Location(L, -1) = data; return 1; } static int AP_GPS_status(lua_State *L) { // 1 uint8_t 53 : 8 const int args = lua_gettop(L); if (args > 3) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 3) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const int raw_data_2 = luaL_checkinteger(L, 2); luaL_argcheck(L, ((raw_data_2 >= MAX(0, 0)) && (raw_data_2 <= MIN(GPS_MAX_INSTANCES, UINT8_MAX))), 2, "argument out of range"); const uint8_t data_2 = static_cast(raw_data_2); const uint8_t data = ud->status( data_2); lua_pushinteger(L, data); return 1; } static int AP_GPS_primary_sensor(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const uint8_t data = ud->primary_sensor( ); lua_pushinteger(L, data); return 1; } static int AP_GPS_num_sensors(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "gps"); AP_GPS * ud = AP_GPS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "gps not supported on this firmware"); } const uint8_t data = ud->num_sensors( ); lua_pushinteger(L, data); return 1; } static int AP_AHRS_prearm_healthy(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const bool data = ud->prearm_healthy( ); lua_pushboolean(L, data); return 1; } static int AP_AHRS_home_is_set(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const bool data = ud->home_is_set( ); lua_pushboolean(L, data); return 1; } static int AP_AHRS_get_relative_position_NED_home(lua_State *L) { // 1 Vector3f 26 : 6 const int args = lua_gettop(L); if (args > 2) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 2) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } Vector3f data_5002 = {}; const bool data = ud->get_relative_position_NED_home( data_5002); if (data) { new_Vector3f(L); *check_Vector3f(L, -1) = data_5002; } else { lua_pushnil(L); } return 1; } static int AP_AHRS_get_velocity_NED(lua_State *L) { // 1 Vector3f 25 : 6 const int args = lua_gettop(L); if (args > 2) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 2) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } Vector3f data_5002 = {}; const bool data = ud->get_velocity_NED( data_5002); if (data) { new_Vector3f(L); *check_Vector3f(L, -1) = data_5002; } else { lua_pushnil(L); } return 1; } static int AP_AHRS_groundspeed_vector(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const Vector2f &data = ud->groundspeed_vector( ); new_Vector2f(L); *check_Vector2f(L, -1) = data; return 1; } static int AP_AHRS_wind_estimate(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const Vector3f &data = ud->wind_estimate( ); new_Vector3f(L); *check_Vector3f(L, -1) = data; return 1; } static int AP_AHRS_get_hagl(lua_State *L) { // 1 float 22 : 6 const int args = lua_gettop(L); if (args > 2) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 2) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } float data_5002 = {}; const bool data = ud->get_hagl( data_5002); if (data) { lua_pushnumber(L, data_5002); } else { lua_pushnil(L); } return 1; } static int AP_AHRS_get_gyro(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const Vector3f &data = ud->get_gyro( ); new_Vector3f(L); *check_Vector3f(L, -1) = data; return 1; } static int AP_AHRS_get_home(lua_State *L) { const int args = lua_gettop(L); if (args > 1) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 1) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } const Location &data = ud->get_home( ); new_Location(L); *check_Location(L, -1) = data; return 1; } static int AP_AHRS_get_position(lua_State *L) { // 1 Location 19 : 6 const int args = lua_gettop(L); if (args > 2) { return luaL_argerror(L, args, "too many arguments"); } else if (args < 2) { return luaL_argerror(L, args, "too few arguments"); } luaL_checkudata(L, 1, "ahrs"); AP_AHRS * ud = AP_AHRS::get_singleton(); if (ud == nullptr) { return luaL_argerror(L, args, "ahrs not supported on this firmware"); } Location data_5002 = {}; const bool data = ud->get_position( data_5002); if (data) { new_Location(L); *check_Location(L, -1) = data_5002; } else { lua_pushnil(L); } return 1; } const luaL_Reg RangeFinder_meta[] = { {"num_sensors", RangeFinder_num_sensors}, {NULL, NULL} }; const luaL_Reg AP_Notify_meta[] = { {"play_tune", AP_Notify_play_tune}, {NULL, NULL} }; const luaL_Reg notify_meta[] = { {NULL, NULL} }; const luaL_Reg AP_GPS_meta[] = { {"first_unconfigured_gps", AP_GPS_first_unconfigured_gps}, {"all_configured", AP_GPS_all_configured}, {"get_antenna_offset", AP_GPS_get_antenna_offset}, {"have_vertical_velocity", AP_GPS_have_vertical_velocity}, {"get_vdop", AP_GPS_get_vdop}, {"get_hdop", AP_GPS_get_hdop}, {"num_sats", AP_GPS_num_sats}, {"ground_course", AP_GPS_ground_course}, {"ground_speed", AP_GPS_ground_speed}, {"velocity", AP_GPS_velocity}, {"vertical_accuracy", AP_GPS_vertical_accuracy}, {"horizontal_accuracy", AP_GPS_horizontal_accuracy}, {"speed_accuracy", AP_GPS_speed_accuracy}, {"location", AP_GPS_location}, {"status", AP_GPS_status}, {"primary_sensor", AP_GPS_primary_sensor}, {"num_sensors", AP_GPS_num_sensors}, {NULL, NULL} }; const luaL_Reg AP_AHRS_meta[] = { {"prearm_healthy", AP_AHRS_prearm_healthy}, {"home_is_set", AP_AHRS_home_is_set}, {"get_relative_position_NED_home", AP_AHRS_get_relative_position_NED_home}, {"get_velocity_NED", AP_AHRS_get_velocity_NED}, {"groundspeed_vector", AP_AHRS_groundspeed_vector}, {"wind_estimate", AP_AHRS_wind_estimate}, {"get_hagl", AP_AHRS_get_hagl}, {"get_gyro", AP_AHRS_get_gyro}, {"get_home", AP_AHRS_get_home}, {"get_position", AP_AHRS_get_position}, {NULL, NULL} }; const struct userdata_fun { const char *name; const luaL_Reg *reg; } userdata_fun[] = { {"Vector2f", Vector2f_meta}, {"Vector3f", Vector3f_meta}, {"Location", Location_meta}, }; const struct singleton_fun { const char *name; const luaL_Reg *reg; } singleton_fun[] = { {"rangefinder", RangeFinder_meta}, {"AP_Notify", AP_Notify_meta}, {"notify", notify_meta}, {"gps", AP_GPS_meta}, {"ahrs", AP_AHRS_meta}, }; void load_generated_bindings(lua_State *L) { // userdata metatables for (uint32_t i = 0; i < ARRAY_SIZE(userdata_fun); i++) { luaL_newmetatable(L, userdata_fun[i].name); luaL_setfuncs(L, userdata_fun[i].reg, 0); lua_pushstring(L, "__index"); lua_pushvalue(L, -2); lua_settable(L, -3); lua_pop(L, 1); } // singleton metatables for (uint32_t i = 0; i < ARRAY_SIZE(singleton_fun); i++) { luaL_newmetatable(L, singleton_fun[i].name); luaL_setfuncs(L, singleton_fun[i].reg, 0); lua_pushstring(L, "__index"); lua_pushvalue(L, -2); lua_settable(L, -3); lua_pop(L, 1); lua_newuserdata(L, 0); luaL_getmetatable(L, singleton_fun[i].name); lua_setmetatable(L, -2); lua_setglobal(L, singleton_fun[i].name); } } const char *singletons[] = { "rangefinder", "AP_Notify", "notify", "gps", "ahrs", }; const struct userdata { const char *name; const lua_CFunction fun; } new_userdata[] = { {"Vector2f", new_Vector2f}, {"Vector3f", new_Vector3f}, {"Location", new_Location}, }; void load_generated_sandbox(lua_State *L) { for (uint32_t i = 0; i < ARRAY_SIZE(singletons); i++) { lua_pushstring(L, singletons[i]); lua_getglobal(L, singletons[i]); lua_settable(L, -3); } for (uint32_t i = 0; i < ARRAY_SIZE(new_userdata); i++) { lua_pushstring(L, new_userdata[i].name); lua_pushcfunction(L, new_userdata[i].fun); lua_settable(L, -3); } }