 b9a766d909
			
		
	
	
		b9a766d909
		
	
	
	
	
		
			
			* Added support for running applications from SD card (FAPs - Flipper Application Packages) * Added plugin_dist target for fbt to build FAPs * All apps of type FlipperAppType.EXTERNAL and FlipperAppType.PLUGIN are built as FAPs by default * Updated VSCode configuration for new fbt features - re-deploy stock configuration to use them * Added debugging support for FAPs with fbt debug & VSCode * Added public firmware API with automated versioning Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: SG <who.just.the.doctor@gmail.com> Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include "types.h"
 | |
| #include "protocols/base.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| typedef struct SubGhzReceiver SubGhzReceiver;
 | |
| 
 | |
| typedef void (*SubGhzReceiverCallback)(
 | |
|     SubGhzReceiver* decoder,
 | |
|     SubGhzProtocolDecoderBase* decoder_base,
 | |
|     void* context);
 | |
| 
 | |
| /**
 | |
|  * Allocate and init SubGhzReceiver.
 | |
|  * @param environment Pointer to a SubGhzEnvironment instance
 | |
|  * @return SubGhzReceiver* pointer to a SubGhzReceiver instance
 | |
|  */
 | |
| SubGhzReceiver* subghz_receiver_alloc_init(SubGhzEnvironment* environment);
 | |
| 
 | |
| /**
 | |
|  * Free SubGhzReceiver.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  */
 | |
| void subghz_receiver_free(SubGhzReceiver* instance);
 | |
| 
 | |
| /**
 | |
|  * Parse a raw sequence of levels and durations received from the air.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  * @param level Signal level true-high false-low
 | |
|  * @param duration Duration of this level in, us
 | |
|  */
 | |
| void subghz_receiver_decode(SubGhzReceiver* instance, bool level, uint32_t duration);
 | |
| 
 | |
| /**
 | |
|  * Reset decoder SubGhzReceiver.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  */
 | |
| void subghz_receiver_reset(SubGhzReceiver* instance);
 | |
| 
 | |
| /**
 | |
|  * Set a callback upon completion of successful decoding of one of the protocols.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  * @param callback Callback, SubGhzReceiverCallback
 | |
|  * @param context Context
 | |
|  */
 | |
| void subghz_receiver_set_rx_callback(
 | |
|     SubGhzReceiver* instance,
 | |
|     SubGhzReceiverCallback callback,
 | |
|     void* context);
 | |
| 
 | |
| /**
 | |
|  * Set the filter of receivers that will work at the moment.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  * @param filter Filter, SubGhzProtocolFlag
 | |
|  */
 | |
| void subghz_receiver_set_filter(SubGhzReceiver* instance, SubGhzProtocolFlag filter);
 | |
| 
 | |
| /**
 | |
|  * Search for a cattery by his name.
 | |
|  * @param instance Pointer to a SubGhzReceiver instance
 | |
|  * @param decoder_name Receiver name
 | |
|  * @return SubGhzProtocolDecoderBase* pointer to a SubGhzProtocolDecoderBase instance
 | |
|  */
 | |
| SubGhzProtocolDecoderBase*
 | |
|     subghz_receiver_search_decoder_base_by_name(SubGhzReceiver* instance, const char* decoder_name);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |