Fixed potential memory leak, added the music state and music info events type

This commit is contained in:
Th3maz1ng 2023-04-09 17:03:53 +02:00
parent b3bf6ce896
commit 5206181a32
3 changed files with 291 additions and 12 deletions

View File

@ -49,10 +49,18 @@ typedef enum gadget_bridge_parser_fsm
GADGET_BRIDGE_PARSER_FSM_FOUND_FIND, GADGET_BRIDGE_PARSER_FSM_FOUND_FIND,
GADGET_BRIDGE_PARSER_FSM_FOUND_ACT, GADGET_BRIDGE_PARSER_FSM_FOUND_ACT,
GADGET_BRIDGE_PARSER_FSM_FOUND_HRM,
GADGET_BRIDGE_PARSER_FSM_FOUND_STP, GADGET_BRIDGE_PARSER_FSM_FOUND_STP,
GADGET_BRIDGE_PARSER_FSM_FOUND_HRM_INT, GADGET_BRIDGE_PARSER_FSM_FOUND_HRM_INT,
GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICSTATE,
GADGET_BRIDGE_PARSER_FSM_FOUND_POSITION,
GADGET_BRIDGE_PARSER_FSM_FOUND_SHUFFLE,
GADGET_BRIDGE_PARSER_FSM_FOUND_REPEAT,
GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICINFO,
GADGET_BRIDGE_PARSER_FSM_FOUND_TRACK,
GADGET_BRIDGE_PARSER_FSM_FOUND_DURATION,
GADGET_BRIDGE_PARSER_FSM_ERROR, GADGET_BRIDGE_PARSER_FSM_ERROR,
} gadget_bridge_parser_fsm_e; } gadget_bridge_parser_fsm_e;
@ -226,6 +234,7 @@ static bool _parser_extract_handle(char *start, char *end);
static void _parser_extract_src(char *start, char *end); static void _parser_extract_src(char *start, char *end);
static void _parser_extract_char_str(char *start, char *end, char **data); static void _parser_extract_char_str(char *start, char *end, char **data);
static void _parser_extract_cmd(char *start, char *end); static void _parser_extract_cmd(char *start, char *end);
static void _parser_extract_state(char *start, char *end);
static bool _parser_extract_uint8_t(char *start, char *end, uint8_t *data); static bool _parser_extract_uint8_t(char *start, char *end, uint8_t *data);
static bool _parser_extract_float(char *start, char *end, float *data); static bool _parser_extract_float(char *start, char *end, float *data);
static bool _parser_extract_uint16_t(char *start, char *end, uint16_t *data); static bool _parser_extract_uint16_t(char *start, char *end, uint16_t *data);
@ -352,7 +361,29 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
); );
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_ACT; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_ACT;
} }
// If we did not find the rest but found GB again, the some payload was lost... else if((start = strstr(_gadget_bridge_internals.buffer, "t:\"musicstate\",")))
{
//printf("###Found musicstate\n");
_gadget_bridge_internals.event_data.event_type = GADGET_BRIDGE_EVENT_TYPE_MUSIC_STATE;
// We remove the parsed part from the buffer
start += 15;
_parser_free_buffer(
start -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICSTATE;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "t:\"musicinfo\",")))
{
//printf("###Found musicinfo\n");
_gadget_bridge_internals.event_data.event_type = GADGET_BRIDGE_EVENT_TYPE_MUSIC_INFO;
// We remove the parsed part from the buffer
start += 14;
_parser_free_buffer(
start -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICINFO;
}
// If we did not find the rest but found GB again, then some payload was lost...
else if((start = strstr(_gadget_bridge_internals.buffer, "GB("))) else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD) else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
@ -472,7 +503,7 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
case GADGET_BRIDGE_PARSER_FSM_FOUND_SRC_BODY: case GADGET_BRIDGE_PARSER_FSM_FOUND_SRC_BODY:
if((start = strstr(_gadget_bridge_internals.buffer, "body:"))) if((start = strstr(_gadget_bridge_internals.buffer, "body:")))
{ {
//printf("###Parsing body content\n"); //printf("###Parsing BODY content\n");
// We remove the : "body":" part // We remove the : "body":" part
start += 6; start += 6;
@ -506,9 +537,11 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
if(_gadget_bridge_internals.parser_event_callback) if(_gadget_bridge_internals.parser_event_callback)
{ {
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data); _gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
// Free the allocated data
_free_event_data();
} }
// Free the allocated data
_free_event_data();
// The end of the road for this object // The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
} }
@ -530,9 +563,11 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
if(_gadget_bridge_internals.parser_event_callback) if(_gadget_bridge_internals.parser_event_callback)
{ {
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data); _gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
// Free the allocated data
_free_event_data();
} }
// Free the allocated data
_free_event_data();
// The end of the road for this object // The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
} }
@ -653,9 +688,11 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
if(_gadget_bridge_internals.parser_event_callback) if(_gadget_bridge_internals.parser_event_callback)
{ {
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data); _gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
// Free the allocated data
_free_event_data();
} }
// Free the allocated data
_free_event_data();
// The end of the road for this object // The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
} }
@ -788,9 +825,11 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
if(_gadget_bridge_internals.parser_event_callback) if(_gadget_bridge_internals.parser_event_callback)
{ {
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data); _gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
// Free the allocated data
_free_event_data();
} }
// Free the allocated data
_free_event_data();
// The end of the road for this object // The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE; _gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
} }
@ -895,6 +934,165 @@ gadget_bridge_parser_code_e gadget_bridge_parser_run(void)
free_some_space = true; free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK; else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break; break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICSTATE:
if((start = strstr(_gadget_bridge_internals.buffer, "state:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",position")))
{
//printf("###Found POSITION\n");
_parser_extract_state(start + 7, end - 1);
// We remove the parsed part from the buffer
end += 1;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_POSITION;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_POSITION:
if((start = strstr(_gadget_bridge_internals.buffer, "position:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",shuffle")))
{
//printf("###Found SHUFFLE\n");
_parser_extract_uint16_t(start + 9, end, &_gadget_bridge_internals.event_data.music_state.position_in_seconds);
// We remove the parsed part from the buffer
end += 1;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_SHUFFLE;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_SHUFFLE:
if((start = strstr(_gadget_bridge_internals.buffer, "shuffle:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",repeat")))
{
//printf("###Found REPEAT\n");
_parser_extract_uint8_t(start + 8, end, &_gadget_bridge_internals.event_data.music_state.shuffle);
// We remove the parsed part from the buffer
end += 1;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_REPEAT;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_REPEAT:
if((start = strstr(_gadget_bridge_internals.buffer, "repeat:"))
&& (end = strstr(_gadget_bridge_internals.buffer, "})")))
{
//printf("###MUSICSTATE Type done\n");
_parser_extract_uint8_t(start + 7, end, &_gadget_bridge_internals.event_data.music_state.repeat);
// We remove the parsed part from the buffer
end += 2;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
// If a callback was registered, we call it and pass the data to it
if(_gadget_bridge_internals.parser_event_callback)
{
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
}
// The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_MUSICINFO:
if((start = strstr(_gadget_bridge_internals.buffer, "artist:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",track")))
{
//printf("###Found TRACK\n");
_parser_extract_char_str(start + 8, end - 1, &_gadget_bridge_internals.event_data.music_info.artist);
// We remove the parsed part from the buffer
end += 1;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_TRACK;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_TRACK:
if((start = strstr(_gadget_bridge_internals.buffer, "track:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",dur")))
{
//printf("###Found DURATION\n");
_parser_extract_char_str(start + 7, end - 1, &_gadget_bridge_internals.event_data.music_info.track);
// We remove the parsed part from the buffer
end += 1;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_FOUND_DURATION;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_FOUND_DURATION:
if((start = strstr(_gadget_bridge_internals.buffer, "dur:"))
&& (end = strstr(_gadget_bridge_internals.buffer, ",c")))
{
//printf("###MUSICINFO Type done\n");
_parser_extract_uint16_t(start + 4, end, &_gadget_bridge_internals.event_data.music_info.duration_in_seconds);
// We remove the parsed part from the buffer
end += 2;
_parser_free_buffer(
end -_gadget_bridge_internals.buffer
);
// If a callback was registered, we call it and pass the data to it
if(_gadget_bridge_internals.parser_event_callback)
{
_gadget_bridge_internals.parser_event_callback(&_gadget_bridge_internals.event_data);
}
// Free the allocated data
_free_event_data();
// The end of the road for this object
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
}
else if((start = strstr(_gadget_bridge_internals.buffer, "GB(")))
_gadget_bridge_internals.gadget_bridge_parser_fsm = GADGET_BRIDGE_PARSER_FSM_NEW_MESSAGE;
else if(_gadget_bridge_internals.buffer_content_size > GADGET_BRIDGE_PARSER_BUFFER_THRESHOLD)
free_some_space = true;
else to_return = GADGET_BRIDGE_PARSER_CODE_OK;
break;
case GADGET_BRIDGE_PARSER_FSM_ERROR: case GADGET_BRIDGE_PARSER_FSM_ERROR:
//printf("###Parser error\n"); //printf("###Parser error\n");
default: default:
@ -940,6 +1138,8 @@ const char *gadget_bridge_event_type_2_str(gadget_bridge_event_type_e event_type
CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_WEATHER) CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_WEATHER)
CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_FIND) CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_FIND)
CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_ACT) CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_ACT)
CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_MUSIC_INFO)
CASE_RETURN_STR(GADGET_BRIDGE_EVENT_TYPE_MUSIC_STATE)
default: default:
return "Unknown event type"; return "Unknown event type";
} }
@ -957,6 +1157,18 @@ const char *gadget_bridge_notification_type_2_str(gadget_bridge_notification_typ
} }
} }
const char *gadget_bridge_music_state_2_str(gadget_bridge_music_state_e music_state)
{
switch(music_state)
{
CASE_RETURN_STR(GADGET_BRIDGE_MUSIC_STATE_PAUSE)
CASE_RETURN_STR(GADGET_BRIDGE_MUSIC_STATE_PLAY)
CASE_RETURN_STR(GADGET_BRIDGE_MUSIC_STATE_UNKNOWN)
default:
return "Unknown music state";
}
}
void gadget_bridge_parser_debug(void) void gadget_bridge_parser_debug(void)
{ {
//printf("Buffer size : %u\nBuffer content : #%s#\n", _gadget_bridge_internals.buffer_content_size, _gadget_bridge_internals.buffer); //printf("Buffer size : %u\nBuffer content : #%s#\n", _gadget_bridge_internals.buffer_content_size, _gadget_bridge_internals.buffer);
@ -1142,6 +1354,20 @@ static void _parser_extract_cmd(char *start, char *end)
//printf("###Commande is : %s\n", start); //printf("###Commande is : %s\n", start);
} }
static void _parser_extract_state(char *start, char *end)
{
*end = '\0';
if(strcmp(start, "play") == 0)
_gadget_bridge_internals.event_data.music_state.music_state = GADGET_BRIDGE_MUSIC_STATE_PLAY;
else if(strcmp(start, "pause") == 0)
_gadget_bridge_internals.event_data.music_state.music_state = GADGET_BRIDGE_MUSIC_STATE_PAUSE;
else
_gadget_bridge_internals.event_data.music_state.music_state = GADGET_BRIDGE_MUSIC_STATE_UNKNOWN;
//printf("###State is : %s\n", start);
}
static bool _parser_extract_bool(char *start, char *end, bool *data) static bool _parser_extract_bool(char *start, char *end, bool *data)
{ {
*end = '\0'; *end = '\0';
@ -1186,6 +1412,12 @@ static void _free_event_data(void)
tls_mem_free(_gadget_bridge_internals.event_data.weather.weather_desc); tls_mem_free(_gadget_bridge_internals.event_data.weather.weather_desc);
_gadget_bridge_internals.event_data.weather.weather_desc = NULL; _gadget_bridge_internals.event_data.weather.weather_desc = NULL;
break; break;
case GADGET_BRIDGE_EVENT_TYPE_MUSIC_INFO:
tls_mem_free(_gadget_bridge_internals.event_data.music_info.artist);
_gadget_bridge_internals.event_data.music_info.artist = NULL;
tls_mem_free(_gadget_bridge_internals.event_data.music_info.track);
_gadget_bridge_internals.event_data.music_info.track = NULL;
break;
default: default:
break; break;
} }

View File

@ -120,6 +120,8 @@ typedef enum gadget_bridge_event_type
GADGET_BRIDGE_EVENT_TYPE_WEATHER, GADGET_BRIDGE_EVENT_TYPE_WEATHER,
GADGET_BRIDGE_EVENT_TYPE_FIND, GADGET_BRIDGE_EVENT_TYPE_FIND,
GADGET_BRIDGE_EVENT_TYPE_ACT, GADGET_BRIDGE_EVENT_TYPE_ACT,
GADGET_BRIDGE_EVENT_TYPE_MUSIC_INFO,
GADGET_BRIDGE_EVENT_TYPE_MUSIC_STATE,
GADGET_BRIDGE_EVENT_TYPE_UNKNOWN, GADGET_BRIDGE_EVENT_TYPE_UNKNOWN,
} gadget_bridge_event_type_e; } gadget_bridge_event_type_e;
@ -130,6 +132,13 @@ typedef enum gadget_bridge_notification_type
GADGET_BRIDGE_NOTIFICATION_TYPE_UNKNOWN, GADGET_BRIDGE_NOTIFICATION_TYPE_UNKNOWN,
} gadget_bridge_notification_type_e; } gadget_bridge_notification_type_e;
typedef enum
{
GADGET_BRIDGE_MUSIC_STATE_PAUSE = 0,
GADGET_BRIDGE_MUSIC_STATE_PLAY,
GADGET_BRIDGE_MUSIC_STATE_UNKNOWN,
} gadget_bridge_music_state_e;
typedef struct gadget_bridge_event_data typedef struct gadget_bridge_event_data
{ {
gadget_bridge_event_type_e event_type; gadget_bridge_event_type_e event_type;
@ -173,6 +182,19 @@ typedef struct gadget_bridge_event_data
bool steps; bool steps;
uint8_t heart_rate_interval; uint8_t heart_rate_interval;
} act; } act;
struct
{
gadget_bridge_music_state_e music_state;
uint16_t position_in_seconds;
uint8_t shuffle;
uint8_t repeat;
} music_state;
struct
{
char *artist;
char *track;
uint16_t duration_in_seconds;
} music_info;
}; };
} gadget_bridge_event_data_t; } gadget_bridge_event_data_t;
@ -292,6 +314,8 @@ const char *gadget_bridge_event_type_2_str(gadget_bridge_event_type_e event_type
const char *gadget_bridge_notification_type_2_str(gadget_bridge_notification_type_e notification_type); const char *gadget_bridge_notification_type_2_str(gadget_bridge_notification_type_e notification_type);
const char *gadget_bridge_music_state_2_str(gadget_bridge_music_state_e music_state);
void gadget_bridge_parser_debug(void); void gadget_bridge_parser_debug(void);
#endif //GADGET_BRIDGE_H #endif //GADGET_BRIDGE_H

View File

@ -147,6 +147,19 @@ static void parser_event_cb(const gadget_bridge_event_data_t *gadget_bridge_even
gadget_bridge_event_data->act.steps, gadget_bridge_event_data->act.steps,
gadget_bridge_event_data->act.heart_rate_interval); gadget_bridge_event_data->act.heart_rate_interval);
break; break;
case GADGET_BRIDGE_EVENT_TYPE_MUSIC_STATE:
shell_printf("%s\n%u\n%u\n%u\n",
gadget_bridge_music_state_2_str(gadget_bridge_event_data->music_state.music_state),
gadget_bridge_event_data->music_state.position_in_seconds,
gadget_bridge_event_data->music_state.shuffle,
gadget_bridge_event_data->music_state.repeat);
break;
case GADGET_BRIDGE_EVENT_TYPE_MUSIC_INFO:
shell_printf("%s\n%s\n%u\n",
gadget_bridge_event_data->music_info.artist,
gadget_bridge_event_data->music_info.track,
gadget_bridge_event_data->music_info.duration_in_seconds);
break;
default: default:
shell_printf("Unhandled\n"); shell_printf("Unhandled\n");
} }
@ -748,10 +761,20 @@ int _bluetooth(const shell_cmd_t *pcmd, int argc, char *const argv[])
{ {
to_return = gadget_bridge_send_activity_data(atoi(argv[3]), atoi(argv[4])); to_return = gadget_bridge_send_activity_data(atoi(argv[3]), atoi(argv[4]));
} }
/*else if(strcmp(argv[2], "calendar") == 0 && argc == 3)
{
to_return = gadget_bridge_send_force_calendar_sync();
}*/
else if(strcmp(argv[2], "http") == 0 && argc == 6)
{
to_return = gadget_bridge_send_http_request(atoi(argv[3]), argv[4], GADGET_BRIDGE_HTTP_REQUEST_GET, NULL, NULL);
}
else else
{ {
shell_printf("Unknown %s action, list of send_ble_notif actions :"NEW_LINE"toast info|warn|error \"msg\""NEW_LINE"bat \"XX%%\" 1|0 X.X"NEW_LINE"find_phone true|false"NEW_LINE"music play|pause|playpause|previous|next|volumeup|volumedown|forward|rewind"NEW_LINE"notify reply|dismiss_all id \"tel\" \"msg\""NEW_LINE shell_printf("Unknown %s action, list of send_ble_notif actions :"NEW_LINE"toast info|warn|error \"msg\""NEW_LINE"bat \"XX%%\" 1|0 X.X"NEW_LINE"find_phone true|false"NEW_LINE"music play|pause|playpause|previous|next|volumeup|volumedown|forward|rewind"NEW_LINE"notify reply|dismiss_all id \"tel\" \"msg\""NEW_LINE
"act hrm steps"NEW_LINE, argv[2]); "act hrm steps"NEW_LINE
"ver \"version 1\" \"version 2\""NEW_LINE
, argv[2]);
} }
shell_printf("Sending ble ntf : %d"NEW_LINE, to_return); shell_printf("Sending ble ntf : %d"NEW_LINE, to_return);