2022-09-24 19:35:56 -04:00
/*
2023-08-19 17:49:08 -04:00
WebUI Library 2.4 .0
2023-04-17 15:43:46 -04:00
http : //webui.me
2023-05-13 10:47:42 -04:00
https : //github.com/webui-dev/webui
2023-04-17 15:43:46 -04:00
Copyright ( c ) 2020 - 2023 Hassan Draga .
2023-05-04 21:41:03 -04:00
Licensed under MIT License .
2023-04-17 15:43:46 -04:00
All rights reserved .
Canada .
2022-09-24 19:35:56 -04:00
*/
# ifndef _WEBUI_H
# define _WEBUI_H
2023-08-19 17:49:08 -04:00
# define WEBUI_VERSION "2.4.0"
2023-09-11 18:09:42 -04:00
// Max windows, servers and threads
2023-05-07 13:54:15 -04:00
# define WEBUI_MAX_IDS (512)
2023-04-17 15:43:46 -04:00
// Dynamic Library Exports
2022-09-24 19:35:56 -04:00
# if defined(_MSC_VER) || defined(__TINYC__)
2023-04-17 15:43:46 -04:00
# ifndef WEBUI_EXPORT
# define WEBUI_EXPORT __declspec(dllexport)
# endif
2022-09-24 19:35:56 -04:00
# else
2023-04-17 15:43:46 -04:00
# ifndef WEBUI_EXPORT
# define WEBUI_EXPORT extern
# endif
2022-09-24 19:35:56 -04:00
# endif
2022-10-19 19:48:47 -04:00
// -- C STD ---------------------------
2022-09-24 19:35:56 -04:00
# include <stdbool.h>
# include <inttypes.h>
# include <assert.h>
# include <stdint.h>
# include <stdlib.h>
# include <string.h>
# include <stdio.h>
# include <ctype.h>
# include <stddef.h>
# include <time.h>
# include <errno.h>
2022-12-12 10:13:27 -05:00
# include <math.h>
2022-09-24 19:35:56 -04:00
# if defined(__GNUC__) || defined(__TINYC__)
# include <dirent.h>
# endif
2022-10-19 19:48:47 -04:00
// -- Windows -------------------------
2022-09-24 19:35:56 -04:00
# ifdef _WIN32
2022-11-07 23:33:03 -05:00
# ifndef WIN32_LEAN_AND_MEAN
# define WIN32_LEAN_AND_MEAN
# endif
2022-09-24 19:35:56 -04:00
# include <windows.h>
2022-11-07 23:33:03 -05:00
# include <winsock2.h>
2022-09-24 19:35:56 -04:00
# include <ws2tcpip.h>
# include <direct.h>
# include <io.h>
# include <tchar.h>
2023-05-04 21:41:03 -04:00
# include <tlhelp32.h>
2022-09-24 19:35:56 -04:00
# define WEBUI_GET_CURRENT_DIR _getcwd
# define WEBUI_FILE_EXIST _access
2022-09-28 19:41:24 -04:00
# define WEBUI_POPEN _popen
# define WEBUI_PCLOSE _pclose
2022-10-23 20:06:15 -04:00
# define WEBUI_MAX_PATH MAX_PATH
2022-09-24 19:35:56 -04:00
# endif
2023-04-17 15:43:46 -04:00
2022-10-19 19:48:47 -04:00
// -- Linux ---------------------------
2022-09-24 19:35:56 -04:00
# ifdef __linux__
2023-04-24 17:44:27 -04:00
# include <unistd.h>
2023-04-17 15:43:46 -04:00
# include <pthread.h>
2022-09-24 19:35:56 -04:00
# include <unistd.h>
2022-10-23 20:06:15 -04:00
# include <limits.h>
# include <dirent.h>
# include <sys/socket.h>
# include <fcntl.h>
# include <poll.h>
2023-04-17 15:43:46 -04:00
# include <sys/time.h>
2023-05-07 13:54:15 -04:00
# include <signal.h>
2022-09-24 19:35:56 -04:00
# define WEBUI_GET_CURRENT_DIR getcwd
2022-10-23 20:06:15 -04:00
# define WEBUI_FILE_EXIST access
2022-09-28 19:41:24 -04:00
# define WEBUI_POPEN popen
# define WEBUI_PCLOSE pclose
2022-10-23 20:06:15 -04:00
# define WEBUI_MAX_PATH PATH_MAX
2022-09-24 19:35:56 -04:00
# endif
2023-04-17 15:43:46 -04:00
2023-03-28 15:50:10 -05:00
// -- Apple ---------------------------
# ifdef __APPLE__
2023-04-17 15:43:46 -04:00
# include <pthread.h>
2023-03-28 15:50:10 -05:00
# include <unistd.h>
# include <limits.h>
# include <dirent.h>
# include <sys/socket.h>
# include <fcntl.h>
# include <poll.h>
2023-04-25 17:56:57 -04:00
# include <sys/syslimits.h>
2023-04-17 15:43:46 -04:00
# include <sys/time.h>
2023-04-24 17:44:27 -04:00
# include <sys/sysctl.h>
2023-05-07 13:54:15 -04:00
# include <signal.h>
2023-03-28 15:50:10 -05:00
# define WEBUI_GET_CURRENT_DIR getcwd
# define WEBUI_FILE_EXIST access
# define WEBUI_POPEN popen
# define WEBUI_PCLOSE pclose
# define WEBUI_MAX_PATH PATH_MAX
# endif
2022-10-19 00:38:54 -04:00
2023-04-17 15:43:46 -04:00
// -- Enums ---------------------------
enum webui_browsers {
AnyBrowser = 0 , // 0. Default recommended web browser
Chrome , // 1. Google Chrome
Firefox , // 2. Mozilla Firefox
Edge , // 3. Microsoft Edge
Safari , // 4. Apple Safari
Chromium , // 5. The Chromium Project
Opera , // 6. Opera Browser
Brave , // 7. The Brave Browser
Vivaldi , // 8. The Vivaldi Browser
Epic , // 9. The Epic Browser
Yandex , // 10. The Yandex Browser
2023-09-22 09:04:37 +02:00
ChromiumBased , // 11. Any Chromium based browser
2023-04-17 15:43:46 -04:00
} ;
enum webui_runtimes {
None = 0 , // 0. Prevent WebUI from using any runtime for .js and .ts files
Deno , // 1. Use Deno runtime for .js and .ts files
NodeJS , // 2. Use Nodejs runtime for .js files
} ;
enum webui_events {
WEBUI_EVENT_DISCONNECTED = 0 , // 0. Window disconnection event
WEBUI_EVENT_CONNECTED , // 1. Window connection event
WEBUI_EVENT_MULTI_CONNECTION , // 2. New window connection event
WEBUI_EVENT_UNWANTED_CONNECTION , // 3. New unwanted window connection event
WEBUI_EVENT_MOUSE_CLICK , // 4. Mouse click event
WEBUI_EVENT_NAVIGATION , // 5. Window navigation event
WEBUI_EVENT_CALLBACK , // 6. Function call event
} ;
2022-10-29 21:41:20 -04:00
// -- Structs -------------------------
typedef struct webui_event_t {
2023-05-05 17:41:20 -04:00
size_t window ; // The window object number
2023-05-07 13:54:15 -04:00
size_t event_type ; // Event type
2023-04-29 13:46:11 -04:00
char * element ; // HTML element ID
2023-04-17 15:43:46 -04:00
char * data ; // JavaScript data
2023-08-30 19:47:31 -04:00
size_t size ; // JavaScript data len
2023-05-07 13:54:15 -04:00
size_t event_number ; // Internal WebUI
2022-10-29 21:41:20 -04:00
} webui_event_t ;
2022-09-24 19:35:56 -04:00
2022-10-19 19:48:47 -04:00
// -- Definitions ---------------------
2023-09-11 18:09:42 -04:00
/**
2023-09-13 15:32:14 -04:00
* @ brief Create a new WebUI window object .
2023-09-11 18:09:42 -04:00
*
* @ return Returns the window number .
*
2023-09-13 15:32:14 -04:00
* @ example size_t myWindow = webui_new_window ( ) ;
2023-09-11 18:09:42 -04:00
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT size_t webui_new_window ( void ) ;
2023-09-11 18:09:42 -04:00
/**
2023-09-13 15:32:14 -04:00
* @ brief Create a new webui window object using a specified window number .
2023-09-11 18:09:42 -04:00
*
2023-09-13 15:32:14 -04:00
* @ param window_number The window number ( should be > 0 , and < WEBUI_MAX_IDS )
2023-09-11 18:09:42 -04:00
*
2023-09-13 15:32:14 -04:00
* @ return Returns the window number .
*
* @ example size_t myWindow = webui_new_window_id ( 123 ) ;
2023-09-11 18:09:42 -04:00
*/
WEBUI_EXPORT size_t webui_new_window_id ( size_t window_number ) ;
/**
* @ brief Get a free window number that can be used with ` webui_new_window_id ( ) ` .
*
2023-09-13 15:32:14 -04:00
* @ return Returns the first available free window number . Starting from 1.
*
* @ example size_t myWindowNumber = webui_get_new_window_id ( ) ;
2023-09-11 18:09:42 -04:00
*/
2023-05-09 07:48:27 -04:00
WEBUI_EXPORT size_t webui_get_new_window_id ( void ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Bind a specific html element click event with a function . Empty element means all events .
*
* @ param window The window number
* @ param element The HTML ID
* @ param func The callback function
*
* @ return Returns a unique bind ID .
*
* @ example webui_bind ( myWindow , " myID " , myFunction ) ;
*/
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT size_t webui_bind ( size_t window , const char * element , void ( * func ) ( webui_event_t * e ) ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Show a window using embedded HTML , or a file . If the window is already open , it will be refreshed .
*
* @ param window The window number
* @ param content The HTML , Or a local file
*
* @ return Returns True if showing the window is successed .
*
* @ example webui_show ( myWindow , " <html>...</html> " ) ; | webui_show ( myWindow , " index.html " ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT bool webui_show ( size_t window , const char * content ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Same as ` webui_show ( ) ` . But using a specific web browser .
*
* @ param window The window number
* @ param content The HTML , Or a local file
* @ param browser The web browser to be used
*
* @ return Returns True if showing the window is successed .
*
* @ example webui_show_browser ( myWindow , " <html>...</html> " , Chrome ) ; | webui_show ( myWindow , " index.html " , Firefox ) ;
*/
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT bool webui_show_browser ( size_t window , const char * content , size_t browser ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the window in Kiosk mode ( Full screen )
*
* @ param window The window number
* @ param status True or False
*
* @ example webui_set_kiosk ( myWindow , true ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT void webui_set_kiosk ( size_t window , bool status ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Wait until all opened windows get closed .
*
* @ example webui_wait ( ) ;
*/
2023-04-17 15:43:46 -04:00
WEBUI_EXPORT void webui_wait ( void ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Close a specific window only . The window object will still exist .
*
* @ param window The window number
*
* @ example webui_close ( myWindow ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT void webui_close ( size_t window ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Close a specific window and free all memory resources .
*
* @ param window The window number
*
* @ example webui_destroy ( myWindow ) ;
*/
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT void webui_destroy ( size_t window ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Close all open windows . ` webui_wait ( ) ` will return ( Break ) .
*
* @ example webui_exit ( ) ;
*/
2023-04-17 15:43:46 -04:00
WEBUI_EXPORT void webui_exit ( void ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the web - server root folder path for a specific window .
*
* @ param window The window number
* @ param path The local folder full path
*
* @ example webui_set_root_folder ( myWindow , " /home/Foo/Bar/ " ) ;
*/
2023-05-27 20:30:31 -04:00
WEBUI_EXPORT bool webui_set_root_folder ( size_t window , const char * path ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the web - server root folder path for all windows . Should be used before ` webui_show ( ) ` .
*
* @ param path The local folder full path
*
* @ example webui_set_default_root_folder ( " /home/Foo/Bar/ " ) ;
*/
2023-08-24 21:54:13 -04:00
WEBUI_EXPORT bool webui_set_default_root_folder ( const char * path ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set a custom handler to serve files .
*
* @ param window The window number
* @ param handler The handler function : ` void myHandler ( const char * filename , int * length ) `
*
* @ return Returns a unique bind ID .
*
* @ example webui_set_file_handler ( myWindow , myHandlerFunction ) ;
*/
2023-06-26 12:11:03 -04:00
WEBUI_EXPORT void webui_set_file_handler ( size_t window , const void * ( * handler ) ( const char * filename , int * length ) ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Check if the specified window is still running .
*
* @ param window The window number
*
* @ example webui_is_shown ( myWindow ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT bool webui_is_shown ( size_t window ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the maximum time in seconds to wait for the browser to start .
*
* @ param second The timeout in seconds
*
* @ example webui_set_timeout ( 30 ) ;
*/
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT void webui_set_timeout ( size_t second ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the default embedded HTML favicon .
*
* @ param window The window number
* @ param icon The icon as string : ` < svg > . . . < / svg > `
* @ param icon_type The icon type : ` image / svg + xml `
*
* @ example webui_set_icon ( myWindow , " <svg>...</svg> " , " image/svg+xml " ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT void webui_set_icon ( size_t window , const char * icon , const char * icon_type ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Allow the window URL to be re - used in normal web browsers .
*
* @ param window The window number
* @ param status The status : True or False
*
* @ example webui_set_multi_access ( myWindow , true ) ;
*/
2023-05-04 21:41:03 -04:00
WEBUI_EXPORT void webui_set_multi_access ( size_t window , bool status ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Base64 encoding . Use this to safely send text based data to the UI . If it fails it will return NULL .
*
* @ param str The string to encode ( Should be null terminated )
*
* @ example webui_encode ( " Hello " ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT char * webui_encode ( const char * str ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Base64 decoding . Use this to safely decode received Base64 text from the UI . If it fails it will return NULL .
*
* @ param str The string to decode ( Should be null terminated )
*
* @ example webui_encode ( " SGVsbG8= " ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT char * webui_decode ( const char * str ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Safely free a buffer allocated by WebUI using ` webui_malloc ( ) ` .
*
* @ param ptr The buffer to be freed
*
* @ example webui_free ( myBuffer ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void webui_free ( void * ptr ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Safely allocate memory using the WebUI memory management system . It can be safely freed using ` webui_free ( ) ` at any time .
*
* @ param size The size of memory in bytes
*
* @ example webui_malloc ( 1024 ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void * webui_malloc ( size_t size ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Safely send raw data to the UI .
*
* @ param window The window number
* @ param function The JavaScript function to receive raw data : ` function myFunc ( myData ) { } `
* @ param raw The raw data buffer
* @ param size The raw data size in bytes
*
* @ example webui_send_raw ( myWindow , " myJavascriptFunction " , myBuffer , 64 ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void webui_send_raw ( size_t window , const char * function , const void * raw , size_t size ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set a window in hidden mode . Should be called before ` webui_show ( ) ` .
*
* @ param window The window number
* @ param status The status : True or False
*
* @ example webui_set_hide ( myWindow , True ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void webui_set_hide ( size_t window , bool status ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the window size .
*
* @ param window The window number
* @ param width The window width
* @ param height The window height
*
* @ example webui_set_size ( myWindow , 800 , 600 ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void webui_set_size ( size_t window , unsigned int width , unsigned int height ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Set the window position .
*
* @ param window The window number
* @ param x The window X
* @ param y The window Y
*
* @ example webui_set_position ( myWindow , 100 , 100 ) ;
*/
2023-09-11 17:18:31 -04:00
WEBUI_EXPORT void webui_set_position ( size_t window , unsigned int x , unsigned int y ) ;
WebUI v2.1.0
#New Features
* Supporting more web browsers
* Search for web browsers in Windows Reg.
* Using the same show() function for HTML script, files, and refresh content
* Support Chrome on macOS
#Breaking code
* Switching from `webui_show(win, html, browser);` to `webui_show(win, content);`, and it's used for HTML, files, and reload the window
* Removing `webui_show_cpy()`, `webui_refresh()`, `webui_refresh_cpy()`
2023-03-28 23:00:09 -04:00
2023-09-19 19:34:09 -04:00
/**
* @ brief Set the web browser profile to use . An empty ` name ` and ` path ` means the default user profile . Need to be called before ` webui_show ( ) ` .
*
* @ param window The window number
* @ param name The web browser profile name
* @ param path The web browser profile full path
*
* @ example webui_set_profile ( myWindow , " Bar " , " /Home/Foo/Bar " ) ; | webui_set_profile ( myWindow , " " , " " ) ;
*/
WEBUI_EXPORT void webui_set_profile ( size_t window , const char * name , const char * path ) ;
2023-09-21 07:21:04 +02:00
/**
2023-09-21 16:36:11 -04:00
* @ brief Get the full current URL
2023-09-21 07:21:04 +02:00
*
* @ param window The window number
*
2023-09-21 16:36:11 -04:00
* @ return Returns the full URL string
2023-09-21 07:21:04 +02:00
*
2023-09-21 16:36:11 -04:00
* @ example const char * url = webui_get_url ( myWindow ) ;
2023-09-21 07:21:04 +02:00
*/
2023-09-21 16:36:11 -04:00
WEBUI_EXPORT const char * webui_get_url ( size_t window ) ;
2023-09-21 07:21:04 +02:00
2023-09-26 18:59:25 -04:00
/**
* @ brief Navigate to a specific URL
*
* @ param window The window number
* @ param url Full HTTP URL
*
* @ example webui_navigate ( myWindow , " http://domain.com " ) ;
*/
WEBUI_EXPORT void webui_navigate ( size_t window , const char * url ) ;
2023-09-29 18:36:57 -04:00
/**
* @ brief Delete all local web browser profile ' s folder
*
* @ example webui_clean ( ) ;
*/
WEBUI_EXPORT void webui_clean ( ) ;
2023-04-17 15:43:46 -04:00
// -- JavaScript ----------------------
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// Run JavaScript without waiting for the response.
2023-05-08 23:03:41 -04:00
WEBUI_EXPORT void webui_run ( size_t window , const char * script ) ;
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// Run JavaScript and get the response back (Make sure your local buffer can hold the response).
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT bool webui_script ( size_t window , const char * script , size_t timeout , char * buffer , size_t buffer_length ) ;
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// Chose between Deno and Nodejs as runtime for .js and .ts files.
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT void webui_set_runtime ( size_t window , size_t runtime ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Parse argument as integer.
WEBUI_EXPORT long long int webui_get_int ( webui_event_t * e ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Parse argument as string.
WEBUI_EXPORT const char * webui_get_string ( webui_event_t * e ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Parse argument as boolean.
WEBUI_EXPORT bool webui_get_bool ( webui_event_t * e ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Return the response to JavaScript as integer.
WEBUI_EXPORT void webui_return_int ( webui_event_t * e , long long int n ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Return the response to JavaScript as string.
2023-05-21 12:20:54 -04:00
WEBUI_EXPORT void webui_return_string ( webui_event_t * e , const char * s ) ;
2023-09-11 18:09:42 -04:00
2023-04-17 15:43:46 -04:00
// Return the response to JavaScript as boolean.
WEBUI_EXPORT void webui_return_bool ( webui_event_t * e , bool b ) ;
2022-09-24 19:35:56 -04:00
2023-09-14 17:31:29 -04:00
// Get process id (The web browser may create another process for the window)
WEBUI_EXPORT size_t webui_get_child_process_id ( size_t window ) ;
WEBUI_EXPORT size_t webui_get_parent_process_id ( size_t window ) ;
2023-09-11 17:18:31 -04:00
// -- Wrapper's Interface -------------
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// Bind a specific html element click event with a function. Empty element means all events. This replaces `webui_bind()`. The func is (Window, EventType, Element, Data, DataSize, EventNumber).
2023-08-30 19:47:31 -04:00
WEBUI_EXPORT size_t webui_interface_bind ( size_t window , const char * element , void ( * func ) ( size_t , size_t , char * , char * , size_t , size_t ) ) ;
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// When using `webui_interface_bind()`, you may need this function to easily set your callback response.
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT void webui_interface_set_response ( size_t window , size_t event_number , const char * response ) ;
2023-09-11 18:09:42 -04:00
2023-09-13 15:32:14 -04:00
/**
* @ brief Check if the app still running .
*
* @ example if ( webui_interface_is_app_running ( ) ) . . .
*/
2023-04-17 15:43:46 -04:00
WEBUI_EXPORT bool webui_interface_is_app_running ( void ) ;
2023-09-11 18:09:42 -04:00
2023-08-25 07:31:50 +02:00
// Get a unique window ID.
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT size_t webui_interface_get_window_id ( size_t window ) ;
2023-09-11 18:09:42 -04:00
2023-05-05 17:41:20 -04:00
// Get a unique ID. Same ID as `webui_bind()`. Return > 0 if bind exist.
2023-05-07 13:54:15 -04:00
WEBUI_EXPORT size_t webui_interface_get_bind_id ( size_t window , const char * element ) ;
2022-09-24 19:35:56 -04:00
# endif /* _WEBUI_H */