mirror of
https://github.com/CTCaer/RetroArch.git
synced 2025-01-12 13:51:27 +00:00
netplay quick connect fixes
This commit is contained in:
parent
2be1355b57
commit
86e332038b
@ -2369,6 +2369,8 @@ MSG_HASH(MENU_ENUM_LABEL_VALUE_SCALE,
|
|||||||
"Scale")
|
"Scale")
|
||||||
MSG_HASH(MENU_ENUM_LABEL_VALUE_NETPLAY_START_WHEN_LOADED,
|
MSG_HASH(MENU_ENUM_LABEL_VALUE_NETPLAY_START_WHEN_LOADED,
|
||||||
"Netplay will start when content is loaded.")
|
"Netplay will start when content is loaded.")
|
||||||
|
MSG_HASH(MENU_ENUM_LABEL_VALUE_NETPLAY_LOAD_CONTENT_MANUALLY,
|
||||||
|
"Couldn't find a suitable core or content file, load manually.")
|
||||||
MSG_HASH(
|
MSG_HASH(
|
||||||
MENU_ENUM_LABEL_VALUE_BROWSE_URL_LIST,
|
MENU_ENUM_LABEL_VALUE_BROWSE_URL_LIST,
|
||||||
"Browse URL"
|
"Browse URL"
|
||||||
|
@ -1550,6 +1550,7 @@ enum msg_hash_enums
|
|||||||
MENU_ENUM_LABEL_VALUE_FILTER,
|
MENU_ENUM_LABEL_VALUE_FILTER,
|
||||||
MENU_ENUM_LABEL_VALUE_SCALE,
|
MENU_ENUM_LABEL_VALUE_SCALE,
|
||||||
MENU_ENUM_LABEL_VALUE_NETPLAY_START_WHEN_LOADED,
|
MENU_ENUM_LABEL_VALUE_NETPLAY_START_WHEN_LOADED,
|
||||||
|
MENU_ENUM_LABEL_VALUE_NETPLAY_LOAD_CONTENT_MANUALLY,
|
||||||
|
|
||||||
MSG_LAST
|
MSG_LAST
|
||||||
};
|
};
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "../playlist.h"
|
#include "../playlist.h"
|
||||||
#include "../command.h"
|
#include "../command.h"
|
||||||
#include "../core_info.h"
|
#include "../core_info.h"
|
||||||
|
#include "../../runloop.h"
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
@ -63,13 +64,25 @@ static void netplay_crc_scan_callback(void *task_data,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
command_event(CMD_EVENT_NETPLAY_INIT_DIRECT_DEFERRED, state->hostname);
|
if (!string_is_empty(info->list[i].path) && !string_is_empty(state->path))
|
||||||
task_push_content_load_default(
|
{
|
||||||
info->list[i].path, state->path,
|
command_event(CMD_EVENT_NETPLAY_INIT_DIRECT_DEFERRED, state->hostname);
|
||||||
&content_info,
|
task_push_content_load_default(
|
||||||
CORE_TYPE_PLAIN,
|
info->list[i].path, state->path,
|
||||||
CONTENT_MODE_LOAD_CONTENT_WITH_NEW_CORE_FROM_MENU,
|
&content_info,
|
||||||
NULL, NULL);
|
CORE_TYPE_PLAIN,
|
||||||
|
CONTENT_MODE_LOAD_CONTENT_WITH_NEW_CORE_FROM_MENU,
|
||||||
|
NULL, NULL);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* TO-DO: Inform the user no compatible core or content was found */
|
||||||
|
RARCH_LOG("Couldn't find a suitable %s\n",
|
||||||
|
string_is_empty(state->path) ? "content file" : "core");
|
||||||
|
runloop_msg_queue_push(
|
||||||
|
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_NETPLAY_LOAD_CONTENT_MANUALLY),
|
||||||
|
1, 480, true);
|
||||||
|
}
|
||||||
|
|
||||||
free(state);
|
free(state);
|
||||||
}
|
}
|
||||||
@ -95,7 +108,8 @@ static void task_netplay_crc_scan_handler(retro_task_t *task)
|
|||||||
if (state->lpl_list->size == 0)
|
if (state->lpl_list->size == 0)
|
||||||
goto no_playlists;
|
goto no_playlists;
|
||||||
|
|
||||||
if (atoi(state->crc) != 0)
|
/* content with no CRC uses 00000000*/
|
||||||
|
if (string_is_equal(state->path, "00000000"))
|
||||||
{
|
{
|
||||||
for (i = 0; i < state->lpl_list->size; i++)
|
for (i = 0; i < state->lpl_list->size; i++)
|
||||||
{
|
{
|
||||||
@ -109,6 +123,7 @@ static void task_netplay_crc_scan_handler(retro_task_t *task)
|
|||||||
{
|
{
|
||||||
for (j = 0; j < playlist->size; j++)
|
for (j = 0; j < playlist->size; j++)
|
||||||
{
|
{
|
||||||
|
printf("CRC Match %s\n", state->crc);
|
||||||
if (string_is_equal(playlist->entries[j].crc32, state->crc))
|
if (string_is_equal(playlist->entries[j].crc32, state->crc))
|
||||||
{
|
{
|
||||||
strlcpy(state->path, playlist->entries[j].path, sizeof(state->path));
|
strlcpy(state->path, playlist->entries[j].path, sizeof(state->path));
|
||||||
@ -142,7 +157,7 @@ static void task_netplay_crc_scan_handler(retro_task_t *task)
|
|||||||
/*printf("State: %s Entry: %s\n", state->path, playlist->entries[j].path);*/
|
/*printf("State: %s Entry: %s\n", state->path, playlist->entries[j].path);*/
|
||||||
if (strstr(playlist->entries[j].path, state->path))
|
if (strstr(playlist->entries[j].path, state->path))
|
||||||
{
|
{
|
||||||
printf("Match! %s %s\n", playlist->entries[j].path, state->path);
|
printf("Filename Match %s\n", state->path);
|
||||||
strlcpy(state->path, playlist->entries[j].path, sizeof(state->path));
|
strlcpy(state->path, playlist->entries[j].path, sizeof(state->path));
|
||||||
state->found = true;
|
state->found = true;
|
||||||
task_set_data(task, state);
|
task_set_data(task, state);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user