директория в которой лежат файлики. имя файликов состоит из домена например 0x80, 0x40, 0x20
и ключа 0x33, 0x66, 0x51 - то есть выглядит следующим образом
40.51
80.33
20.66
...
я эту директорию чищу, но не полностью. некоторые ценные файлики оставляю.
задача сделать список исключений.
чтобы не повторять домены пришла в голову идея сделать следующую структурку
typedef struct DomainKeyPair {
unsigned char domain;
unsigned char keys[];
} DomainKeyPair;
и хранить это в таком виде
static const DomainKeyPair arr_excludes[ ] = {
{80, {33, 66}},
{90, {31, 66, 72}},
}
теперь проблема - массив с ключами для разных доменов может быть разной длины. может быть 1 ключ, может быть 8.
была идея создать массив в глобальной области, но ограничить область видимость статиком. чтобы обращаться к нему можно было отовсюду. а перед мейном я выделить память динамически не могу.
можно сделать массив фиксированной длины, например на 10 ключей. но это как то не очень на мой взгляд.
еще была идея сделать массив unsigned char и потом кастануть его к моей структуре. но там тоже вопросики.
как посоветуете реализовать это грамотно?
Или хранить в структуре количество keys, или в последний элемент keys писать признак конца, например, 0
сначала сдеалал структуру состоящую из домена и указателя, выделял память динамически и сделал чтобы каждый элемент заканчивался нулем. трудность была в том что массивчики с ключами разной длины, и сделать элемент статическим, без выделения динамической памяти, не получалось. по итогу реализовал вот так: // Exception array for for domain 0x40 static const int8_t excl_provisioning_keys[] = { 0x21, 0x20 }; // Structure defining a domain and its key set. static const struct DomainKeySet { const int8_t domain; const int8_t *const keys; const size_t len; } domain_key_set[] = { { .domain = 0x40, .keys = excl_provisioning_keys, .len = sizeof(excl_provisioning_keys) / sizeof(*excl_provisioning_keys) } };
Обсуждают сегодня