mirror of
https://github.com/libretro/RetroArch
synced 2025-04-03 10:21:31 +00:00
Merge remote-tracking branch 'refs/remotes/libretro/master' into wiiu_controller_patcher
This commit is contained in:
commit
a8a2d7730f
12
command.c
12
command.c
@ -90,7 +90,6 @@
|
|||||||
|
|
||||||
struct command
|
struct command
|
||||||
{
|
{
|
||||||
bool local_enable;
|
|
||||||
#ifdef HAVE_STDIN_CMD
|
#ifdef HAVE_STDIN_CMD
|
||||||
bool stdin_enable;
|
bool stdin_enable;
|
||||||
char stdin_buf[STDIN_BUF_SIZE];
|
char stdin_buf[STDIN_BUF_SIZE];
|
||||||
@ -157,8 +156,7 @@ struct cmd_action_map
|
|||||||
const char *arg_desc;
|
const char *arg_desc;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef HAVE_COMMAND
|
bool command_set_shader(const char *arg)
|
||||||
static bool command_set_shader(const char *arg)
|
|
||||||
{
|
{
|
||||||
char msg[256];
|
char msg[256];
|
||||||
enum rarch_shader_type type = RARCH_SHADER_NONE;
|
enum rarch_shader_type type = RARCH_SHADER_NONE;
|
||||||
@ -190,7 +188,7 @@ static bool command_set_shader(const char *arg)
|
|||||||
return video_driver_set_shader(type, arg);
|
return video_driver_set_shader(type, arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_COMMAND
|
||||||
#ifdef HAVE_CHEEVOS
|
#ifdef HAVE_CHEEVOS
|
||||||
static bool command_read_ram(const char *arg)
|
static bool command_read_ram(const char *arg)
|
||||||
{
|
{
|
||||||
@ -541,14 +539,12 @@ static bool command_stdin_init(command_t *handle)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
command_t *command_new(bool local_enable)
|
command_t *command_new(void)
|
||||||
{
|
{
|
||||||
command_t *handle = (command_t*)calloc(1, sizeof(*handle));
|
command_t *handle = (command_t*)calloc(1, sizeof(*handle));
|
||||||
if (!handle)
|
if (!handle)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
handle->local_enable = local_enable;
|
|
||||||
|
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -631,8 +627,6 @@ static void command_stdin_poll(command_t *handle)
|
|||||||
|
|
||||||
bool command_poll(command_t *handle)
|
bool command_poll(command_t *handle)
|
||||||
{
|
{
|
||||||
memset(handle->state, 0, sizeof(handle->state));
|
|
||||||
|
|
||||||
#if defined(HAVE_NETWORKING) && defined(HAVE_NETWORK_CMD)
|
#if defined(HAVE_NETWORKING) && defined(HAVE_NETWORK_CMD)
|
||||||
#ifdef HAVE_COMMAND
|
#ifdef HAVE_COMMAND
|
||||||
command_network_poll(handle);
|
command_network_poll(handle);
|
||||||
|
@ -221,6 +221,8 @@ enum event_command
|
|||||||
CMD_EVENT_RESTORE_DEFAULT_SHADER_PRESET
|
CMD_EVENT_RESTORE_DEFAULT_SHADER_PRESET
|
||||||
};
|
};
|
||||||
|
|
||||||
|
bool command_set_shader(const char *arg);
|
||||||
|
|
||||||
#ifdef HAVE_COMMAND
|
#ifdef HAVE_COMMAND
|
||||||
#if defined(HAVE_NETWORKING) && defined(HAVE_NETWORK_CMD)
|
#if defined(HAVE_NETWORKING) && defined(HAVE_NETWORK_CMD)
|
||||||
bool command_network_send(const char *cmd_);
|
bool command_network_send(const char *cmd_);
|
||||||
@ -233,7 +235,7 @@ bool command_network_new(
|
|||||||
bool network_enable,
|
bool network_enable,
|
||||||
uint16_t port);
|
uint16_t port);
|
||||||
|
|
||||||
command_t *command_new(bool local_enable);
|
command_t *command_new(void);
|
||||||
|
|
||||||
bool command_poll(command_t *handle);
|
bool command_poll(command_t *handle);
|
||||||
|
|
||||||
|
40
dirs.c
40
dirs.c
@ -23,10 +23,10 @@
|
|||||||
#include <retro_stat.h>
|
#include <retro_stat.h>
|
||||||
|
|
||||||
#include "dirs.h"
|
#include "dirs.h"
|
||||||
|
#include "command.h"
|
||||||
#include "configuration.h"
|
#include "configuration.h"
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
#include "defaults.h"
|
#include "defaults.h"
|
||||||
#include "gfx/video_driver.h"
|
|
||||||
#include "list_special.h"
|
#include "list_special.h"
|
||||||
#include "file_path_special.h"
|
#include "file_path_special.h"
|
||||||
#include "msg_hash.h"
|
#include "msg_hash.h"
|
||||||
@ -108,9 +108,6 @@ bool dir_free_shader(void)
|
|||||||
**/
|
**/
|
||||||
void dir_check_shader(bool pressed_next, bool pressed_prev)
|
void dir_check_shader(bool pressed_next, bool pressed_prev)
|
||||||
{
|
{
|
||||||
char msg[128];
|
|
||||||
const char *shader = NULL;
|
|
||||||
enum rarch_shader_type type = RARCH_SHADER_NONE;
|
|
||||||
struct rarch_dir_list *dir_list = (struct rarch_dir_list*)&dir_shader_list;
|
struct rarch_dir_list *dir_list = (struct rarch_dir_list*)&dir_shader_list;
|
||||||
|
|
||||||
if (!dir_list || !dir_list->list)
|
if (!dir_list || !dir_list->list)
|
||||||
@ -131,40 +128,7 @@ void dir_check_shader(bool pressed_next, bool pressed_prev)
|
|||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
|
|
||||||
shader = dir_list->list->elems[dir_list->ptr].data;
|
command_set_shader(dir_list->list->elems[dir_list->ptr].data);
|
||||||
|
|
||||||
switch (msg_hash_to_file_type(msg_hash_calculate(
|
|
||||||
path_get_extension(shader))))
|
|
||||||
{
|
|
||||||
case FILE_TYPE_SHADER_GLSL:
|
|
||||||
case FILE_TYPE_SHADER_PRESET_GLSLP:
|
|
||||||
type = RARCH_SHADER_GLSL;
|
|
||||||
break;
|
|
||||||
case FILE_TYPE_SHADER_SLANG:
|
|
||||||
case FILE_TYPE_SHADER_PRESET_SLANGP:
|
|
||||||
type = RARCH_SHADER_SLANG;
|
|
||||||
break;
|
|
||||||
case FILE_TYPE_SHADER_CG:
|
|
||||||
case FILE_TYPE_SHADER_PRESET_CGP:
|
|
||||||
type = RARCH_SHADER_CG;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
msg[0] = '\0';
|
|
||||||
|
|
||||||
snprintf(msg, sizeof(msg), "%s #%u: \"%s\".",
|
|
||||||
msg_hash_to_str(MSG_SHADER),
|
|
||||||
(unsigned)dir_list->ptr, shader);
|
|
||||||
runloop_msg_queue_push(msg, 2, 120, true);
|
|
||||||
|
|
||||||
RARCH_LOG("%s \"%s\".\n",
|
|
||||||
msg_hash_to_str(MSG_APPLYING_SHADER),
|
|
||||||
shader);
|
|
||||||
|
|
||||||
if (!video_driver_set_shader(type, shader))
|
|
||||||
RARCH_WARN("%s\n", msg_hash_to_str(MSG_FAILED_TO_APPLY_SHADER));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* empty functions */
|
/* empty functions */
|
||||||
|
@ -886,14 +886,8 @@ static bool d3d_alive(void *data)
|
|||||||
|
|
||||||
if (resize)
|
if (resize)
|
||||||
{
|
{
|
||||||
gfx_ctx_mode_t mode;
|
|
||||||
|
|
||||||
d3d->should_resize = true;
|
d3d->should_resize = true;
|
||||||
|
video_driver_set_resize(temp_width, temp_height);
|
||||||
mode.width = temp_width;
|
|
||||||
mode.height = temp_height;
|
|
||||||
|
|
||||||
current_video_context.set_resize(video_context_data, mode.width, mode.height);
|
|
||||||
d3d_restore(d3d);
|
d3d_restore(d3d);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -411,6 +411,12 @@ static bool set_resize_null(void *a, unsigned b, unsigned c)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void video_driver_set_resize(unsigned width, unsigned height)
|
||||||
|
{
|
||||||
|
if (current_video_context.set_resize)
|
||||||
|
current_video_context.set_resize(video_context_data, width, height);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* video_driver_find_handle:
|
* video_driver_find_handle:
|
||||||
* @idx : index of driver to get handle to.
|
* @idx : index of driver to get handle to.
|
||||||
|
@ -1066,6 +1066,8 @@ void video_driver_set_threaded(bool val);
|
|||||||
void video_driver_get_status(uint64_t *frame_count, bool * is_alive,
|
void video_driver_get_status(uint64_t *frame_count, bool * is_alive,
|
||||||
bool *is_focused);
|
bool *is_focused);
|
||||||
|
|
||||||
|
void video_driver_set_resize(unsigned width, unsigned height);
|
||||||
|
|
||||||
extern video_driver_t video_gl;
|
extern video_driver_t video_gl;
|
||||||
extern video_driver_t video_vulkan;
|
extern video_driver_t video_vulkan;
|
||||||
extern video_driver_t video_psp1;
|
extern video_driver_t video_psp1;
|
||||||
|
@ -1183,7 +1183,7 @@ bool input_driver_init_command(void)
|
|||||||
"Cannot use this command interface.\n");
|
"Cannot use this command interface.\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
input_driver_command = command_new(false);
|
input_driver_command = command_new();
|
||||||
|
|
||||||
if (command_network_new(
|
if (command_network_new(
|
||||||
input_driver_command,
|
input_driver_command,
|
||||||
|
@ -65,23 +65,6 @@ void dir_list_sort(struct string_list *list, bool dir_first);
|
|||||||
**/
|
**/
|
||||||
void dir_list_free(struct string_list *list);
|
void dir_list_free(struct string_list *list);
|
||||||
|
|
||||||
/**
|
|
||||||
* dir_list_read:
|
|
||||||
* @dir : directory path.
|
|
||||||
* @list : the string list to add files to
|
|
||||||
* @ext_list : the string list of extensions to include
|
|
||||||
* @include_dirs : include directories as part of the finished directory listing?
|
|
||||||
* @include_hidden : include hidden files and directories as part of the finished directory listing?
|
|
||||||
* @include_compressed : Only include files which match ext. Do not try to match compressed files, etc.
|
|
||||||
* @recursive : list directory contents recursively
|
|
||||||
*
|
|
||||||
* Add files within a directory to an existing string list
|
|
||||||
*
|
|
||||||
* Returns: -1 on error, 0 on success.
|
|
||||||
**/
|
|
||||||
int dir_list_read(const char *dir, struct string_list *list, struct string_list *ext_list,
|
|
||||||
bool include_dirs, bool include_hidden, bool include_compressed, bool recursive);
|
|
||||||
|
|
||||||
RETRO_END_DECLS
|
RETRO_END_DECLS
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -124,7 +124,8 @@ static int parse_dir_entry(const char *name, char *file_path,
|
|||||||
if (!include_dirs && is_dir)
|
if (!include_dirs && is_dir)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if (string_is_equal_fast(name, ".", 1) || string_is_equal_fast(name, "..", 2))
|
if ((name[0] == '.' && name[1] == '\0') ||
|
||||||
|
(name[0] == '.' && name[1] == '.' && name[2] == '\0'))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if (!is_dir && ext_list &&
|
if (!is_dir && ext_list &&
|
||||||
@ -153,46 +154,6 @@ static int parse_dir_entry(const char *name, char *file_path,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* dir_list_new:
|
|
||||||
* @dir : directory path.
|
|
||||||
* @ext : allowed extensions of file directory entries to include.
|
|
||||||
* @include_dirs : include directories as part of the finished directory listing?
|
|
||||||
* @include_hidden : include hidden files and directories as part of the finished directory listing?
|
|
||||||
* @include_compressed : Only include files which match ext. Do not try to match compressed files, etc.
|
|
||||||
* @recursive : list directory contents recursively
|
|
||||||
*
|
|
||||||
* Create a directory listing.
|
|
||||||
*
|
|
||||||
* Returns: pointer to a directory listing of type 'struct string_list *' on success,
|
|
||||||
* NULL in case of error. Has to be freed manually.
|
|
||||||
**/
|
|
||||||
struct string_list *dir_list_new(const char *dir,
|
|
||||||
const char *ext, bool include_dirs,
|
|
||||||
bool include_hidden, bool include_compressed,
|
|
||||||
bool recursive)
|
|
||||||
{
|
|
||||||
struct string_list *ext_list = NULL;
|
|
||||||
struct string_list *list = NULL;
|
|
||||||
|
|
||||||
if (!(list = string_list_new()))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (ext)
|
|
||||||
ext_list = string_split(ext, "|");
|
|
||||||
|
|
||||||
if(dir_list_read(dir, list, ext_list, include_dirs,
|
|
||||||
include_hidden, include_compressed, recursive) == -1)
|
|
||||||
{
|
|
||||||
string_list_free(list);
|
|
||||||
string_list_free(ext_list);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
string_list_free(ext_list);
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* dir_list_read:
|
* dir_list_read:
|
||||||
* @dir : directory path.
|
* @dir : directory path.
|
||||||
@ -207,7 +168,7 @@ struct string_list *dir_list_new(const char *dir,
|
|||||||
*
|
*
|
||||||
* Returns: -1 on error, 0 on success.
|
* Returns: -1 on error, 0 on success.
|
||||||
**/
|
**/
|
||||||
int dir_list_read(const char *dir,
|
static int dir_list_read(const char *dir,
|
||||||
struct string_list *list, struct string_list *ext_list,
|
struct string_list *list, struct string_list *ext_list,
|
||||||
bool include_dirs, bool include_hidden,
|
bool include_dirs, bool include_hidden,
|
||||||
bool include_compressed, bool recursive)
|
bool include_compressed, bool recursive)
|
||||||
@ -275,3 +236,44 @@ int dir_list_read(const char *dir,
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* dir_list_new:
|
||||||
|
* @dir : directory path.
|
||||||
|
* @ext : allowed extensions of file directory entries to include.
|
||||||
|
* @include_dirs : include directories as part of the finished directory listing?
|
||||||
|
* @include_hidden : include hidden files and directories as part of the finished directory listing?
|
||||||
|
* @include_compressed : Only include files which match ext. Do not try to match compressed files, etc.
|
||||||
|
* @recursive : list directory contents recursively
|
||||||
|
*
|
||||||
|
* Create a directory listing.
|
||||||
|
*
|
||||||
|
* Returns: pointer to a directory listing of type 'struct string_list *' on success,
|
||||||
|
* NULL in case of error. Has to be freed manually.
|
||||||
|
**/
|
||||||
|
struct string_list *dir_list_new(const char *dir,
|
||||||
|
const char *ext, bool include_dirs,
|
||||||
|
bool include_hidden, bool include_compressed,
|
||||||
|
bool recursive)
|
||||||
|
{
|
||||||
|
struct string_list *ext_list = NULL;
|
||||||
|
struct string_list *list = NULL;
|
||||||
|
|
||||||
|
if (!(list = string_list_new()))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (ext)
|
||||||
|
ext_list = string_split(ext, "|");
|
||||||
|
|
||||||
|
if(dir_list_read(dir, list, ext_list, include_dirs,
|
||||||
|
include_hidden, include_compressed, recursive) == -1)
|
||||||
|
{
|
||||||
|
string_list_free(list);
|
||||||
|
string_list_free(ext_list);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
string_list_free(ext_list);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stddef.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
@ -32,6 +34,8 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <boolean.h>
|
||||||
|
|
||||||
#if defined(_WIN32) && defined(_XBOX)
|
#if defined(_WIN32) && defined(_XBOX)
|
||||||
size_t read_stdin(char *buf, size_t size)
|
size_t read_stdin(char *buf, size_t size)
|
||||||
{
|
{
|
||||||
|
13
retroarch.c
13
retroarch.c
@ -1093,20 +1093,15 @@ bool retroarch_validate_game_options(char *s, size_t len, bool mkdir)
|
|||||||
{
|
{
|
||||||
char core_path[PATH_MAX_LENGTH];
|
char core_path[PATH_MAX_LENGTH];
|
||||||
char config_directory[PATH_MAX_LENGTH];
|
char config_directory[PATH_MAX_LENGTH];
|
||||||
const char *core_name = NULL;
|
|
||||||
const char *game_name = NULL;
|
|
||||||
rarch_system_info_t *system = runloop_get_system_info();
|
rarch_system_info_t *system = runloop_get_system_info();
|
||||||
|
const char *core_name = system ? system->info.library_name : NULL;
|
||||||
config_directory[0] = core_path[0] = '\0';
|
const char *game_name = path_basename(path_get(RARCH_PATH_BASENAME));
|
||||||
|
|
||||||
if (system)
|
|
||||||
core_name = system->info.library_name;
|
|
||||||
|
|
||||||
game_name = path_basename(path_get(RARCH_PATH_BASENAME));
|
|
||||||
|
|
||||||
if (string_is_empty(core_name) || string_is_empty(game_name))
|
if (string_is_empty(core_name) || string_is_empty(game_name))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
config_directory[0] = core_path[0] = '\0';
|
||||||
|
|
||||||
fill_pathname_application_special(config_directory,
|
fill_pathname_application_special(config_directory,
|
||||||
sizeof(config_directory),
|
sizeof(config_directory),
|
||||||
APPLICATION_SPECIAL_DIRECTORY_CONFIG);
|
APPLICATION_SPECIAL_DIRECTORY_CONFIG);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user