netplay quick connect fixes

This commit is contained in:
radius 2017-01-22 22:45:48 -05:00
parent 2be1355b57
commit 86e332038b
3 changed files with 28 additions and 10 deletions

View File

@ -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"

View File

@ -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
}; };

View File

@ -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);