-#define SAMSUNG_START_BIT_PULSE_TIME 4500.0e-6 // 4500 usec pulse\r
-#define SAMSUNG_START_BIT_PAUSE_TIME 4500.0e-6 // 4500 usec pause\r
-#define SAMSUNG_PULSE_TIME 550.0e-6 // 550 usec pulse\r
-#define SAMSUNG_1_PAUSE_TIME 1450.0e-6 // 1450 usec pause\r
-#define SAMSUNG_0_PAUSE_TIME 450.0e-6 // 450 usec pause\r
-#define SAMSUNG_ADDRESS_OFFSET 0 // skip 0 bits\r
-#define SAMSUNG_ADDRESS_LEN 16 // read 16 address bits\r
-#define SAMSUNG_ID_OFFSET 17 // skip 16 + 1 sync bit\r
-#define SAMSUNG_ID_LEN 4 // read 4 id bits\r
-#define SAMSUNG_COMMAND_OFFSET 21 // skip 16 + 1 sync + 4 data bits\r
-#define SAMSUNG_COMMAND_LEN 16 // read 16 command bits\r
-#define SAMSUNG_COMPLETE_DATA_LEN 37 // complete length\r
-#define SAMSUNG_STOP_BIT 1 // has stop bit\r
-#define SAMSUNG_LSB 1 // LSB...MSB?\r
-\r
-#define SAMSUNG32_COMMAND_OFFSET 16 // skip 16 bits\r
-#define SAMSUNG32_COMMAND_LEN 16 // read 16 command bits\r
-#define SAMSUNG32_COMPLETE_DATA_LEN 32 // complete length\r
-#define SAMSUNG32_REPETITION_CNT 2 // SAMSUNG32 sends each frame 2 times\r
-#define SAMSUNG32_REPETITION_TIME 47.0e-3 // repetition after 47 ms\r
-\r
-#define MATSUSHITA_START_BIT_PULSE_TIME 3488.0e-6 // 3488 usec pulse\r
-#define MATSUSHITA_START_BIT_PAUSE_TIME 3488.0e-6 // 3488 usec pause\r
-#define MATSUSHITA_PULSE_TIME 872.0e-6 // 872 usec pulse\r
-#define MATSUSHITA_1_PAUSE_TIME 2616.0e-6 // 2616 usec pause\r
-#define MATSUSHITA_0_PAUSE_TIME 872.0e-6 // 872 usec pause\r
-#define MATSUSHITA_ADDRESS_OFFSET 12 // skip 12 bits\r
-#define MATSUSHITA_ADDRESS_LEN 12 // read 12 address bits\r
-#define MATSUSHITA_COMMAND_OFFSET 0 // skip 0 bits\r
-#define MATSUSHITA_COMMAND_LEN 12 // read 12 bits (6 custom + 6 command)\r
-#define MATSUSHITA_COMPLETE_DATA_LEN 24 // complete length\r
-#define MATSUSHITA_STOP_BIT 1 // has stop bit\r
-#define MATSUSHITA_LSB 1 // LSB...MSB?\r
-\r
-#define KASEIKYO_START_BIT_PULSE_TIME 3380.0e-6 // 3380 usec pulse\r
-#define KASEIKYO_START_BIT_PAUSE_TIME 1690.0e-6 // 1690 usec pause\r
-#define KASEIKYO_PULSE_TIME 423.0e-6 // 525 usec pulse\r
-#define KASEIKYO_1_PAUSE_TIME 1269.0e-6 // 525 usec pause\r
-#define KASEIKYO_0_PAUSE_TIME 423.0e-6 // 1690 usec pause\r
-#define KASEIKYO_ADDRESS_OFFSET 0 // skip 0 bits\r
-#define KASEIKYO_ADDRESS_LEN 16 // read 16 address bits\r
-#define KASEIKYO_COMMAND_OFFSET 28 // skip 28 bits (16 manufacturer & 4 parity & 8 genre)\r
-#define KASEIKYO_COMMAND_LEN 12 // read 12 command bits (10 real command & 2 id)\r
-#define KASEIKYO_COMPLETE_DATA_LEN 48 // complete length\r
-#define KASEIKYO_STOP_BIT 1 // has stop bit\r
-#define KASEIKYO_LSB 1 // LSB...MSB?\r
-\r
-#define RECS80_START_BIT_PULSE_TIME 158.0e-6 // 158 usec pulse\r
-#define RECS80_START_BIT_PAUSE_TIME 7432.0e-6 // 7432 usec pause\r
-#define RECS80_PULSE_TIME 158.0e-6 // 158 usec pulse\r
-#define RECS80_1_PAUSE_TIME 7432.0e-6 // 7432 usec pause\r
-#define RECS80_0_PAUSE_TIME 4902.0e-6 // 4902 usec pause\r
-#define RECS80_ADDRESS_OFFSET 2 // skip 2 bits (2nd start + 1 toggle)\r
-#define RECS80_ADDRESS_LEN 3 // read 3 address bits\r
-#define RECS80_COMMAND_OFFSET 5 // skip 5 bits (2nd start + 1 toggle + 3 address)\r
-#define RECS80_COMMAND_LEN 6 // read 6 command bits\r
-#define RECS80_COMPLETE_DATA_LEN 11 // complete length\r
-#define RECS80_STOP_BIT 1 // has stop bit\r
-#define RECS80_LSB 0 // MSB...LSB\r
-\r
-#define RC5_BIT_TIME 889.0e-6 // 889 usec pulse/pause\r
-#define RC5_ADDRESS_OFFSET 2 // skip 2 bits (2nd start + 1 toggle)\r
-#define RC5_ADDRESS_LEN 5 // read 5 address bits\r
-#define RC5_COMMAND_OFFSET 7 // skip 5 bits (2nd start + 1 toggle + 5 address)\r
-#define RC5_COMMAND_LEN 6 // read 6 command bits\r
-#define RC5_COMPLETE_DATA_LEN 13 // complete length\r
-#define RC5_STOP_BIT 0 // has no stop bit\r
-#define RC5_LSB 0 // MSB...LSB\r