Commit b274b3c
committed
fix for constant length sequences
This fixes error which occurs when parsing Eurex messages with mFAST.
Eurex schema uses constant length sequences in several places, e.g. in
QuoteRequest message:
```
<sequence name="SequenceGroup">
<length name="NoElements" id="111">
<constant value="1"/>
</length>
<int64 name="Id" id="112">
<copy/>
</int64>
</sequence>
```
Unfortunately mFAST fails to properly handle that schema.
The problem boils down to code decoding sequence instruction:
```
template <typename T>
inline void fast_decoder_base::decode_field(const T &ext_ref,
sequence_type_tag) {
value_storage storage;
auto length = ext_ref.set_length(storage);
this->visit(length);
```
Here value_storage is not initialized with initial (constant) value.
Later, in
```
template <typename T, typename TypeCategory>
void fast_decoder_base::decode_field(const T &ext_ref,
constant_operator_tag,
TypeCategory) {
```
the value for constant field is not copied (and that's what was changed
in original patch) and sequence length is considered to be 0 leaving all
of sequence payload bytes unparsed.1 parent b01b6ee commit b274b3c
File tree
4 files changed
+50
-1
lines changed- src/mfast
- tests
4 files changed
+50
-1
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
310 | 310 | | |
311 | 311 | | |
312 | 312 | | |
| 313 | + | |
313 | 314 | | |
314 | | - | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
315 | 319 | | |
316 | 320 | | |
317 | 321 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
18 | 18 | | |
19 | 19 | | |
20 | 20 | | |
| 21 | + | |
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
| |||
51 | 52 | | |
52 | 53 | | |
53 | 54 | | |
| 55 | + | |
54 | 56 | | |
55 | 57 | | |
56 | 58 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
34 | 34 | | |
35 | 35 | | |
36 | 36 | | |
| 37 | + | |
37 | 38 | | |
38 | 39 | | |
39 | 40 | | |
| |||
294 | 295 | | |
295 | 296 | | |
296 | 297 | | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
0 commit comments