2016-07-27 09:39:03 +02:00
|
|
|
#pragma once
|
|
|
|
#include <wut.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \defgroup proc_ui_procui ProcUI
|
|
|
|
* \ingroup proc_ui
|
2018-06-25 03:01:01 +02:00
|
|
|
*
|
|
|
|
* The ProcUI group of functions provide an interface to manage transitions
|
|
|
|
* between the different states of an application.
|
|
|
|
*
|
|
|
|
* After calling ProcUIInit() or ProcUIInitEx(), an application may call
|
|
|
|
* ProcUIProcessMessages() to process and update its state. These states may
|
|
|
|
* include:
|
|
|
|
* - #PROCUI_STATUS_IN_FOREGROUND - The default state of an application. All
|
|
|
|
* system resources and hardware is available, and the application runs
|
|
|
|
* without any serious restrictions.
|
|
|
|
* - #PROCUI_STATUS_IN_BACKGROUND - When the user instructs the OS to switch
|
|
|
|
* to a secondary application (HOME menu overlay, Internet Browser, etc.) the
|
|
|
|
* application enters this background state. Background applications are
|
|
|
|
* heavily restricted - they get a small amount of CPU time on core 2 (all
|
|
|
|
* other threads are suspended), access to filesystems, and some network IO.
|
|
|
|
* They have no access to graphics, inputs or user interaction of any kind.
|
|
|
|
* - #PROCUI_STATUS_RELEASE_FOREGROUND - The user has requested a foreground
|
|
|
|
* switch. The current application must release all foreground-only resources,
|
|
|
|
* calling ProcUIDrawDoneRelease() when it's ready to go into the background.
|
|
|
|
* - #PROCUI_STATUS_EXITING - The application must release all resources, call
|
|
|
|
* ProcUIShutdown(), and exit.
|
|
|
|
*
|
|
|
|
* An application can determine its state by either examining
|
|
|
|
* ProcUIProcessMessages()'s return value, or using callbacks via
|
|
|
|
* ProcUIRegisterCallback().
|
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* todo: flesh out exactly what is/isn't allowed in background
|
|
|
|
* \endif
|
2016-07-27 09:39:03 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
2016-08-15 06:33:58 +02:00
|
|
|
extern "C" {
|
2016-07-27 09:39:03 +02:00
|
|
|
#endif
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Called when the application needs to save.
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
typedef void (*ProcUISaveCallback)(void);
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Called when the application needs to save.
|
|
|
|
* void* argument is provided in ProcUIInitEx().
|
|
|
|
*/
|
2017-05-10 18:21:57 +02:00
|
|
|
typedef uint32_t (*ProcUISaveCallbackEx)(void *);
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Generic ProcUI callback.
|
|
|
|
* void* argument is provided in ProcUIRegisterCallback().
|
|
|
|
*/
|
2017-05-10 18:21:57 +02:00
|
|
|
typedef uint32_t (*ProcUICallback)(void *);
|
|
|
|
|
|
|
|
typedef enum ProcUICallbackType
|
|
|
|
{
|
2018-06-25 03:01:01 +02:00
|
|
|
//! Application acquires the foreground
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_ACQUIRE,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! Application must release the foreground
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_RELEASE,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! Application must exit
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_EXIT,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! Application may start using networking
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_NET_IO_START,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! Application must stop using networking
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_NET_IO_STOP,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! The user attempted to press the HOME button but was denied
|
2017-05-10 18:21:57 +02:00
|
|
|
PROCUI_CALLBACK_HOME_BUTTON_DENIED,
|
|
|
|
} ProcUICallbackType;
|
2016-07-27 09:39:03 +02:00
|
|
|
|
|
|
|
typedef enum ProcUIStatus
|
|
|
|
{
|
2018-06-25 03:01:01 +02:00
|
|
|
//! The application is in the foreground. All resources may be used.
|
2016-07-27 09:39:03 +02:00
|
|
|
PROCUI_STATUS_IN_FOREGROUND,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! The application is in the background, only limited resources are usable.
|
2016-07-27 09:39:03 +02:00
|
|
|
PROCUI_STATUS_IN_BACKGROUND,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! The application must relelase the foregound - see ProcUIDrawDoneRelease()
|
2016-07-27 09:39:03 +02:00
|
|
|
PROCUI_STATUS_RELEASE_FOREGROUND,
|
2018-06-25 03:01:01 +02:00
|
|
|
//! The application must release all resources (including ProcUI) and quit
|
2016-07-27 09:39:03 +02:00
|
|
|
PROCUI_STATUS_EXITING,
|
|
|
|
} ProcUIStatus;
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
ProcUICalcMemorySize(uint32_t unk);
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Unregister all ProcUI callbacks.
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - ProcUIRegisterCallback()
|
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* Would a currently executing async operation keep or lose the callbacks?
|
|
|
|
* does this block?
|
|
|
|
* \endif
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUIClearCallbacks();
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Signifies to ProcUI that the current application has released all foreground
|
|
|
|
* resources, drawn its last frame, and is ready to be moved into the
|
|
|
|
* background. Should only be called when the application is in the
|
|
|
|
* #PROCUI_STATUS_RELEASE_FOREGROUND state.
|
|
|
|
*
|
|
|
|
* \note
|
|
|
|
* Upon calling this function, all application threads on cores 0 or 1 are
|
|
|
|
* suspended as soon as possible - see coreinit/Thread for information on when
|
|
|
|
* threads are suspended.
|
|
|
|
*
|
|
|
|
* \warning
|
|
|
|
* Do not attempt to use foreground-only resources after calling this function.
|
|
|
|
* You should wait until ProcUI indicates #PROCUI_STATUS_IN_FOREGROUND.
|
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* meta: Does the context switch occur before this function returns? the next
|
|
|
|
* ProcessMessages call? how does SubProcessMessages fit in?
|
|
|
|
* doxy: how do you link to the description of coreinit/thread?
|
|
|
|
* \endif
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUIDrawDoneRelease();
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Determines whether the application is in the foreground.
|
|
|
|
*
|
|
|
|
* \returns
|
|
|
|
* \c true if the application status is #PROCUI_STATUS_IN_FOREGROUND.
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - #PROCUI_STATUS_IN_FOREGROUND
|
|
|
|
* - ProcUIRegisterCallback()
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
BOOL
|
|
|
|
ProcUIInForeground();
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Determines whether the application is in shutdown and should quit.
|
|
|
|
*
|
|
|
|
* \returns
|
|
|
|
* \c true if the application status is #PROCUI_STATUS_EXITING.
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - #PROCUI_STATUS_EXITING
|
|
|
|
* - ProcUIRegisterCallback()
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
BOOL
|
|
|
|
ProcUIInShutdown();
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Initialises the ProcUI library for use.
|
|
|
|
*
|
|
|
|
* \param saveCallback
|
|
|
|
* A callback to be called when the application needs to save. The callback
|
|
|
|
* cannot be NULL and it must call OSSavesDone_ReadyToRelease().
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - OSSavesDone_ReadyToRelease()
|
2018-06-25 03:01:01 +02:00
|
|
|
* - ProcUISetSaveCallback()
|
|
|
|
* - ProcUIShutdown()
|
2018-06-23 12:11:31 +02:00
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUIInit(ProcUISaveCallback saveCallback);
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Initialises the ProcUI library for use; using a save callback that takes
|
|
|
|
* arguments.
|
|
|
|
*
|
|
|
|
* \param saveCallback
|
|
|
|
* A callback to be called when the application needs to save. The callback
|
|
|
|
* cannot be NULL and it must call OSSavesDone_ReadyToRelease().
|
|
|
|
*
|
|
|
|
* \param arg
|
|
|
|
* An argument to pass into saveCallbackEx.
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - OSSavesDone_ReadyToRelease()
|
2018-06-25 03:01:01 +02:00
|
|
|
* - ProcUISetSaveCallback()
|
|
|
|
* - ProcUIShutdown()
|
2018-06-23 12:11:31 +02:00
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUIInitEx(ProcUISaveCallbackEx saveCallback,
|
|
|
|
void *arg);
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Determines whether the application is running.
|
|
|
|
*
|
|
|
|
* \returns
|
|
|
|
* \c true if the application is running.
|
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* running? what does that actually mean? any state except exiting?
|
|
|
|
* \endif
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
BOOL
|
|
|
|
ProcUIIsRunning();
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Main runloop for ProcUI. This function processes messages from the OS and
|
|
|
|
* provides it an opportinity to take control (to open the HOME menu overlay,
|
|
|
|
* for example). Returns the current state of the application.
|
|
|
|
*
|
|
|
|
* \param block
|
|
|
|
* Determines whether the function should block before returning. If \c false,
|
2018-06-25 03:01:01 +02:00
|
|
|
* the function returns immediately and all messages and callbacks are processed
|
|
|
|
* asynchronously.
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \return
|
2018-06-25 03:01:01 +02:00
|
|
|
* The current state of the program. See #ProcUIStatus. If block is \c false,
|
|
|
|
* this value is undefined and should be ignored.
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \warning
|
2018-06-25 03:01:01 +02:00
|
|
|
* ProcUI's non-blocking mode is not widely used and may have undocumented
|
|
|
|
* behaviour. Be careful with callbacks and the return value.
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \note
|
2018-06-25 03:01:01 +02:00
|
|
|
* This function should only be called from the main core. See OSIsMainCore()
|
|
|
|
* and ProcUISubProcessMessages().
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \if false
|
2018-06-25 03:01:01 +02:00
|
|
|
* Assuming
|
2018-06-23 12:11:31 +02:00
|
|
|
* \endif
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
ProcUIStatus
|
|
|
|
ProcUIProcessMessages(BOOL block);
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* Register a callback for certain ProcUI events.
|
|
|
|
*
|
|
|
|
* \param type
|
|
|
|
* The event to register a callback for. See #ProcUICallbackType.
|
|
|
|
*
|
|
|
|
* \param callback
|
|
|
|
* Function pointer for the callback to call when the given event occurs.
|
|
|
|
*
|
|
|
|
* \param param
|
|
|
|
* Argument for the callback. This will be passed in as the *second* argument.
|
|
|
|
*
|
|
|
|
* \param priority
|
|
|
|
* The priority of the callback.
|
|
|
|
*
|
2018-06-25 03:01:01 +02:00
|
|
|
* \sa
|
|
|
|
* - ProcUIRegisterCallbackCore()
|
|
|
|
*
|
2018-06-23 12:11:31 +02:00
|
|
|
* \if false
|
|
|
|
* higher-priority callbacks exec first? dunno
|
|
|
|
* \endif
|
|
|
|
*/
|
2017-05-10 18:21:57 +02:00
|
|
|
void
|
|
|
|
ProcUIRegisterCallback(ProcUICallbackType type,
|
|
|
|
ProcUICallback callback,
|
|
|
|
void *param,
|
|
|
|
uint32_t priority);
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Register a callback for certain ProcUI events on the given core.
|
|
|
|
*
|
|
|
|
* \param type
|
|
|
|
* The event to register a callback for. See #ProcUICallbackType.
|
|
|
|
*
|
|
|
|
* \param callback
|
|
|
|
* Function pointer for the callback to call when the given event occurs.
|
|
|
|
*
|
|
|
|
* \param param
|
|
|
|
* Argument for the callback. This will be passed in as the *second* argument.
|
|
|
|
*
|
|
|
|
* \param priority
|
|
|
|
* The priority of the callback.
|
|
|
|
*
|
|
|
|
* \param core
|
|
|
|
* The core to register the callback for.
|
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* is core the core that the callback executes on? or is it about having
|
|
|
|
* different callbacks for each core
|
|
|
|
* \false
|
|
|
|
*/
|
2017-05-10 18:21:57 +02:00
|
|
|
void
|
|
|
|
ProcUIRegisterCallbackCore(ProcUICallbackType type,
|
|
|
|
ProcUICallback callback,
|
|
|
|
void *param,
|
|
|
|
uint32_t priority,
|
|
|
|
uint32_t core);
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Sets the save callback. Unlike ProcUIInitEx(), this function can be called
|
|
|
|
* while ProcUI is already running.
|
|
|
|
*
|
|
|
|
* \param saveCallback
|
|
|
|
* A callback to be called when the application needs to save. The callback
|
|
|
|
* cannot be NULL and it must call OSSavesDone_ReadyToRelease().
|
|
|
|
*
|
|
|
|
* \param arg
|
|
|
|
* An argument to pass into saveCallbackEx.
|
|
|
|
*
|
|
|
|
* \sa
|
|
|
|
* - OSSavesDone_ReadyToRelease()
|
|
|
|
* - ProcUIInitEx()
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUISetSaveCallback(ProcUISaveCallbackEx saveCallback,
|
|
|
|
void *arg);
|
|
|
|
|
2018-06-25 03:01:01 +02:00
|
|
|
/**
|
|
|
|
* Shut down the ProcUI library for the current application. This should be
|
|
|
|
* called before the app exits.
|
|
|
|
*
|
|
|
|
* \note
|
|
|
|
* Do not attempt to use any ProcUI library functions after calling this
|
|
|
|
* function, except for ProcUIInit() or ProcUIInitEx().
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
void
|
|
|
|
ProcUIShutdown();
|
|
|
|
|
2018-06-23 12:11:31 +02:00
|
|
|
/**
|
|
|
|
* ProcUIProcessMessages(), but for secondary cores.
|
|
|
|
*
|
|
|
|
* \param block
|
|
|
|
* Determines whether the function should block before returning. If \c false,
|
2018-06-25 03:01:01 +02:00
|
|
|
* the function returns immediately and all messages and callbacks are processed
|
|
|
|
* asynchronously.
|
|
|
|
*
|
|
|
|
* \returns
|
|
|
|
* The current state of the program - see #ProcUIStatus. If block is \c false,
|
|
|
|
* this value is undefined and should be ignored.
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \warning
|
2018-06-25 03:01:01 +02:00
|
|
|
* ProcUI's non-blocking mode is not widely used and may have undocumented
|
|
|
|
* behaviour. Be careful with callbacks and the return value.
|
2018-06-23 12:11:31 +02:00
|
|
|
*
|
|
|
|
* \if false
|
|
|
|
* didn't know what this did, only seen it in the else{} from OSIsMainCore...
|
|
|
|
* please research and correct!
|
|
|
|
* \endif
|
|
|
|
*/
|
2016-07-27 09:39:03 +02:00
|
|
|
ProcUIStatus
|
2016-08-15 06:33:58 +02:00
|
|
|
ProcUISubProcessMessages(BOOL block);
|
2016-07-27 09:39:03 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @} */
|