mirror of
https://github.com/wiiu-env/wut.git
synced 2025-01-23 11:41:13 +01:00
Merge pull request #75 from QuarkTheAwesome/master
COS Docs: Most of ProcUI
This commit is contained in:
commit
75bdc97d3b
@ -4,6 +4,35 @@
|
|||||||
/**
|
/**
|
||||||
* \defgroup proc_ui_procui ProcUI
|
* \defgroup proc_ui_procui ProcUI
|
||||||
* \ingroup proc_ui
|
* \ingroup proc_ui
|
||||||
|
*
|
||||||
|
* 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
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -28,34 +57,97 @@ typedef uint32_t (*ProcUICallback)(void *);
|
|||||||
|
|
||||||
typedef enum ProcUICallbackType
|
typedef enum ProcUICallbackType
|
||||||
{
|
{
|
||||||
|
//! Application acquires the foreground
|
||||||
PROCUI_CALLBACK_ACQUIRE,
|
PROCUI_CALLBACK_ACQUIRE,
|
||||||
|
//! Application must release the foreground
|
||||||
PROCUI_CALLBACK_RELEASE,
|
PROCUI_CALLBACK_RELEASE,
|
||||||
|
//! Application must exit
|
||||||
PROCUI_CALLBACK_EXIT,
|
PROCUI_CALLBACK_EXIT,
|
||||||
|
//! Application may start using networking
|
||||||
PROCUI_CALLBACK_NET_IO_START,
|
PROCUI_CALLBACK_NET_IO_START,
|
||||||
|
//! Application must stop using networking
|
||||||
PROCUI_CALLBACK_NET_IO_STOP,
|
PROCUI_CALLBACK_NET_IO_STOP,
|
||||||
|
//! The user attempted to press the HOME button but was denied
|
||||||
PROCUI_CALLBACK_HOME_BUTTON_DENIED,
|
PROCUI_CALLBACK_HOME_BUTTON_DENIED,
|
||||||
} ProcUICallbackType;
|
} ProcUICallbackType;
|
||||||
|
|
||||||
typedef enum ProcUIStatus
|
typedef enum ProcUIStatus
|
||||||
{
|
{
|
||||||
|
//! The application is in the foreground. All resources may be used.
|
||||||
PROCUI_STATUS_IN_FOREGROUND,
|
PROCUI_STATUS_IN_FOREGROUND,
|
||||||
|
//! The application is in the background, only limited resources are usable.
|
||||||
PROCUI_STATUS_IN_BACKGROUND,
|
PROCUI_STATUS_IN_BACKGROUND,
|
||||||
|
//! The application must release the foregound - see ProcUIDrawDoneRelease()
|
||||||
PROCUI_STATUS_RELEASE_FOREGROUND,
|
PROCUI_STATUS_RELEASE_FOREGROUND,
|
||||||
|
//! The application must release all resources (including ProcUI) and quit
|
||||||
PROCUI_STATUS_EXITING,
|
PROCUI_STATUS_EXITING,
|
||||||
} ProcUIStatus;
|
} ProcUIStatus;
|
||||||
|
|
||||||
uint32_t
|
uint32_t
|
||||||
ProcUICalcMemorySize(uint32_t unk);
|
ProcUICalcMemorySize(uint32_t unk);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister all ProcUI callbacks.
|
||||||
|
*
|
||||||
|
* \sa
|
||||||
|
* - ProcUIRegisterCallback()
|
||||||
|
*
|
||||||
|
* \if false
|
||||||
|
* Would a currently executing async operation keep or lose the callbacks?
|
||||||
|
* does this block?
|
||||||
|
* \endif
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
ProcUIClearCallbacks();
|
ProcUIClearCallbacks();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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
|
||||||
|
* After calling this function, the context will switch next time
|
||||||
|
* ProcUIProcessMessages() is called. All user threads on core 0 and 1 will
|
||||||
|
* be suspended once this happens.
|
||||||
|
*
|
||||||
|
* \warning
|
||||||
|
* Do not attempt to use foreground-only resources after calling this function
|
||||||
|
* and its accompanying ProcUIProcessMessages().
|
||||||
|
* You should wait until ProcUI indicates #PROCUI_STATUS_IN_FOREGROUND.
|
||||||
|
*
|
||||||
|
* \if false
|
||||||
|
* how does SubProcessMessages fit in?
|
||||||
|
* doxy: how do you link to the description of coreinit/thread? would like to
|
||||||
|
* note that threads can't be suspended immediately
|
||||||
|
* \endif
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
ProcUIDrawDoneRelease();
|
ProcUIDrawDoneRelease();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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()
|
||||||
|
*/
|
||||||
BOOL
|
BOOL
|
||||||
ProcUIInForeground();
|
ProcUIInForeground();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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()
|
||||||
|
*/
|
||||||
BOOL
|
BOOL
|
||||||
ProcUIInShutdown();
|
ProcUIInShutdown();
|
||||||
|
|
||||||
@ -68,6 +160,8 @@ ProcUIInShutdown();
|
|||||||
*
|
*
|
||||||
* \sa
|
* \sa
|
||||||
* - OSSavesDone_ReadyToRelease()
|
* - OSSavesDone_ReadyToRelease()
|
||||||
|
* - ProcUISetSaveCallback()
|
||||||
|
* - ProcUIShutdown()
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ProcUIInit(ProcUISaveCallback saveCallback);
|
ProcUIInit(ProcUISaveCallback saveCallback);
|
||||||
@ -85,11 +179,23 @@ ProcUIInit(ProcUISaveCallback saveCallback);
|
|||||||
*
|
*
|
||||||
* \sa
|
* \sa
|
||||||
* - OSSavesDone_ReadyToRelease()
|
* - OSSavesDone_ReadyToRelease()
|
||||||
|
* - ProcUISetSaveCallback()
|
||||||
|
* - ProcUIShutdown()
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
ProcUIInitEx(ProcUISaveCallbackEx saveCallback,
|
ProcUIInitEx(ProcUISaveCallbackEx saveCallback,
|
||||||
void *arg);
|
void *arg);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
BOOL
|
BOOL
|
||||||
ProcUIIsRunning();
|
ProcUIIsRunning();
|
||||||
|
|
||||||
@ -100,22 +206,23 @@ ProcUIIsRunning();
|
|||||||
*
|
*
|
||||||
* \param block
|
* \param block
|
||||||
* Determines whether the function should block before returning. If \c false,
|
* Determines whether the function should block before returning. If \c false,
|
||||||
* the function returns immediately.
|
* the function returns immediately and all messages and callbacks are processed
|
||||||
|
* asynchronously.
|
||||||
*
|
*
|
||||||
* \return
|
* \return
|
||||||
* The current state of the program. See #ProcUIStatus.
|
* The current state of the program. See #ProcUIStatus. If block is \c false,
|
||||||
|
* this value is undefined and should be ignored.
|
||||||
*
|
*
|
||||||
* \warning
|
* \warning
|
||||||
* At this time, using ProcUI's non-blocking mode is not recommended as not much
|
* ProcUI's non-blocking mode is not widely used and may have undocumented
|
||||||
* is known about it. Instead, set block to \c true and examine the return
|
* behaviour. Be careful with callbacks and the return value.
|
||||||
* value.
|
|
||||||
*
|
*
|
||||||
* \note
|
* \note
|
||||||
* This function should only be called from the main core. See OSIsMainCore().
|
* This function should only be called from the main core. See OSIsMainCore()
|
||||||
|
* and ProcUISubProcessMessages().
|
||||||
*
|
*
|
||||||
* \if false
|
* \if false
|
||||||
* meta: what happens when block=false? is the return value trustworthy? how
|
* Assuming the note about core behaviour is true, based on homebrew
|
||||||
* does it interact with ProcUIRegisterCallback?
|
|
||||||
* \endif
|
* \endif
|
||||||
*/
|
*/
|
||||||
ProcUIStatus
|
ProcUIStatus
|
||||||
@ -136,6 +243,9 @@ ProcUIProcessMessages(BOOL block);
|
|||||||
* \param priority
|
* \param priority
|
||||||
* The priority of the callback.
|
* The priority of the callback.
|
||||||
*
|
*
|
||||||
|
* \sa
|
||||||
|
* - ProcUIRegisterCallbackCore()
|
||||||
|
*
|
||||||
* \if false
|
* \if false
|
||||||
* higher-priority callbacks exec first? dunno
|
* higher-priority callbacks exec first? dunno
|
||||||
* \endif
|
* \endif
|
||||||
@ -146,6 +256,27 @@ ProcUIRegisterCallback(ProcUICallbackType type,
|
|||||||
void *param,
|
void *param,
|
||||||
uint32_t priority);
|
uint32_t priority);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register a callback for certain ProcUI events, executed 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 ID to run the callback on.
|
||||||
|
*
|
||||||
|
* \sa
|
||||||
|
* - ProcUIRegisterCallback()
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
ProcUIRegisterCallbackCore(ProcUICallbackType type,
|
ProcUIRegisterCallbackCore(ProcUICallbackType type,
|
||||||
ProcUICallback callback,
|
ProcUICallback callback,
|
||||||
@ -153,10 +284,33 @@ ProcUIRegisterCallbackCore(ProcUICallbackType type,
|
|||||||
uint32_t priority,
|
uint32_t priority,
|
||||||
uint32_t core);
|
uint32_t core);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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()
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
ProcUISetSaveCallback(ProcUISaveCallbackEx saveCallback,
|
ProcUISetSaveCallback(ProcUISaveCallbackEx saveCallback,
|
||||||
void *arg);
|
void *arg);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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().
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
ProcUIShutdown();
|
ProcUIShutdown();
|
||||||
|
|
||||||
@ -165,12 +319,16 @@ ProcUIShutdown();
|
|||||||
*
|
*
|
||||||
* \param block
|
* \param block
|
||||||
* Determines whether the function should block before returning. If \c false,
|
* Determines whether the function should block before returning. If \c false,
|
||||||
* the function returns immediately.
|
* 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.
|
||||||
*
|
*
|
||||||
* \warning
|
* \warning
|
||||||
* At this time, using ProcUI's non-blocking mode is not recommended as not much
|
* ProcUI's non-blocking mode is not widely used and may have undocumented
|
||||||
* is known about it. Instead, set block to \c true and examine the return
|
* behaviour. Be careful with callbacks and the return value.
|
||||||
* value.
|
|
||||||
*
|
*
|
||||||
* \if false
|
* \if false
|
||||||
* didn't know what this did, only seen it in the else{} from OSIsMainCore...
|
* didn't know what this did, only seen it in the else{} from OSIsMainCore...
|
||||||
|
Loading…
x
Reference in New Issue
Block a user