public CellBasedMDT Decode(BitArrayInputStream input) { CellBasedMDT dmdt = new CellBasedMDT(); dmdt.InitDefaults(); BitMaskStream stream = (input.ReadBit() != 0) ? new BitMaskStream(input, 1) : new BitMaskStream(input, 1); dmdt.cellIdListforMDT = new List<ECGI>(); int nBits = 5; int num5 = input.ReadBits(nBits) + 1; for (int i = 0; i < num5; i++) { ECGI item = ECGI.PerDecoder.Instance.Decode(input); dmdt.cellIdListforMDT.Add(item); } if (stream.Read()) { input.skipUnreadedBits(); dmdt.iE_Extensions = new List<ProtocolExtensionField>(); nBits = 0x10; int num7 = input.ReadBits(nBits) + 1; for (int j = 0; j < num7; j++) { ProtocolExtensionField field = ProtocolExtensionField.PerDecoder.Instance.Decode(input); dmdt.iE_Extensions.Add(field); } } return dmdt; }
public CellBasedMDT Decode(BitArrayInputStream input) { CellBasedMDT dmdt = new CellBasedMDT(); dmdt.InitDefaults(); BitMaskStream stream = (input.readBit() != 0) ? new BitMaskStream(input, 1) : new BitMaskStream(input, 1); dmdt.cellIdListforMDT = new List <ECGI>(); int nBits = 5; int num5 = input.readBits(nBits) + 1; for (int i = 0; i < num5; i++) { ECGI item = ECGI.PerDecoder.Instance.Decode(input); dmdt.cellIdListforMDT.Add(item); } if (stream.Read()) { input.skipUnreadedBits(); dmdt.iE_Extensions = new List <ProtocolExtensionField>(); nBits = 0x10; int num7 = input.readBits(nBits) + 1; for (int j = 0; j < num7; j++) { ProtocolExtensionField field = ProtocolExtensionField.PerDecoder.Instance.Decode(input); dmdt.iE_Extensions.Add(field); } } return(dmdt); }