 942bbfaefe
			
		
	
	
		942bbfaefe
		
			
		
	
	
	
	
		
			
			* add input debounce code from old fw * exampl of input api * change input API to get/release * revert input API to read * pointer instead of instance * add input API description * add display API * rewrite display names * migrate to valuemanager * add LED API * add closing brakets * add sound api * fix led api * basic api * rename API pages * change pubsub implementation * move FURI AC -> flapp, add valuemutex example, add valuemanager implementation * pubsub usage example * user led example * update example * simplify input * add composed display * add SPI/GPIO and CC1101 bus * change cc1101 api * spi api and devices * spi api and devices * move SPI to page, add GPIO * not block pin open * backlight API and more * add minunit tests * fix logging * ignore unexisting time service on embedded targets * fix warning, issue with printf * Deprecate furi_open and furi_close (#167) Rename existing furi_open and furi_close to deprecated version * add exitcode * migrate to printf * indicate test by leds * add testing description * rename furi.h * wip basic api * add valuemutex, pubsub, split files * add value expanders * value mutex realization and tests * valuemutex test added to makefile * do not build unimplemented files * fix build furmware target f2 * redesigned minunit tests to allow testing in separate files * test file for valuemutex minunit testing * minunit partial test valuemutex * local cmsis_os2 mutex bindings * implement furi open/create, tests * migrate concurrent_access to ValueMutex * add spi header * Lib: add mlib submodule. Co-authored-by: rusdacent <rusdacentx0x08@gmail.com> Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include "flipper.h"
 | |
| 
 | |
| // == Flipper Application control (flapp) ==
 | |
| 
 | |
| typedef FlappHandler uint32_t; // TODO
 | |
| 
 | |
| /*
 | |
| simply starts application. It call `app` entrypoint with `param` passed as argument
 | |
| Useful for daemon applications and pop-up.
 | |
| */
 | |
| FlappHandler* flapp_start(void(app*)(void*), char* name, void* param);
 | |
| 
 | |
| /*
 | |
| swtich to other application.
 | |
| System **stop current app**, call `app` entrypoint with `param` passed
 | |
| as argument and save current application entrypoint to `prev` field in
 | |
| current application registry. Useful for UI or "active" application.
 | |
| */
 | |
| FlappHandler* flapp_switch(void(app*)(void*), char* name, void* param);
 | |
| 
 | |
| /*
 | |
| Exit application
 | |
| stop current application (stop thread and clear application's stack),
 | |
| start application from `prev` entry in current application registry,
 | |
| cleanup current application registry.
 | |
| */
 | |
| void flapp_exit(void* param);
 | |
| 
 | |
| /*
 | |
| stop specified `app` without returning to `prev` application.
 | |
| */
 | |
| bool flapp_kill(FlappHandler* app);
 | |
| 
 | |
| /*
 | |
| If case one app depend on other, notify that app is ready.
 | |
| */
 | |
| void flapp_ready();
 | |
| 
 | |
| /*
 | |
| Register on-exit callback.
 | |
| It called before app will be killed.
 | |
| Not recommended to use in user scenario, only for system purpose
 | |
| (unregister callbacks, release mutexes, etc.)
 | |
| */
 | |
| bool flapp_on_exit(void(cb*)(void*), void* ctx);
 |