VaKeR CYBER ARMY
Logo of a company Server : Apache/2.4.41 (Ubuntu)
System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64
User : www-data ( 33)
PHP Version : 7.4.33
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Directory :  /proc/thread-self/root/usr/share/emscripten/system/include/emscripten/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //proc/thread-self/root/usr/share/emscripten/system/include/emscripten/html5.h
#ifndef __emscripten_events_h__
#define __emscripten_events_h__

#ifdef __cplusplus
extern "C" {
#endif

/* This file defines Emscripten low-level glue bindings for interfacing with the following HTML5 APIs:
 *    - DOM Level 3 Events: Keyboard, Mouse, Mouse Wheel, Resize, Scroll, Focus. See https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html
 *    - DeviceOrientation Events for gyro and accelerometer. See http://www.w3.org/TR/orientation-event/
 *    - Screen Orientation Events for portrait/landscape handling. See https://dvcs.w3.org/hg/screen-orientation/raw-file/tip/Overview.html
 *    - Fullscreen Events for browser canvas fullscreen modes transitioning. See https://dvcs.w3.org/hg/fullscreen/raw-file/tip/Overview.html
 *    - Pointer Lock Events for relative-mode mouse motion control. See http://www.w3.org/TR/pointerlock/
 *    - Vibration API for mobile device haptic vibration feedback control. See http://dev.w3.org/2009/dap/vibration/
 *    - Page Visibility Events for power management control. See http://www.w3.org/TR/page-visibility/
 *    - Touch Events. See http://www.w3.org/TR/touch-events/
 *    - Gamepad API. See http://www.w3.org/TR/gamepad/
 *    - Beforeunload event. See http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#beforeunloadevent
 *    - WebGL context events. See http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.15.2
 *
 * Most web APIs are event-based, which means that the functionality is accessed by registering a callback function to be called when the event occurs. The
 * Gamepad API is currently an exception, for which only a polling API is available. For some APIs, both an event-based and a polling-based API is exposed.
 *
 * Calling a callback registration function with a null pointer function causes an unregistration of that callback from the given target element. All event
 * handlers are also automatically unregistered when the C exit() function is invoked during the atexit handler pass. Use either the function 
 * emscripten_set_main_loop() or set Module.noExitRuntime = true; to make sure that leaving main() will not immediately cause an exit() and clean up the
 * event handlers.
 *
 * Throughout this file, the function signatures have a 'target' parameter. This parameter allows specifying the HTML Element ID to which the callback
 * registration is to be applied to. This field has the following special meanings:
 *    - 0 or NULL: A default element is chosen automatically based on the event type, which should be reasonable most of the time.
 *    - "#window": The event listener is applied to the JS 'window' object.
 *    - "#document": The event listener is applied to the JS 'document' object.
 *    - "#screen": The event listener is applied to the JS 'window.screen' object.
 *    - "#canvas": The event listener is applied to the Emscripten default WebGL canvas element.
 *    - Any other string without a leading hash "#" sign: The event listener is applied to the element by the given ID on the page.
 *
 * The callback hook functions also take in a 'userData' parameter. This is a custom user-defineable value that will be carried through unchanged to all 
 * invocations of the registered event callback. Use this e.g. to pass a pointer to a C++ class or similar to enclose the C API in a clean object-oriented manner.
 *
 * Callback handlers that return an EM_BOOL may return nonzero to signal that the default action for that event is to be suppressed. This will call 
 * the .preventDefault(); member on the event. Returning zero will cause the default browser event action to be carried out.
 *
 * Most functions return the result using the type EMSCRIPTEN_RESULT. Nonzero and positive values denote success. Negative values
 * signal failure. None of the functions fail or abort by throwing a JS or C++ exception. If a particular browser does not support the given feature,
 * the value EMSCRIPTEN_RESULT_NOT_SUPPORTED will be returned at the time the callback is registered.
 *
 * Due to web security purposes, the pointer lock and fullscreen requests can only be invoked from inside an user-originated event handler. Such requests
 * are automatically deferred until the user presses a keyboard or mouse button the next time.
 */

#define EMSCRIPTEN_EVENT_KEYPRESS               1
#define EMSCRIPTEN_EVENT_KEYDOWN                2
#define EMSCRIPTEN_EVENT_KEYUP                  3
#define EMSCRIPTEN_EVENT_CLICK                  4
#define EMSCRIPTEN_EVENT_MOUSEDOWN              5
#define EMSCRIPTEN_EVENT_MOUSEUP                6
#define EMSCRIPTEN_EVENT_DBLCLICK               7
#define EMSCRIPTEN_EVENT_MOUSEMOVE              8
#define EMSCRIPTEN_EVENT_WHEEL                  9
#define EMSCRIPTEN_EVENT_RESIZE                10
#define EMSCRIPTEN_EVENT_SCROLL                11
#define EMSCRIPTEN_EVENT_BLUR                  12
#define EMSCRIPTEN_EVENT_FOCUS                 13
#define EMSCRIPTEN_EVENT_FOCUSIN               14
#define EMSCRIPTEN_EVENT_FOCUSOUT              15
#define EMSCRIPTEN_EVENT_DEVICEORIENTATION     16
#define EMSCRIPTEN_EVENT_DEVICEMOTION          17
#define EMSCRIPTEN_EVENT_ORIENTATIONCHANGE     18
#define EMSCRIPTEN_EVENT_FULLSCREENCHANGE      19
#define EMSCRIPTEN_EVENT_POINTERLOCKCHANGE     20
#define EMSCRIPTEN_EVENT_VISIBILITYCHANGE      21
#define EMSCRIPTEN_EVENT_TOUCHSTART            22
#define EMSCRIPTEN_EVENT_TOUCHEND              23
#define EMSCRIPTEN_EVENT_TOUCHMOVE             24
#define EMSCRIPTEN_EVENT_TOUCHCANCEL           25
#define EMSCRIPTEN_EVENT_GAMEPADCONNECTED      26
#define EMSCRIPTEN_EVENT_GAMEPADDISCONNECTED   27
#define EMSCRIPTEN_EVENT_BEFOREUNLOAD          28
#define EMSCRIPTEN_EVENT_BATTERYCHARGINGCHANGE 29
#define EMSCRIPTEN_EVENT_BATTERYLEVELCHANGE    30
#define EMSCRIPTEN_EVENT_WEBGLCONTEXTLOST      31
#define EMSCRIPTEN_EVENT_WEBGLCONTEXTRESTORED  32

#define EMSCRIPTEN_RESULT int

// The operation succeeded
#define EMSCRIPTEN_RESULT_SUCCESS              0

// For web security reasons, the requested operation cannot be completed now, but was deferred for completion in the next event handler.
#define EMSCRIPTEN_RESULT_DEFERRED             1

// The given operation is not supported by this browser or the target element.
#define EMSCRIPTEN_RESULT_NOT_SUPPORTED       -1

// For web security reasons, the requested operation could not be completed now, and it failed since the user requested the operation to not be deferred.
#define EMSCRIPTEN_RESULT_FAILED_NOT_DEFERRED -2

// The given target element for the operation is invalid.
#define EMSCRIPTEN_RESULT_INVALID_TARGET      -3

// The given target element for the operation was not found.
#define EMSCRIPTEN_RESULT_UNKNOWN_TARGET      -4

// An invalid parameter was passed to the function.
#define EMSCRIPTEN_RESULT_INVALID_PARAM       -5

// The operation failed due to some generic reason.
#define EMSCRIPTEN_RESULT_FAILED              -6

// Operation failed since no data is currently available.
#define EMSCRIPTEN_RESULT_NO_DATA             -7

#define EM_BOOL int
#define EM_UTF8 char

#define DOM_KEY_LOCATION int
#define DOM_KEY_LOCATION_STANDARD 0x00
#define DOM_KEY_LOCATION_LEFT     0x01
#define DOM_KEY_LOCATION_RIGHT    0x02
#define DOM_KEY_LOCATION_NUMPAD   0x03

/*
 * The event structure passed in keyboard events keypress, keydown and keyup.
 * https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#keys
 *
 * Note that since the DOM Level 3 Events spec is very recent at the time of writing (2014-03), uniform
 * support for the different fields in the spec is still in flux. Be sure to check the results in multiple
 * browsers. See the unmerged pull request #2222 for an example way on how to interpret the legacy key events.
 */
typedef struct EmscriptenKeyboardEvent {
  // The printed representation of the pressed key.
  EM_UTF8 key[32];
  // A string that identifies the physical key being pressed. The value is not affected by the current keyboard
  // layout or modifier state, so a particular key will always return the same value.
  EM_UTF8 code[32];
  // Indicates the location of the key on the keyboard. One of the DOM_KEY_LOCATION_ values.
  unsigned long location;
  // Specifies which modifiers were active during the key event.
  EM_BOOL ctrlKey;
  EM_BOOL shiftKey;
  EM_BOOL altKey;
  EM_BOOL metaKey;
  // Specifies if this keyboard event represents a repeated press.
  EM_BOOL repeat;
  // A locale string indicating the locale the keyboard is configured for. This may be the empty string if the
  // browser or device doesn't know the keyboard's locale.
  EM_UTF8 locale[32];
  // The following fields are values from previous versions of the DOM key events specifications.
  // See https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent?redirectlocale=en-US&redirectslug=DOM%2FKeyboardEvent
  // The character representation of the key. This is the field 'char' from the docs, but renamed to charValue to avoid a C reserved word.
  // Warning: This attribute has been dropped from DOM Level 3 events.
  EM_UTF8 charValue[32];
  // The Unicode reference number of the key; this attribute is used only by the keypress event. For keys whose char attribute
  // contains multiple characters, this is the Unicode value of the first character in that attribute.
  // Warning: This attribute is deprecated, you should use the field 'key' instead, if available.
  unsigned long charCode;
  // A system and implementation dependent numerical code identifying the unmodified value of the pressed key.
  // Warning: This attribute is deprecated, you should use the field 'key' instead, if available.
  unsigned long keyCode;
  // A system and implementation dependent numeric code identifying the unmodified value of the pressed key; this is usually the same as keyCode.
  // Warning: This attribute is deprecated, you should use the field 'key' instead, if available.
  unsigned long which;
} EmscriptenKeyboardEvent;

/*
 * Registers a callback function for receiving browser-generated keyboard input events.
 * See https://developer.mozilla.org/en/DOM/Event/UIEvent/KeyEvent
 * and http://www.javascriptkit.com/jsref/eventkeyboardmouse.shtml
 */
typedef EM_BOOL (*em_key_callback_func)(int eventType, const EmscriptenKeyboardEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_keypress_callback(const char *target, void *userData, EM_BOOL useCapture, em_key_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_keydown_callback(const char *target, void *userData, EM_BOOL useCapture, em_key_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_keyup_callback(const char *target, void *userData, EM_BOOL useCapture, em_key_callback_func callback);

/*
 * The event structure passed in mouse events click, mousedown, mouseup, dblclick and mousemove.
 * https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#interface-MouseEvent
 */
typedef struct EmscriptenMouseEvent {
  // A timestamp of when this data was generated by the browser. This is an absolute wallclock time in milliseconds.
  double timestamp;
  // The coordinate relative to the browser screen coordinate system.
  long screenX;
  long screenY;
  // The coordinate relative to the viewport associate with the event.
  long clientX;
  long clientY;
  // Specifies which modifiers were active during the mouse event.
  EM_BOOL ctrlKey;
  EM_BOOL shiftKey;
  EM_BOOL altKey;
  EM_BOOL metaKey;
  // Which pointer device button changed state.
  unsigned short button;
  // A bitmask that indicates which combinations of mouse buttons were being held down at the time of the event.
  unsigned short buttons;
  // If pointer lock is active, these two extra fields give relative mouse movement since the last event.
  long movementX;
  long movementY;
  // Emscripten-specific extension: These fields give the mouse coordinates mapped to the Emscripten canvas client area.
  // If the Emscripten canvas does not exist (Module.canvas element is null), then these fields will contain a value (0, 0).
  long canvasX;
  long canvasY;
  // Pad this struct to multiple of 8 bytes to make WheelEvent unambiguously align to 8 bytes.
  long padding;
} EmscriptenMouseEvent;

/*
 * Registers a callback function for receiving browser-generated mouse input events.
 * See https://developer.mozilla.org/en/DOM/MouseEvent
 */
typedef EM_BOOL (*em_mouse_callback_func)(int eventType, const EmscriptenMouseEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_click_callback(const char *target, void *userData, EM_BOOL useCapture, em_mouse_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_mousedown_callback(const char *target, void *userData, EM_BOOL useCapture, em_mouse_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_mouseup_callback(const char *target, void *userData, EM_BOOL useCapture, em_mouse_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_dblclick_callback(const char *target, void *userData, EM_BOOL useCapture, em_mouse_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_mousemove_callback(const char *target, void *userData, EM_BOOL useCapture, em_mouse_callback_func callback);
/*
 * Returns the most recently received mouse event state. Note that for this function call to succeed, emscripten_set_xx_callback must have first
 * been called with one of the mouse event types and a non-zero callback function pointer to enable the Mouse state capture.
 */
extern EMSCRIPTEN_RESULT emscripten_get_mouse_status(EmscriptenMouseEvent *mouseState);

#define DOM_DELTA_PIXEL 0x00
#define DOM_DELTA_LINE  0x01
#define DOM_DELTA_PAGE  0x02

/*
 * The event structure passed in mouse wheelevent.
 * https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#interface-WheelEvent
 */
typedef struct EmscriptenWheelEvent {
  // Specifies general mouse information related to this event.
  EmscriptenMouseEvent mouse;
  // Measures along different axes the movement of the wheel.
  double deltaX;
  double deltaY;
  double deltaZ;
  // One of the DOM_DELTA_ values that indicates the units of measurement for the delta values.
  unsigned long deltaMode;
} EmscriptenWheelEvent;

/*
 * Registers a callback function for receiving browser-generated mouse wheel events.
 * See http://www.w3.org/TR/DOM-Level-3-Events/#event-type-wheel
 */
typedef EM_BOOL (*em_wheel_callback_func)(int eventType, const EmscriptenWheelEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_wheel_callback(const char *target, void *userData, EM_BOOL useCapture, em_wheel_callback_func callback);

/*
 * The event structure passed in DOM element resize and scroll events.
 * https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#interface-UIEvent
 */
typedef struct EmscriptenUiEvent {
  // Specifies detail information about this event.
  long detail;
  // The clientWidth/clientHeight of the document.body element.
  int documentBodyClientWidth;
  int documentBodyClientHeight;
  // The innerWidth/innerHeight of the window element.
  int windowInnerWidth;
  int windowInnerHeight;
  // The outerWidth/outerHeight of the window element.
  int windowOuterWidth;
  int windowOuterHeight;
  // The page scroll position.
  int scrollTop;
  int scrollLeft;
} EmscriptenUiEvent;

/*
 * Registers a callback function for receiving DOM element resize and scroll events.
 * See https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#event-type-resize
 * Note: For the resize callback, pass in target = 0 to get resize events from the Window object. The DOM3 Events spec only
 *       requires that the Window object sends resize events. It is valid to register a resize callback to other DOM elements,
 *       but the browser is not required to fire resize events on them.
 */
typedef EM_BOOL (*em_ui_callback_func)(int eventType, const EmscriptenUiEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_resize_callback(const char *target, void *userData, EM_BOOL useCapture, em_ui_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_scroll_callback(const char *target, void *userData, EM_BOOL useCapture, em_ui_callback_func callback);

/*
 * The event structure passed in DOM element blur, focus, focusin and focusout events.
 * https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#interface-FocusEvent
 */
typedef struct EmscriptenFocusEvent {
  // The nodeName of the target HTML Element. See https://developer.mozilla.org/en-US/docs/Web/API/Node.nodeName
  EM_UTF8 nodeName[128];
  // The HTML Element ID of the target element.
  EM_UTF8 id[128];
} EmscriptenFocusEvent;

/*
 * Registers a callback function for receiving DOM element blur, focus, focusin and focusout events.
 * See https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3-Events.html#event-type-blur
 */
typedef EM_BOOL (*em_focus_callback_func)(int eventType, const EmscriptenFocusEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_blur_callback(const char *target, void *userData, EM_BOOL useCapture, em_focus_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_focus_callback(const char *target, void *userData, EM_BOOL useCapture, em_focus_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_focusin_callback(const char *target, void *userData, EM_BOOL useCapture, em_focus_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_focusout_callback(const char *target, void *userData, EM_BOOL useCapture, em_focus_callback_func callback);

/*
 * The event structure passed in the deviceorientation event.
 * http://dev.w3.org/geo/api/spec-source-orientation.html#deviceorientation
 */
typedef struct EmscriptenDeviceOrientationEvent {
  // Absolute wallclock time in msec units of when the event occurred.
  double timestamp;
  // The orientation of the device in terms of the transformation from a coordinate frame fixed on the Earth to a coordinate frame fixed in the device. 
  double alpha;
  double beta;
  double gamma;
  // If false, the orientation is only relative to some other bas orinetation, not to the fixed coordinate frame.
  EM_BOOL absolute;
} EmscriptenDeviceOrientationEvent;

/*
 * Registers a callback function for receiving the deviceorientation event.
 * See http://dev.w3.org/geo/api/spec-source-orientation.html
 */
typedef EM_BOOL (*em_deviceorientation_callback_func)(int eventType, const EmscriptenDeviceOrientationEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_deviceorientation_callback(void *userData, EM_BOOL useCapture, em_deviceorientation_callback_func callback);
/*
 * Returns the most recently received deviceorientation event state. Note that for this function call to succeed, emscripten_set_deviceorientation_callback
 * must have first been called with one of the mouse event types and a non-zero callback function pointer to enable the Device Orientation state capture.
 */
extern EMSCRIPTEN_RESULT emscripten_get_deviceorientation_status(EmscriptenDeviceOrientationEvent *orientationState);

/*
 * The event structure passed in the devicemotion event.
 * http://dev.w3.org/geo/api/spec-source-orientation.html#devicemotion
 */
typedef struct EmscriptenDeviceMotionEvent {
  // Absolute wallclock time in msec units of when the event occurred.
  double timestamp;
  // Acceleration of the device excluding gravity.
  double accelerationX;
  double accelerationY;
  double accelerationZ;
  // Acceleration of the device including gravity.
  double accelerationIncludingGravityX;
  double accelerationIncludingGravityY;
  double accelerationIncludingGravityZ;
  // The rotational delta of the device.
  double rotationRateAlpha;
  double rotationRateBeta;
  double rotationRateGamma;
} EmscriptenDeviceMotionEvent;

/*
 * Registers a callback function for receiving the devicemotion event.
 * See http://dev.w3.org/geo/api/spec-source-orientation.html
 */
typedef EM_BOOL (*em_devicemotion_callback_func)(int eventType, const EmscriptenDeviceMotionEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_devicemotion_callback(void *userData, EM_BOOL useCapture, em_devicemotion_callback_func callback);
/*
 * Returns the most recently received deviceomotion event state. Note that for this function call to succeed, emscripten_set_devicemotion_callback
 * must have first been called with one of the mouse event types and a non-zero callback function pointer to enable the Device Motion state capture.
 */
extern EMSCRIPTEN_RESULT emscripten_get_devicemotion_status(EmscriptenDeviceMotionEvent *motionState);

#define EMSCRIPTEN_ORIENTATION_PORTRAIT_PRIMARY    1
#define EMSCRIPTEN_ORIENTATION_PORTRAIT_SECONDARY  2
#define EMSCRIPTEN_ORIENTATION_LANDSCAPE_PRIMARY   4
#define EMSCRIPTEN_ORIENTATION_LANDSCAPE_SECONDARY 8

/*
 * The event structure passed in the orientationchange event.
 * https://dvcs.w3.org/hg/screen-orientation/raw-file/tip/Overview.html
 */
typedef struct EmscriptenOrientationChangeEvent {
  // One of EM_ORIENTATION_PORTRAIT_xx fields, or -1 if unknown.
  int orientationIndex;
  // Emscripten-specific extension: Some browsers refer to 'window.orientation', so report that as well.
  // Orientation angle in degrees. 0: "default orientation", i.e. default upright orientation to hold the mobile device in. Could be either landscape or portrait.
  int orientationAngle;
} EmscriptenOrientationChangeEvent;

/*
 * Registers a callback function for receiving the orientationchange event.
 * https://dvcs.w3.org/hg/screen-orientation/raw-file/tip/Overview.html
 */
typedef EM_BOOL (*em_orientationchange_callback_func)(int eventType, const EmscriptenOrientationChangeEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_orientationchange_callback(void *userData, EM_BOOL useCapture, em_orientationchange_callback_func callback);
/*
 * Returns the current device orientation state.
 */
extern EMSCRIPTEN_RESULT emscripten_get_orientation_status(EmscriptenOrientationChangeEvent *orientationStatus);
/*
 * Locks the screen orientation to the given set of allowed orientations.
 * allowedOrientations: A bitfield set of EM_ORIENTATION_xx flags.
 */
extern EMSCRIPTEN_RESULT emscripten_lock_orientation(int allowedOrientations);
/*
 * Allows the screen to turn again into any orientation.
 */
extern EMSCRIPTEN_RESULT emscripten_unlock_orientation(void);

/*
 * The event structure passed in the fullscreenchange event.
 * https://dvcs.w3.org/hg/fullscreen/raw-file/tip/Overview.html
 */
typedef struct EmscriptenFullscreenChangeEvent {
  // Specifies whether an element on the browser page is currently fullscreen.
  EM_BOOL isFullscreen;
  // Specifies if the current page has the ability to display elements fullscreen.
  EM_BOOL fullscreenEnabled;
  // The nodeName of the target HTML Element that is in full screen mode. See https://developer.mozilla.org/en-US/docs/Web/API/Node.nodeName
  // If isFullscreen is false, then nodeName, id and elementWidth/Height specify information about the element that just exited fullscreen mode.
  EM_UTF8 nodeName[128];
  // The HTML Element ID of the target HTML element that is in full screen mode.
  EM_UTF8 id[128];
  // The new pixel size of the element that changed fullscreen status.
  int elementWidth;
  int elementHeight;
  // The size of the whole screen, in pixels.
  int screenWidth;
  int screenHeight;
} EmscriptenFullscreenChangeEvent;

/*
 * Registers a callback function for receiving the fullscreenchange event.
 * https://dvcs.w3.org/hg/screen-orientation/raw-file/tip/Overview.html
 */
typedef EM_BOOL (*em_fullscreenchange_callback_func)(int eventType, const EmscriptenFullscreenChangeEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_fullscreenchange_callback(const char *target, void *userData, EM_BOOL useCapture, em_fullscreenchange_callback_func callback);
/*
 * Returns the current page fullscreen state.
 */
extern EMSCRIPTEN_RESULT emscripten_get_fullscreen_status(EmscriptenFullscreenChangeEvent *fullscreenStatus);
/*
 * Requests the given target element to transition to full screen mode.
 * Note: This function can only run inside a user-generated JavaScript event handler.
 * deferUntilInEventHandler: If true and you called this function outside an event callback, this request will
 *                           be queued to be executed the next time a JS event handler runs. If false, this
 *                           function will instead fail if not running inside a JS event handler.
 */
extern EMSCRIPTEN_RESULT emscripten_request_fullscreen(const char *target, EM_BOOL deferUntilInEventHandler);
/*
 * Returns back to windowed browsing mode.
 */
extern EMSCRIPTEN_RESULT emscripten_exit_fullscreen(void);

/*
 * The event structure passed in the pointerlockchange event.
 * http://www.w3.org/TR/pointerlock/
 */
typedef struct EmscriptenPointerlockChangeEvent {
  // Specifies whether an element on the browser page currently has pointer lock enabled.
  EM_BOOL isActive;
  // The nodeName of the target HTML Element that has the pointer lock active. See https://developer.mozilla.org/en-US/docs/Web/API/Node.nodeName
  EM_UTF8 nodeName[128];
  // The HTML Element ID of the target HTML element that has the pointer lock active.
  EM_UTF8 id[128];
} EmscriptenPointerlockChangeEvent;

/*
 * Registers a callback function for receiving the pointerlockchange event.
 * Pointer lock hides the mouse cursor and exclusively gives the target element relative mouse movement events via the mousemove event.
 * http://www.w3.org/TR/pointerlock/
 */
typedef EM_BOOL (*em_pointerlockchange_callback_func)(int eventType, const EmscriptenPointerlockChangeEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_pointerlockchange_callback(const char *target, void *userData, EM_BOOL useCapture, em_pointerlockchange_callback_func callback);
/*
 * Returns the current page pointerlock state.
 */
extern EMSCRIPTEN_RESULT emscripten_get_pointerlock_status(EmscriptenPointerlockChangeEvent *pointerlockStatus);
/*
 * Requests the given target element to grab pointerlock.
 * Note: This function can only run inside a user-generated JavaScript event handler.
 * deferUntilInEventHandler: If true and you called this function outside an event callback, this request will
 *                           be queued to be executed the next time a JS event handler runs. If false, this
 *                           function will instead fail if not running inside a JS event handler.
 */
extern EMSCRIPTEN_RESULT emscripten_request_pointerlock(const char *target, EM_BOOL deferUntilInEventHandler);
/*
 * Exits pointer lock state and restores the mouse cursor to be visible again.
 */
extern EMSCRIPTEN_RESULT emscripten_exit_pointerlock(void);

#define EMSCRIPTEN_VISIBILITY_HIDDEN    0
#define EMSCRIPTEN_VISIBILITY_VISIBLE   1
#define EMSCRIPTEN_VISIBILITY_PRERENDER 2
#define EMSCRIPTEN_VISIBILITY_UNLOADED  3

/*
 * The event structure passed in the visibilitychange event.
 * http://www.w3.org/TR/page-visibility/
 */
typedef struct EmscriptenVisibilityChangeEvent {
  // If true, the current browser page is now hidden.
  EM_BOOL hidden;
  // Specifies a more fine-grained state of the current page visibility status. One of the EMSCRIPTEN_VISIBILITY_ values.
  int visibilityState;
} EmscriptenVisibilityChangeEvent;

/*
 * Registers a callback function for receiving the visibilitychange event.
 * http://www.w3.org/TR/page-visibility/
 */
typedef EM_BOOL (*em_visibilitychange_callback_func)(int eventType, const EmscriptenVisibilityChangeEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_visibilitychange_callback(void *userData, EM_BOOL useCapture, em_visibilitychange_callback_func callback);
/*
 * Returns the current page visibility state.
 */
extern EMSCRIPTEN_RESULT emscripten_get_visibility_status(EmscriptenVisibilityChangeEvent *visibilityStatus);

/*
 * Specifies the status of a single touch point on the page.
 * See http://www.w3.org/TR/touch-events/#touch-interface
 */
typedef struct EmscriptenTouchPoint
{
  // An identification number for each touch point.
  long identifier;
  // The touch coordinate relative to the whole screen origin, in pixels.
  long screenX;
  long screenY;
  // The touch coordinate relative to the viewport, in pixels.
  long clientX;
  long clientY;
  // The touch coordinate relative to the viewport, in pixels, and including any scroll offset.
  long pageX;
  long pageY;
  // Specifies whether this touch point changed during this event.
  EM_BOOL isChanged;
  // Specifies whether this touch point is still above the original target on which it was initially pressed against.
  EM_BOOL onTarget;
  // The touch coordinates mapped to the Emscripten canvas client area, in pixels.
  long canvasX;
  long canvasY;
} EmscriptenTouchPoint;

/*
 * Specifies the data of a single touch event.
 * See http://www.w3.org/TR/touch-events/#touchevent-interface
 */
typedef struct EmscriptenTouchEvent {
  // The number of valid elements in the touches array.
  int numTouches;
  // Specifies which modifiers were active during the key event.
  EM_BOOL ctrlKey;
  EM_BOOL shiftKey;
  EM_BOOL altKey;
  EM_BOOL metaKey;
  // An array of currently active touches, one for each finger.
  EmscriptenTouchPoint touches[32];
} EmscriptenTouchEvent;

/*
 * Registers a callback function for receiving the touchstart, touchend, touchmove and touchcancel events.
 * http://www.w3.org/TR/touch-events/
 */
typedef EM_BOOL (*em_touch_callback_func)(int eventType, const EmscriptenTouchEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_touchstart_callback(const char *target, void *userData, EM_BOOL useCapture, em_touch_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_touchend_callback(const char *target, void *userData, EM_BOOL useCapture, em_touch_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_touchmove_callback(const char *target, void *userData, EM_BOOL useCapture, em_touch_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_touchcancel_callback(const char *target, void *userData, EM_BOOL useCapture, em_touch_callback_func callback);

/*
 * Represents the current snapshot state of a gamepad.
 * http://www.w3.org/TR/gamepad/#gamepad-interface
 */
typedef struct EmscriptenGamepadEvent {
  // Absolute wallclock time in msec units of when the data was recorded.
  double timestamp;
  // The number of valid axes entries in the axis array.
  int numAxes;
  // The number of valid button entries in the analogButton and digitalButton arrays.
  int numButtons;
  // The analog state of the gamepad axes, in the range [-1, 1].
  double axis[64];
  // The analog state of the gamepad buttons, in the range [0, 1].
  double analogButton[64];
  // The digital state of the gamepad buttons, either 0 or 1.
  EM_BOOL digitalButton[64];
  // Specifies whether this gamepad is connected to the browser page.
  EM_BOOL connected;
  // An ordinal associated with this gamepad, zero-based.
  long index;
  // An ID for the brand or style of the connected gamepad device. Typically, this will include the USB vendor and a product ID.
  EM_UTF8 id[64];
  // A string that identifies the layout or control mapping of this device.
  EM_UTF8 mapping[64];
} EmscriptenGamepadEvent;

/*
 * Registers a callback function for receiving the gamepadconnected and gamepaddisconnected events.
 * http://www.w3.org/TR/gamepad/
 */
typedef EM_BOOL (*em_gamepad_callback_func)(int eventType, const EmscriptenGamepadEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_gamepadconnected_callback(void *userData, EM_BOOL useCapture, em_gamepad_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_gamepaddisconnected_callback(void *userData, EM_BOOL useCapture, em_gamepad_callback_func callback);

/*
 * Returns the number of gamepads connected to the system or EMSCRIPTEN_RESULT_NOT_SUPPORTED if the current browser does not support gamepads.
 * Note: A gamepad does not show up as connected until a button on it is pressed.
 */
extern int emscripten_get_num_gamepads(void);
/*
 * Returns a snapshot of the current gamepad state.
 */
extern EMSCRIPTEN_RESULT emscripten_get_gamepad_status(int index, EmscriptenGamepadEvent *gamepadState);

/*
 * The event structure passed in the battery chargingchange and levelchange event.
 * http://www.w3.org/TR/battery-status/#batterymanager-interface
 */
typedef struct EmscriptenBatteryEvent {
  double chargingTime;
  double dischargingTime;
  double level;
  EM_BOOL charging;
} EmscriptenBatteryEvent;

/*
 * Registers a callback function for receiving the battery chargingchange and levelchange events.
 * http://www.w3.org/TR/battery-status/
 */
typedef EM_BOOL (*em_battery_callback_func)(int eventType, const EmscriptenBatteryEvent *keyEvent, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_batterychargingchange_callback(void *userData, em_battery_callback_func callback);
extern EMSCRIPTEN_RESULT emscripten_set_batterylevelchange_callback(void *userData, em_battery_callback_func callback);
/*
 * Returns the current battery status.
 */
extern EMSCRIPTEN_RESULT emscripten_get_battery_status(EmscriptenBatteryEvent *batteryState);

/*
 * Produces a vibration feedback for given msecs.
 * http://dev.w3.org/2009/dap/vibration/
 */
extern EMSCRIPTEN_RESULT emscripten_vibrate(int msecs);
/*
 * Produces a complex vibration feedback pattern.
 * msecsArray: An array of timing entries [on, off, on, off, on, off, ...] where every second one specifies a duration of vibration, and 
 *             every other one specifies a duration of silence.
 * numEntries: The number of integers in the array msecsArray.
 */
extern EMSCRIPTEN_RESULT emscripten_vibrate_pattern(int *msecsArray, int numEntries);

/*
 * Registers a callback function for receiving the page beforeunload event.
 * Hook onto this event to perform process right prior to page close, and/or display a confirmation notification asking if the user really wants to leave the page.
 * http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#beforeunloadevent
 */
typedef const char *(*em_beforeunload_callback)(int eventType, const void *reserved, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_beforeunload_callback(void *userData, em_beforeunload_callback callback);

// Represents a handle to an Emscripten WebGL context object. The value 0 denotes an invalid/no context.
typedef int EMSCRIPTEN_WEBGL_CONTEXT_HANDLE;

/*
 * Specifies WebGL context creation parameters, as documented at http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2
 */
typedef struct EmscriptenWebGLContextAttributes {
  // If true, request an alpha channel for the context. If you create an alpha channel, you can blend the canvas rendering with the
  // underlying web page contents. Default value: true.
  EM_BOOL alpha;
  // If true, request a depth buffer of at least 16 bits. If false, no depth buffer will be initialized. Default value: true.
  EM_BOOL depth;
  // If true, request a stencil buffer of at least 8 bits. If false, no stencil buffer will be initialized. Default value: false.
  EM_BOOL stencil;
  // If true, antialiasing will be initialized with a browser-specified algorithm and quality level. If false, antialiasing is disabled. Default value: true.
  EM_BOOL antialias;
  // If true, the alpha channel of the rendering context will be treated as representing premultiplied alpha values. If false, the alpha
  // channel represents non-premultiplied alpha. Default value: true.
  EM_BOOL premultipliedAlpha;
  // If true, the contents of the drawing buffer are preserved between consecutive requestAnimationFrame() calls. If false, color, depth
  // and stencil are cleared at the beginning of each requestAnimationFrame(). Generally setting this to false gives better performance. Default value: false.
  EM_BOOL preserveDrawingBuffer;
  // If true, hints the browser to initialize a low-power GPU rendering context. If false, prefers to initialize a high-performance
  // rendering context. Default value: false.
  EM_BOOL preferLowPowerToHighPerformance;
  // If true, requests context creation to abort if the browser is only able to create a context that does not give good 
  // hardware-accelerated performance. Default value: false.
  EM_BOOL failIfMajorPerformanceCaveat;

  // Emscripten-specific extensions:
  // majorVersion x minorVersion: Specifies the WebGL context version to initialize.
  // For example, pass in majorVersion=1, minorVersion=0 to request a WebGL 1.0 context, and
  // majorVersion=2, minorVersion=0 to request a WebGL 2.0 context.
  // Default value: majorVersion=1, minorVersion=0
  int majorVersion;
  int minorVersion;

  // If true, all GLES2-compatible non-performance-impacting WebGL extensions will automatically be enabled for you after the context
  // has been created. If false, no extensions are enabled by default, and you need to manually call emscripten_webgl_enable_extension()
  // to enable each extension that you want to use. Default value: true.
  EM_BOOL enableExtensionsByDefault;
} EmscriptenWebGLContextAttributes;

/*
 * Populates all fields of the given EmscriptenWebGLContextAttributes structure to their default values for use with WebGL 1.0.
 * Call this function as a forward-compatible way to ensure that if there are new fields added to the EmscriptenWebGLContextAttributes
 * structure in the future, that they also will get default-initialized without having to change any code.
 */
extern void emscripten_webgl_init_context_attributes(EmscriptenWebGLContextAttributes *attributes);

/*
 * Creates a new WebGL context. See http://www.khronos.org/registry/webgl/specs/latest/1.0/#2.1
 * The parameter 'target' specifies the DOM canvas element in which to initialize the WebGL context. If 0 is passed for the target,
 * the element specified by Module.canvas will be used.
 * On success, this function returns a strictly positive value that represents a handle to the created context.
 * On failure, this function returns a negative number that can be casted to a EMSCRIPTEN_RESULT field to get an error reason
 * why the context creation failed.
 * NOTE: A successful call to emscripten_webgl_create_context() will not immediately make that rendering context active. Call
 *       emscripten_webgl_make_context_current() after creating a context to activate it.
 * NOTE: This function will try to initialize the context version that was *exactly* requested. It will not e.g. initialize a newer
 *       backwards-compatible version or similar. 
 */ 
extern EMSCRIPTEN_WEBGL_CONTEXT_HANDLE emscripten_webgl_create_context(const char *target, const EmscriptenWebGLContextAttributes *attributes);

/*
 * Activates the given WebGL context for rendering. After calling this function, all gl***() functions apply to the given GL context.
 */
extern EMSCRIPTEN_RESULT emscripten_webgl_make_context_current(EMSCRIPTEN_WEBGL_CONTEXT_HANDLE context);

/*
 * Returns the currently active WebGL rendering context, or 0 if no such context is active. Calling any WebGL functions when there is no active
 * rendering context is undefined and may throw a JavaScript exception.
 */
extern EMSCRIPTEN_WEBGL_CONTEXT_HANDLE emscripten_webgl_get_current_context();

/*
 * Deletes the given WebGL context. If that context was active, then the no context is set to active.
 */
extern EMSCRIPTEN_RESULT emscripten_webgl_destroy_context(EMSCRIPTEN_WEBGL_CONTEXT_HANDLE context);

/*
 * Enables the given extension on the given context.
 * Returns EM_TRUE if the given extension is supported by the context, and EM_FALSE if the extension was not available.
 */
extern EM_BOOL emscripten_webgl_enable_extension(EMSCRIPTEN_WEBGL_CONTEXT_HANDLE context, const char *extension);

/*
 * Registers a callback function for the canvas webgl context webglcontextlost and webglcontextrestored events.
 * See http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.15.2
 */
typedef EM_BOOL (*em_webgl_context_callback)(int eventType, const void *reserved, void *userData);
extern EMSCRIPTEN_RESULT emscripten_set_webglcontextlost_callback(const char *target, void *userData, EM_BOOL useCapture, em_webgl_context_callback callback);
extern EMSCRIPTEN_RESULT emscripten_set_webglcontextrestored_callback(const char *target, void *userData, EM_BOOL useCapture, em_webgl_context_callback callback);

/*
 * Queries the given canvas element for whether its WebGL context is in a lost state.
 * target: Reserved for future use, pass in 0.
 */
extern EM_BOOL emscripten_is_webgl_context_lost(const char *target);

#ifdef __cplusplus
} // ~extern "C"
#endif

#endif

VaKeR 2022