Tasmota/lib/lib_basic/IRremoteESP8266/src/IRutils.h

133 lines
6.6 KiB
C++

#ifndef IRUTILS_H_
#define IRUTILS_H_
// Copyright 2017 David Conran
#ifndef UNIT_TEST
#include <Arduino.h>
#endif
#define __STDC_LIMIT_MACROS
#include <stdint.h>
#ifndef ARDUINO
#include <string>
#endif
#include "IRremoteESP8266.h"
#include "IRrecv.h"
const uint8_t kNibbleSize = 4;
const uint8_t kLowNibble = 0;
const uint8_t kHighNibble = 4;
const uint8_t kModeBitsSize = 3;
uint64_t reverseBits(uint64_t input, uint16_t nbits);
String uint64ToString(uint64_t input, uint8_t base = 10);
String typeToString(const decode_type_t protocol,
const bool isRepeat = false);
void serialPrintUint64(uint64_t input, uint8_t base = 10);
String resultToSourceCode(const decode_results * const results);
String resultToTimingInfo(const decode_results * const results);
String resultToHumanReadableBasic(const decode_results * const results);
String resultToHexidecimal(const decode_results * const result);
bool hasACState(const decode_type_t protocol);
uint16_t getCorrectedRawLength(const decode_results * const results);
uint16_t *resultToRawArray(const decode_results * const decode);
uint8_t sumBytes(const uint8_t * const start, const uint16_t length,
const uint8_t init = 0);
uint8_t xorBytes(const uint8_t * const start, const uint16_t length,
const uint8_t init = 0);
uint16_t countBits(const uint8_t * const start, const uint16_t length,
const bool ones = true, const uint16_t init = 0);
uint16_t countBits(const uint64_t data, const uint8_t length,
const bool ones = true, const uint16_t init = 0);
uint64_t invertBits(const uint64_t data, const uint16_t nbits);
decode_type_t strToDecodeType(const char *str);
float celsiusToFahrenheit(const float deg);
float fahrenheitToCelsius(const float deg);
/// Namespace for covering common functions & procedures for advancd protocol
/// handlers
namespace irutils {
String addBoolToString(const bool value, const String label,
const bool precomma = true);
String addIntToString(const uint16_t value, const String label,
const bool precomma = true);
String modelToStr(const decode_type_t protocol, const int16_t model);
String addModelToString(const decode_type_t protocol, const int16_t model,
const bool precomma = true);
String addLabeledString(const String value, const String label,
const bool precomma = true);
String addTempToString(const uint16_t degrees, const bool celsius = true,
const bool precomma = true);
String addTempFloatToString(const float degrees, const bool celsius = true,
const bool precomma = true);
String addModeToString(const uint8_t mode, const uint8_t automatic,
const uint8_t cool, const uint8_t heat,
const uint8_t dry, const uint8_t fan);
String addFanToString(const uint8_t speed, const uint8_t high,
const uint8_t low, const uint8_t automatic,
const uint8_t quiet, const uint8_t medium,
const uint8_t maximum = 0xFF);
String addSwingHToString(const uint8_t position, const uint8_t automatic,
const uint8_t maxleft, const uint8_t left,
const uint8_t middle,
const uint8_t right, const uint8_t maxright,
const uint8_t off,
const uint8_t leftright, const uint8_t rightleft,
const uint8_t threed, const uint8_t wide);
String addSwingVToString(const uint8_t position, const uint8_t automatic,
const uint8_t highest, const uint8_t high,
const uint8_t uppermiddle,
const uint8_t middle,
const uint8_t lowermiddle,
const uint8_t low, const uint8_t lowest,
const uint8_t off, const uint8_t swing,
const uint8_t breeze, const uint8_t circulate);
String addDayToString(const uint8_t day_of_week, const int8_t offset = 0,
const bool precomma = true);
String htmlEscape(const String unescaped);
String msToString(uint32_t const msecs);
String minsToString(const uint16_t mins);
uint8_t sumNibbles(const uint8_t * const start, const uint16_t length,
const uint8_t init = 0);
uint8_t sumNibbles(const uint64_t data, const uint8_t count = 16,
const uint8_t init = 0, const bool nibbleonly = true);
uint8_t bcdToUint8(const uint8_t bcd);
uint8_t uint8ToBcd(const uint8_t integer);
bool getBit(const uint64_t data, const uint8_t position,
const uint8_t size = 64);
bool getBit(const uint8_t data, const uint8_t position);
#define GETBIT8(a, b) (a & ((uint8_t)1 << b))
#define GETBIT16(a, b) (a & ((uint16_t)1 << b))
#define GETBIT32(a, b) (a & ((uint32_t)1 << b))
#define GETBIT64(a, b) (a & ((uint64_t)1 << b))
#define GETBITS8(data, offset, size) \
(((data) & (((uint8_t)UINT8_MAX >> (8 - (size))) << (offset))) >> (offset))
#define GETBITS16(data, offset, size) \
(((data) & (((uint16_t)UINT16_MAX >> (16 - (size))) << (offset))) >> \
(offset))
#define GETBITS32(data, offset, size) \
(((data) & (((uint32_t)UINT32_MAX >> (32 - (size))) << (offset))) >> \
(offset))
#define GETBITS64(data, offset, size) \
(((data) & (((uint64_t)UINT64_MAX >> (64 - (size))) << (offset))) >> \
(offset))
uint64_t setBit(const uint64_t data, const uint8_t position,
const bool on = true, const uint8_t size = 64);
uint8_t setBit(const uint8_t data, const uint8_t position,
const bool on = true);
void setBit(uint8_t * const data, const uint8_t position,
const bool on = true);
void setBit(uint32_t * const data, const uint8_t position,
const bool on = true);
void setBit(uint64_t * const data, const uint8_t position,
const bool on = true);
void setBits(uint8_t * const dst, const uint8_t offset, const uint8_t nbits,
const uint8_t data);
void setBits(uint32_t * const dst, const uint8_t offset, const uint8_t nbits,
const uint32_t data);
void setBits(uint64_t * const dst, const uint8_t offset, const uint8_t nbits,
const uint64_t data);
uint8_t * invertBytePairs(uint8_t *ptr, const uint16_t length);
bool checkInvertedBytePairs(const uint8_t * const ptr, const uint16_t length);
uint8_t lowLevelSanityCheck(void);
} // namespace irutils
#endif // IRUTILS_H_