 e3c7201a20
			
		
	
	
		e3c7201a20
		
			
		
	
	
	
	
		
			
			* Furi: rename and move core * Furi: drop CMSIS_OS header and unused api, partially refactor and cleanup the rest * Furi: CMSIS_OS drop and refactoring. * Furi: refactoring, remove cmsis legacy * Furi: fix incorrect assert on queue deallocation, cleanup timer * Furi: improve delay api, get rid of floats * hal: dropped furi_hal_crc * Furi: move DWT based delay to cortex HAL * Furi: update core documentation Co-authored-by: hedger <hedger@nanode.su>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "dialogs/dialogs_message.h"
 | |
| #include "dialogs_i.h"
 | |
| #include "dialogs_api_lock.h"
 | |
| #include "dialogs_module_file_browser.h"
 | |
| #include "dialogs_module_message.h"
 | |
| 
 | |
| static DialogsApp* dialogs_app_alloc() {
 | |
|     DialogsApp* app = malloc(sizeof(DialogsApp));
 | |
|     app->message_queue = furi_message_queue_alloc(8, sizeof(DialogsAppMessage));
 | |
| 
 | |
|     return app;
 | |
| }
 | |
| 
 | |
| static void dialogs_app_process_message(DialogsApp* app, DialogsAppMessage* message) {
 | |
|     UNUSED(app);
 | |
|     switch(message->command) {
 | |
|     case DialogsAppCommandFileBrowser:
 | |
|         message->return_data->bool_value =
 | |
|             dialogs_app_process_module_file_browser(&message->data->file_browser);
 | |
|         break;
 | |
|     case DialogsAppCommandDialog:
 | |
|         message->return_data->dialog_value =
 | |
|             dialogs_app_process_module_message(&message->data->dialog);
 | |
|         break;
 | |
|     }
 | |
|     API_LOCK_UNLOCK(message->lock);
 | |
| }
 | |
| 
 | |
| int32_t dialogs_srv(void* p) {
 | |
|     UNUSED(p);
 | |
|     DialogsApp* app = dialogs_app_alloc();
 | |
|     furi_record_create("dialogs", app);
 | |
| 
 | |
|     DialogsAppMessage message;
 | |
|     while(1) {
 | |
|         if(furi_message_queue_get(app->message_queue, &message, FuriWaitForever) == FuriStatusOk) {
 | |
|             dialogs_app_process_message(app, &message);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 |