struct cmd_send_hello_result {
fixed_string_t send_hello;
uint64_t addr;
+ struct xbee_neigh *neigh;
uint16_t period;
uint16_t count;
fixed_string_t data;
};
/* function called when cmd_send_hello is parsed successfully */
-static void cmd_send_hello_parsed(void *parsed_result, void *data)
+static void cmd_send_hello_parsed(void *parsed_result, void *use_neigh)
{
struct cmd_send_hello_result *res = parsed_result;
uint16_t now, next, diff;
uint8_t flags;
+ uint64_t addr;
- (void)data;
+ if (use_neigh)
+ addr = res->neigh->addr;
+ else
+ addr = res->addr;
IRQ_LOCK(flags);
now = global_ms;
next = now;
- while (!cmdline_keypressed() || res->count == 0) {
+ while (!cmdline_keypressed() && res->count != 0) {
IRQ_LOCK(flags);
now = global_ms;
IRQ_UNLOCK(flags);
if (diff < res->period)
continue;
- rc_proto_send_hello(res->addr, res->data, strlen(res->data));
+ rc_proto_send_hello(addr, res->data, strlen(res->data));
next += res->period;
+ res->count--;
}
}
},
};
+const parse_token_neighbor_t PROGMEM cmd_send_hello_neigh =
+ TOKEN_NEIGHBOR_INITIALIZER(struct cmd_send_hello_result, neigh,
+ &xbee_dev);
+
+const parse_inst_t PROGMEM cmd_send_hello_name = {
+ .f = cmd_send_hello_parsed, /* function to call */
+ .data = (void *)1, /* 2nd arg of func */
+ .help_str = help_send_hello,
+ .tokens = { /* token list, NULL terminated */
+ (PGM_P)&cmd_send_hello_send_hello,
+ (PGM_P)&cmd_send_hello_neigh,
+ (PGM_P)&cmd_send_hello_period,
+ (PGM_P)&cmd_send_hello_count,
+ (PGM_P)&cmd_send_hello_data,
+ NULL,
+ },
+};
+
/* ************* */
/* this structure is filled when cmd_sendmsg_name is parsed successfully */
&cmd_write_u32,
&cmd_sendmsg,
&cmd_send_hello,
+ &cmd_send_hello_name,
&cmd_sendmsg_name,
&cmd_range,
&cmd_range_period,