clearification of keysize descriptor stuff
This commit is contained in:
parent
1d6dd40713
commit
4702ee6467
|
@ -28,50 +28,49 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include "keysize_descriptor.h"
|
#include "keysize_descriptor.h"
|
||||||
|
|
||||||
|
#define KS8 ((uint8_t*)ks_desc)
|
||||||
uint8_t is_valid_keysize_P(const void* ks_desc, uint16_t keysize){
|
uint8_t is_valid_keysize_P(const void* ks_desc, uint16_t keysize){
|
||||||
uint8_t type;
|
uint8_t type;
|
||||||
type = *((uint8_t*)ks_desc);
|
type = KS8[0];
|
||||||
ks_desc = (uint8_t*)ks_desc + 1;
|
ks_desc = KS8 + 1;
|
||||||
if(type==KS_TYPE_TERMINATOR)
|
if(type==KS_TYPE_TERMINATOR)
|
||||||
return 0;
|
return 0;
|
||||||
if(type==KS_TYPE_LIST){
|
if(type==KS_TYPE_LIST){
|
||||||
uint8_t items;
|
uint8_t items;
|
||||||
uint16_t item;
|
uint16_t item;
|
||||||
items = *((uint8_t*)ks_desc);
|
items = KS8[0];
|
||||||
ks_desc = (uint8_t*)ks_desc + 1;
|
ks_desc = KS8 + 1;
|
||||||
while(items--){
|
while(items--){
|
||||||
item = *((uint16_t*)ks_desc);
|
item = KS8[1] * 256 + KS8[0];
|
||||||
ks_desc = (uint8_t*)ks_desc + 2;
|
ks_desc = KS8 + 2;
|
||||||
if(item==keysize)
|
if(item==keysize)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
ks_desc = (uint8_t*)ks_desc - 2;
|
ks_desc = KS8 - 2;
|
||||||
}
|
}
|
||||||
if(type==KS_TYPE_RANGE){
|
if(type==KS_TYPE_RANGE){
|
||||||
uint16_t max, min;
|
uint16_t max, min;
|
||||||
min = *((uint16_t*)ks_desc);
|
min = KS8[1] * 256 + KS8[0];
|
||||||
ks_desc = (uint8_t*)ks_desc + 2;
|
ks_desc = (uint8_t*)ks_desc + 2;
|
||||||
max = *((uint16_t*)ks_desc);
|
max = KS8[1] * 256 + KS8[0];
|
||||||
if(min<=keysize && keysize<=max)
|
if(min <= keysize && keysize <= max)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if(type==KS_TYPE_ARG_RANGE){
|
if(type==KS_TYPE_ARG_RANGE){
|
||||||
uint16_t max, min, dist, offset;
|
uint16_t max, min, dist, offset;
|
||||||
min = *((uint16_t*)ks_desc);
|
min = KS8[1] * 256 + KS8[0];
|
||||||
ks_desc = (uint8_t*)ks_desc + 2;
|
max = KS8[3] * 256 + KS8[2];
|
||||||
max = *((uint16_t*)ks_desc);
|
dist = KS8[5] * 256 + KS8[4];
|
||||||
ks_desc = (uint8_t*)ks_desc + 2;
|
offset = KS8[7] * 256 + KS8[6];
|
||||||
dist = *((uint16_t*)ks_desc);
|
ks_desc = KS8 + 6;
|
||||||
ks_desc = (uint8_t*)ks_desc + 2;
|
if(min <= keysize && keysize <= max && (keysize % dist == offset))
|
||||||
offset = *((uint16_t*)ks_desc);
|
|
||||||
if(min<=keysize && keysize<=max && (keysize%dist==offset))
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if(type>KS_TYPE_ARG_RANGE){
|
if(type>KS_TYPE_ARG_RANGE){
|
||||||
/* bad error, you may insert a big warning message here */
|
/* bad error, you may insert a big warning message here */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return is_valid_keysize_P((uint8_t*)ks_desc+1, keysize); /* search the next record */
|
return is_valid_keysize_P(KS8+1, keysize); /* search the next record */
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t get_keysize(const void* ks_desc){
|
uint16_t get_keysize(const void* ks_desc){
|
||||||
|
|
Loading…
Reference in New Issue