kopia lustrzana https://github.com/pimoroni/pimoroni-pico
Removed MP accesors to Snapshot class
rodzic
652612fc31
commit
ae606e7bf5
|
@ -2,21 +2,6 @@
|
|||
|
||||
|
||||
/***** Methods *****/
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot___del___obj, Snapshot___del__);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_count_obj, Snapshot_count);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_delta_obj, Snapshot_delta);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_frequency_obj, Snapshot_frequency);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_revolutions_obj, Snapshot_revolutions);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_degrees_obj, Snapshot_degrees);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_radians_obj, Snapshot_radians);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_revolutions_delta_obj, Snapshot_revolutions_delta);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_degrees_delta_obj, Snapshot_degrees_delta);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_radians_delta_obj, Snapshot_radians_delta);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_revolutions_per_second_obj, Snapshot_revolutions_per_second);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_revolutions_per_minute_obj, Snapshot_revolutions_per_minute);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_degrees_per_second_obj, Snapshot_degrees_per_second);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Snapshot_radians_per_second_obj, Snapshot_radians_per_second);
|
||||
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder___del___obj, Encoder___del__);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder_pins_obj, Encoder_pins);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder_common_pin_obj, Encoder_common_pin);
|
||||
|
@ -31,27 +16,9 @@ MP_DEFINE_CONST_FUN_OBJ_1(Encoder_degrees_obj, Encoder_degrees);
|
|||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder_radians_obj, Encoder_radians);
|
||||
MP_DEFINE_CONST_FUN_OBJ_KW(Encoder_direction_obj, 1, Encoder_direction);
|
||||
MP_DEFINE_CONST_FUN_OBJ_KW(Encoder_counts_per_revolution_obj, 1, Encoder_counts_per_revolution);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder_take_snapshot_obj, Encoder_take_snapshot);
|
||||
MP_DEFINE_CONST_FUN_OBJ_1(Encoder_capture_obj, Encoder_capture);
|
||||
|
||||
/***** Binding of Methods *****/
|
||||
STATIC const mp_rom_map_elem_t Snapshot_locals_dict_table[] = {
|
||||
{ MP_ROM_QSTR(MP_QSTR___del__), MP_ROM_PTR(&Snapshot___del___obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_count), MP_ROM_PTR(&Snapshot_count_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_delta), MP_ROM_PTR(&Snapshot_delta_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_frequency), MP_ROM_PTR(&Snapshot_frequency_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_revolutions), MP_ROM_PTR(&Snapshot_revolutions_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_degrees), MP_ROM_PTR(&Snapshot_degrees_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_radians), MP_ROM_PTR(&Snapshot_radians_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_revolutions_delta), MP_ROM_PTR(&Snapshot_revolutions_delta_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_degrees_delta), MP_ROM_PTR(&Snapshot_degrees_delta_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_radians_delta), MP_ROM_PTR(&Snapshot_radians_delta_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_revolutions_per_second), MP_ROM_PTR(&Snapshot_revolutions_per_second_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_revolutions_per_minute), MP_ROM_PTR(&Snapshot_revolutions_per_minute_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_degrees_per_second), MP_ROM_PTR(&Snapshot_degrees_per_second_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_radians_per_second), MP_ROM_PTR(&Snapshot_radians_per_second_obj) },
|
||||
};
|
||||
|
||||
STATIC const mp_rom_map_elem_t Encoder_locals_dict_table[] = {
|
||||
{ MP_ROM_QSTR(MP_QSTR___del__), MP_ROM_PTR(&Encoder___del___obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_pins), MP_ROM_PTR(&Encoder_pins_obj) },
|
||||
|
@ -67,22 +34,12 @@ STATIC const mp_rom_map_elem_t Encoder_locals_dict_table[] = {
|
|||
{ MP_ROM_QSTR(MP_QSTR_radians), MP_ROM_PTR(&Encoder_radians_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_direction), MP_ROM_PTR(&Encoder_direction_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_counts_per_revolution), MP_ROM_PTR(&Encoder_counts_per_revolution_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_take_snapshot), MP_ROM_PTR(&Encoder_take_snapshot_obj) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_capture), MP_ROM_PTR(&Encoder_capture_obj) },
|
||||
};
|
||||
|
||||
STATIC MP_DEFINE_CONST_DICT(Snapshot_locals_dict, Snapshot_locals_dict_table);
|
||||
STATIC MP_DEFINE_CONST_DICT(Encoder_locals_dict, Encoder_locals_dict_table);
|
||||
|
||||
/***** Class Definition *****/
|
||||
const mp_obj_type_t Snapshot_type = {
|
||||
{ &mp_type_type },
|
||||
.name = MP_QSTR_snapshot,
|
||||
.print = Snapshot_print,
|
||||
.make_new = Snapshot_make_new,
|
||||
.locals_dict = (mp_obj_dict_t*)&Snapshot_locals_dict,
|
||||
};
|
||||
|
||||
const mp_obj_type_t Encoder_type = {
|
||||
{ &mp_type_type },
|
||||
.name = MP_QSTR_encoder,
|
||||
|
@ -95,7 +52,6 @@ const mp_obj_type_t Encoder_type = {
|
|||
STATIC const mp_map_elem_t encoder_globals_table[] = {
|
||||
{ MP_OBJ_NEW_QSTR(MP_QSTR___name__), MP_OBJ_NEW_QSTR(MP_QSTR_encoder) },
|
||||
{ MP_OBJ_NEW_QSTR(MP_QSTR_Encoder), (mp_obj_t)&Encoder_type },
|
||||
{ MP_OBJ_NEW_QSTR(MP_QSTR_Snapshot), (mp_obj_t)&Snapshot_type },
|
||||
|
||||
{ MP_ROM_QSTR(MP_QSTR_NORMAL), MP_ROM_INT(0x00) },
|
||||
{ MP_ROM_QSTR(MP_QSTR_REVERSED), MP_ROM_INT(0x01) },
|
||||
|
|
|
@ -12,110 +12,6 @@ extern "C" {
|
|||
#include "py/builtin.h"
|
||||
|
||||
|
||||
/********** Snapshot **********/
|
||||
|
||||
/***** Variables Struct *****/
|
||||
typedef struct _Snapshot_obj_t {
|
||||
mp_obj_base_t base;
|
||||
Encoder::Snapshot snapshot;
|
||||
} _Snapshot_obj_t;
|
||||
|
||||
|
||||
/***** Print *****/
|
||||
void Snapshot_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||
(void)kind; //Unused input parameter
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
Encoder::Snapshot& snap = self->snapshot;
|
||||
mp_print_str(print, "Snapshot(count = ");
|
||||
mp_obj_print_helper(print, mp_obj_new_int(snap.count()), PRINT_REPR);
|
||||
mp_print_str(print, ", delta = ");
|
||||
mp_obj_print_helper(print, mp_obj_new_int(snap.delta()), PRINT_REPR);
|
||||
mp_print_str(print, ", freq = ");
|
||||
mp_obj_print_helper(print, mp_obj_new_float(snap.frequency()), PRINT_REPR);
|
||||
mp_print_str(print, ")");
|
||||
}
|
||||
|
||||
|
||||
/***** Constructor *****/
|
||||
mp_obj_t Snapshot_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args) {
|
||||
mp_raise_TypeError("cannot create an instance of Snapshot. They can only be created by calling take_snapshot on an Encoder object");
|
||||
return mp_const_none;
|
||||
}
|
||||
|
||||
|
||||
/***** Destructor ******/
|
||||
mp_obj_t Snapshot___del__(mp_obj_t self_in) {
|
||||
return mp_const_none;
|
||||
}
|
||||
|
||||
|
||||
/***** Methods *****/
|
||||
mp_obj_t Snapshot_count(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_int(self->snapshot.count());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_delta(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_int(self->snapshot.delta());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_frequency(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.frequency());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_revolutions(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.revolutions());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_degrees(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.degrees());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_radians(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.radians());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_revolutions_delta(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.revolutions_delta());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_degrees_delta(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.degrees_delta());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_radians_delta(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.radians_delta());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_revolutions_per_second(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.revolutions_per_second());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_revolutions_per_minute(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.revolutions_per_minute());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_degrees_per_second(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.degrees_per_second());
|
||||
}
|
||||
|
||||
mp_obj_t Snapshot_radians_per_second(mp_obj_t self_in) {
|
||||
_Snapshot_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Snapshot_obj_t);
|
||||
return mp_obj_new_float(self->snapshot.radians_per_second());
|
||||
}
|
||||
|
||||
|
||||
/********** Encoder **********/
|
||||
|
||||
/***** Variables Struct *****/
|
||||
|
@ -280,7 +176,6 @@ extern mp_obj_t Encoder_common_pin(mp_obj_t self_in) {
|
|||
return mp_obj_new_int(self->encoder->common_pin());
|
||||
}
|
||||
|
||||
|
||||
extern mp_obj_t Encoder_state(mp_obj_t self_in) {
|
||||
_Encoder_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Encoder_obj_t);
|
||||
bool_pair state = self->encoder->state();
|
||||
|
@ -406,17 +301,6 @@ extern mp_obj_t Encoder_counts_per_revolution(size_t n_args, const mp_obj_t *pos
|
|||
}
|
||||
}
|
||||
|
||||
extern mp_obj_t Encoder_take_snapshot(mp_obj_t self_in) {
|
||||
_Encoder_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Encoder_obj_t);
|
||||
|
||||
// Create a new MP Snapshot instance and assign a copy of the encoder's snapshot to it
|
||||
_Snapshot_obj_t *snap = m_new_obj_with_finaliser(_Snapshot_obj_t);
|
||||
snap->base.type = &Snapshot_type;
|
||||
|
||||
snap->snapshot = self->encoder->take_snapshot();
|
||||
return MP_OBJ_FROM_PTR(snap);
|
||||
}
|
||||
|
||||
extern mp_obj_t Encoder_capture(mp_obj_t self_in) {
|
||||
_Encoder_obj_t *self = MP_OBJ_TO_PTR2(self_in, _Encoder_obj_t);
|
||||
|
||||
|
|
|
@ -2,27 +2,9 @@
|
|||
#include "py/runtime.h"
|
||||
|
||||
/***** Extern of Class Definition *****/
|
||||
extern const mp_obj_type_t Snapshot_type;
|
||||
extern const mp_obj_type_t Encoder_type;
|
||||
|
||||
/***** Extern of Class Methods *****/
|
||||
extern void Snapshot_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind);
|
||||
extern mp_obj_t Snapshot_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args);
|
||||
extern mp_obj_t Snapshot___del__(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_count(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_delta(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_frequency(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_revolutions(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_degrees(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_radians(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_revolutions_delta(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_degrees_delta(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_radians_delta(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_revolutions_per_second(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_revolutions_per_minute(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_degrees_per_second(mp_obj_t self_in);
|
||||
extern mp_obj_t Snapshot_radians_per_second(mp_obj_t self_in);
|
||||
|
||||
extern void Encoder_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind);
|
||||
extern mp_obj_t Encoder_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args);
|
||||
extern mp_obj_t Encoder___del__(mp_obj_t self_in);
|
||||
|
@ -39,5 +21,4 @@ extern mp_obj_t Encoder_degrees(mp_obj_t self_in);
|
|||
extern mp_obj_t Encoder_radians(mp_obj_t self_in);
|
||||
extern mp_obj_t Encoder_direction(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args);
|
||||
extern mp_obj_t Encoder_counts_per_revolution(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args);
|
||||
extern mp_obj_t Encoder_take_snapshot(mp_obj_t self_in);
|
||||
extern mp_obj_t Encoder_capture(mp_obj_t self_in);
|
Ładowanie…
Reference in New Issue