I've done some further investigation and as far as I can tell the problem appears to be with the value returned by cDiseqc::Codes in diseqc.c.
The return value changed from 'uchar' to 'const uchar' between 1.7.18 and 1.7.19 and the returned value now always points to the last diseqc code in the string.
The following trace from 1.7.19 shows the problem:
Diseqc command list found = t V [E0 10 38 F4] W500 [E0 31 6B 01] W250 [E1 31 6B 01] W15 T
Entered cDiseqc::Codes pointing at : E0 10 38 F4]
In cDiseqc::Codes - returning a pointer 137345561 to : W500 [E0 31
Received from diseqc->Codes(n) a pointer 137345509 to : E1 31 6B 01
Sending Diseqc command: E1 31 6B 01
Entered cDiseqc::Codes pointing at : E0 31 6B 01]
In cDiseqc::Codes - returning a pointer 137345580 to : W250 [E1 31
Received from diseqc->Codes(n) a pointer 137345509 to : E1 31 6B 01
Sending Diseqc command: E1 31 6B 01
Entered cDiseqc::Codes pointing at : E1 31 6B 01]
In cDiseqc::Codes - returning a pointer 137345599 to : W15 T
Received from diseqc->Codes(n) a pointer 137345509 to : E1 31 6B 01
Sending Diseqc command: E1 31 6B 01
The identical trace from 1.7.18 which works correctly looks like this:
Diseqc command list found = t V [E0 10 38 F4] W500 [E0 31 6B 01] W250 [E1 31 6B 01] W15 T
Entered cDiseqc::Codes pointing at : E0 10 38 F4]
In cDiseqc::Codes - returning a pointer 137333177 to : W500 [E0 31
Received from diseqc->Codes(n) a pointer 137333125 to : E0 10 38 F4
Sending Diseqc command: E0 10 38 F4
Entered cDiseqc::Codes pointing at : E0 31 6B 01]
In cDiseqc::Codes - returning a pointer 137333196 to : W250 [E1 31
Received from diseqc->Codes(n) a pointer 137333125 to : E0 31 6B 01
Sending Diseqc command: E0 31 6B 01
Entered cDiseqc::Codes pointing at : E1 31 6B 01]
In cDiseqc::Codes - returning a pointer 137333215 to : W15 T
Received from diseqc->Codes(n) a pointer 137333125 to : E1 31 6B 01
Sending Diseqc command: E1 31 6B 01
I have tried to revert cDiseqc::Codes in 1.7.19 to the 1.7.18 version but the extent of the changes introduced to 1.7.19 in this area eventually defeated my limited C++ skills. In doing so I have learnt and read a lot and it appears that there are some pitfalls in returning 'const' values. I suspect that this is the problem here but can't be sure.
If someone could have a look at this and suggest how to fix it, it would be much appreciated.
Thanks,
Mark.