mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-30 12:30:23 -04:00 
			
		
		
		
	
		
			
	
	
		
			32 lines
		
	
	
		
			772 B
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			32 lines
		
	
	
		
			772 B
		
	
	
	
		
			C++
		
	
	
	
	
	
|  | #include <boost/crc.hpp>
 | ||
|  | #include <boost/config.hpp>
 | ||
|  | 
 | ||
|  | extern "C" | ||
|  | { | ||
|  |    short crc13 (unsigned char const * data, int length); | ||
|  |    bool crc13_check (unsigned char const * data, int length); | ||
|  | } | ||
|  | 
 | ||
|  | #define POLY 0x15D7
 | ||
|  | 
 | ||
|  | #ifdef BOOST_NO_CXX11_CONSTEXPR
 | ||
|  | #define TRUNCATED_POLYNOMIAL POLY
 | ||
|  | #else
 | ||
|  | namespace | ||
|  | { | ||
|  |   unsigned long constexpr TRUNCATED_POLYNOMIAL = POLY; | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | // assumes CRC is last 13 bits of the data and is set to zero
 | ||
|  | // caller should assign the returned CRC into the message in big endian byte order
 | ||
|  | short crc13 (unsigned char const * data, int length) | ||
|  | { | ||
|  |     return boost::augmented_crc<13, TRUNCATED_POLYNOMIAL> (data, length); | ||
|  | } | ||
|  | 
 | ||
|  | bool crc13_check (unsigned char const * data, int length) | ||
|  | { | ||
|  |    return !boost::augmented_crc<13, TRUNCATED_POLYNOMIAL> (data, length); | ||
|  | } |