RetroArch/tasks/tasks.h

122 lines
3.2 KiB
C
Raw Normal View History

2015-05-05 15:36:58 +00:00
/* RetroArch - A frontend for libretro.
* Copyright (C) 2011-2015 - Daniel De Matteis
*
* RetroArch is free software: you can redistribute it and/or modify it under the terms
* of the GNU General Public License as published by the Free Software Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with RetroArch.
* If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef COMMON_TASKS_H
#define COMMON_TASKS_H
#include <stdint.h>
#include <boolean.h>
2015-07-08 20:14:31 +00:00
#include <queues/message_queue.h>
2015-05-05 15:36:58 +00:00
#include "../runloop_data.h"
2015-09-16 20:39:47 +00:00
#define MAX_TOKEN_LEN 255
2015-05-05 15:36:58 +00:00
#ifdef __cplusplus
extern "C" {
#endif
2015-11-22 23:15:42 +00:00
typedef struct rarch_task rarch_task_t;
typedef void (*rarch_task_callback_t)(void *task_data, void *user_data, const char *error);
typedef void (*rarch_task_handler_t)(rarch_task_t *task);
struct rarch_task {
rarch_task_handler_t handler;
rarch_task_callback_t callback; /* always called from the main loop */
/* set by the handler */
bool finished;
/* created by the handler, destroyed by the user */
void *task_data;
/* owned by the user */
void *user_data;
/* created and destroyed by the code related to the handler */
void *state;
/* created by task handler; destroyed by main loop (after calling the callback) */
char *error;
/* don't touch this. */
rarch_task_t *next;
};
/* MAIN THREAD ONLY */
void rarch_task_init(void);
void rarch_task_deinit(void);
void rarch_task_check(void);
/* MAIN AND TASK THREADS */
void rarch_task_push(rarch_task_t *task);
2015-05-05 15:36:58 +00:00
#ifdef HAVE_NETWORKING
/**
* rarch_main_data_http_iterate_transfer:
*
* Resumes HTTP transfer update.
*
* Returns: 0 when finished, -1 when we should continue
* with the transfer on the next frame.
**/
void rarch_main_data_http_iterate(bool is_thread);
2015-07-08 19:18:34 +00:00
msg_queue_t *rarch_main_data_http_get_msg_queue_ptr(void);
void rarch_main_data_http_init_msg_queue(void);
2015-07-08 19:35:24 +00:00
void *rarch_main_data_http_get_handle(void);
void *rarch_main_data_http_conn_get_handle(void);
2015-07-08 19:38:22 +00:00
void rarch_main_data_http_uninit(void);
2015-07-08 19:35:24 +00:00
void rarch_main_data_http_init(void);
2015-05-05 15:36:58 +00:00
#endif
#ifdef HAVE_RPNG
2015-11-23 03:17:27 +00:00
bool rarch_task_push_image_load(const char *fullpath, const char *type, rarch_task_callback_t cb);
#endif
#ifdef HAVE_LIBRETRODB
bool rarch_task_push_dbscan(const char *fullpath, bool directory, rarch_task_callback_t cb);
#endif
#ifdef HAVE_OVERLAY
2015-11-22 17:25:09 +00:00
void rarch_main_data_overlay_iterate(void);
#endif
void rarch_main_data_nbio_iterate(bool is_thread);
2015-05-05 15:36:58 +00:00
2015-06-02 16:28:51 +00:00
void data_runloop_osd_msg(const char *s, size_t len);
2015-05-05 15:36:58 +00:00
2015-09-16 20:39:47 +00:00
int find_first_data_track(const char* cue_path,
int32_t* offset, char* track_path, size_t max_len);
int detect_system(const char* track_path, int32_t offset,
const char** system_name);
int detect_ps1_game(const char *track_path, char *game_id);
2015-09-26 22:12:17 +00:00
int detect_psp_game(const char *track_path, char *game_id);
2015-05-05 15:36:58 +00:00
#ifdef __cplusplus
}
#endif
#endif