rtl_433/include/fileformat.h
2021-12-06 10:15:56 +01:00

138 lines
4.5 KiB
C

/** @file
Various utility functions handling file formats.
Copyright (C) 2018 Christian Zuckschwerdt
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
*/
#ifndef INCLUDE_FILEFORMAT_H_
#define INCLUDE_FILEFORMAT_H_
#include <stdint.h>
#include <stdio.h>
char const *file_basename(char const *path);
/// a single handy number to define the file type.
/// bitmask: RRRR LLLL WWWWWWWW 00CC 00FS
enum file_type {
// format bits
F_UNSIGNED = 0 << 0,
F_SIGNED = 1 << 0,
F_INT = 0 << 1,
F_FLOAT = 1 << 1,
F_1CH = 1 << 4,
F_2CH = 2 << 4,
F_W8 = 8 << 8,
F_W12 = 12 << 8,
F_W16 = 16 << 8,
F_W32 = 32 << 8,
F_W64 = 64 << 8,
// content types
F_I = 1 << 16,
F_Q = 2 << 16,
F_AM = 3 << 16,
F_FM = 4 << 16,
F_IQ = F_I | F_Q << 4,
F_LOGIC = 5 << 16,
F_VCD = 6 << 16,
F_OOK = 7 << 16,
// format types
F_U8 = F_1CH | F_UNSIGNED | F_INT | F_W8,
F_S8 = F_1CH | F_SIGNED | F_INT | F_W8,
F_CU8 = F_2CH | F_UNSIGNED | F_INT | F_W8,
F_CS8 = F_2CH | F_SIGNED | F_INT | F_W8,
F_U16 = F_1CH | F_UNSIGNED | F_INT | F_W16,
F_S16 = F_1CH | F_SIGNED | F_INT | F_W16,
F_CU16 = F_2CH | F_UNSIGNED | F_INT | F_W16,
F_CS16 = F_2CH | F_SIGNED | F_INT | F_W16,
F_U32 = F_1CH | F_UNSIGNED | F_INT | F_W32,
F_S32 = F_1CH | F_SIGNED | F_INT | F_W32,
F_CU32 = F_2CH | F_UNSIGNED | F_INT | F_W32,
F_CS32 = F_2CH | F_SIGNED | F_INT | F_W32,
F_F32 = F_1CH | F_SIGNED | F_FLOAT | F_W32,
F_CF32 = F_2CH | F_SIGNED | F_FLOAT | F_W32,
// compound types
CU8_IQ = F_CU8 | F_IQ,
CS8_IQ = F_CS8 | F_IQ,
S16_AM = F_S16 | F_AM,
S16_FM = F_S16 | F_FM,
CS16_IQ = F_CS16 | F_IQ,
CF32_IQ = F_CF32 | F_IQ,
F32_AM = F_F32 | F_AM,
F32_FM = F_F32 | F_FM,
F32_I = F_F32 | F_I,
F32_Q = F_F32 | F_Q,
U8_LOGIC = F_LOGIC | F_U8,
VCD_LOGIC = F_VCD,
PULSE_OOK = F_OOK,
};
typedef struct {
uint32_t format;
uint32_t raw_format;
uint32_t center_frequency;
uint32_t sample_rate;
char const *spec;
char const *path;
FILE *file;
} file_info_t;
/// Clear all file info.
///
/// @param[in,out] info the file info to clear
void file_info_clear(file_info_t *info);
/// Parse file info from a filename, optionally prefixed with overrides.
///
/// Detects tags in the file name delimited by non-alphanum
/// and prefixes delimited with a colon.
///
/// Parse "[0-9]+(\.[0-9]+)?[A-Za-z]"
/// - as frequency (suffix "M" or "[kMG]?Hz")
/// - or sample rate (suffix "k" or "[kMG]?sps")
///
/// Parse "[A-Za-z][0-9A-Za-z]+" as format or content specifier:
/// - 2ch formats: "cu8", "cs8", "cs16", "cs32", "cf32"
/// - 1ch formats: "u8", "s8", "s16", "u16", "s32", "u32", "f32"
/// - text formats: "vcd", "ook"
/// - content types: "iq", "i", "q", "am", "fm", "logic"
///
/// Parses left to right, with the exception of a prefix up to the last colon ":"
/// This prefix is the forced override, parsed last and removed from the filename.
///
/// All matches are case-insensitive.
///
/// - default detection, e.g.: path/filename.am.s16
/// - overrides, e.g.: am:s16:path/filename.ext
/// - other styles are detected but discouraged, e.g.:
/// am-s16:path/filename.ext, am.s16:path/filename.ext, path/filename.am_s16
///
/// @param[in,out] info the file info to parse into
/// @param filename a file name with optional override prefix to parse
/// @return the detected file format, 0 otherwise
int file_info_parse_filename(file_info_t *info, const char *filename);
/// Check if the format in this file info is supported for reading,
/// print a warning and exit otherwise.
///
/// @param info the file info to check
void file_info_check_read(file_info_t *info);
/// Check if the format in this file info is supported for reading,
/// print a warning and exit otherwise.
///
/// @param info the file info to check
void file_info_check_write(file_info_t *info);
/// Return a string describing the format in this file info.
///
/// @param info the file info to check
/// @return a string describing the format
char const *file_info_string(file_info_t *info);
#endif /* INCLUDE_FILEFORMAT_H_ */