generate all length prefix array variants via macro
This commit is contained in:
parent
4c7302c4a3
commit
e29a5a3475
7 changed files with 175 additions and 241 deletions
morphisms
|
@ -12,19 +12,19 @@ morph_seqseq_valsep_uint8 (T: Type, SrcDelim: T, DstDelim: T)
|
|||
~ < ValueSep DstDelim T >
|
||||
~ < Seq~<LengthPrefix x86.UInt64> T >
|
||||
```
|
||||
length_prefix_uint8_array_clear( dst );
|
||||
length_prefix_uint64_t_array_uint8_t_clear( dst );
|
||||
|
||||
uint8_t * dst_items = dst->items;
|
||||
for( uint64_t i = 0; i < src->len; ++i ) {
|
||||
if( src->items[i] == SrcDelim ) {
|
||||
length_prefix_uint8_array_push( dst, DstDelim );
|
||||
length_prefix_uint64_t_array_uint8_t_push( dst, DstDelim );
|
||||
} else if( src->items[i] == DstDelim ) {
|
||||
if( DstDelim == '\n' ) {
|
||||
length_prefix_uint8_array_push( dst, '\\' );
|
||||
length_prefix_uint8_array_push( dst, 'n' );
|
||||
length_prefix_uint64_t_array_uint8_t_push( dst, '\\' );
|
||||
length_prefix_uint64_t_array_uint8_t_push( dst, 'n' );
|
||||
}
|
||||
} else {
|
||||
length_prefix_uint8_array_push( dst, src->items[i] );
|
||||
length_prefix_uint64_t_array_uint8_t_push( dst, src->items[i] );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -44,9 +44,9 @@ morph_seqseq_as_valsep_to_lenpfx (T: Type, Delim: T, EscKey: T)
|
|||
~ x86.UInt64
|
||||
>
|
||||
```
|
||||
length_prefix_uint64_array_clear( dst );
|
||||
length_prefix_uint64_t_array_uint64_t_clear( dst );
|
||||
|
||||
struct LengthPrefixUInt8Array * cur_item = NULL;
|
||||
struct LengthPrefix_uint64_t_Array_uint8_t * cur_item = NULL;
|
||||
|
||||
uint8_t const * start = &src->items[0];
|
||||
uint8_t const * cur = start;
|
||||
|
@ -60,7 +60,7 @@ morph_seqseq_as_valsep_to_lenpfx (T: Type, Delim: T, EscKey: T)
|
|||
cur_item->len = len;
|
||||
memcpy( cur_item->items, start, len );
|
||||
|
||||
length_prefix_uint64_array_push( dst, (uint64_t)cur_item );
|
||||
length_prefix_uint64_t_array_uint64_t_push( dst, (uint64_t)cur_item );
|
||||
start = ++cur;
|
||||
} else {
|
||||
cur++;
|
||||
|
@ -81,17 +81,17 @@ morph_seqeq_as_lenpfx_to_valsep (T: Type, Delim: T, EscKey: T)
|
|||
~ < ValueSep T Delim >
|
||||
~ < Seq~<LengthPrefix x86.UInt64> T >
|
||||
```
|
||||
length_prefix_uint8_array_clear( dst );
|
||||
length_prefix_uint64_t_array_uint8_t_clear( dst );
|
||||
|
||||
for( uint64_t i = 0; i < src->len; ++i ) {
|
||||
LengthPrefixUInt8Array * item = src->items[i];
|
||||
LengthPrefix_uint64_t_Array_uint8_t * item = src->items[i];
|
||||
|
||||
for( uint64_t j = 0; j < item->len; ++j ) {
|
||||
length_prefix_uint8_array_push( items->items[j] );
|
||||
length_prefix_uint64_t_array_uint8_t_push( items->items[j] );
|
||||
}
|
||||
|
||||
if( i+1 < src->len ) {
|
||||
length_prefix_uint8_array_push( Delim );
|
||||
length_prefix_uint64_t_array_uint8_t_push( Delim );
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue