public Octets Update(Octets oin)
        {
            _legacyIn.Append(oin);
            _blenTotol = (uint)(_legacyIn.Count * 8 - _l);
            _legacyIn.Reserve(_legacyIn.Count + 3);

            _rptr = 0;
            _blen = 7;
            Octets oout = oin;

            oout.Clear();
            uint histhead = _histptr;

            while (_blenTotol > _blen)
            {
                _adjustL    = _l;
                _adjustRptr = _rptr;
                uint val = Fetch();

                if (val < 0x80000000)
                {
                    if (!Passbits(8))
                    {
                        break;
                    }
                    _history[_histptr++] = (byte)(val >> 24);
                    continue;
                }
                if (val < 0xc0000000)
                {
                    if (!Passbits(9))
                    {
                        break;
                    }
                    _history[_histptr++] = (byte)(((val >> 23) | 0x80) & 0xff);
                    continue;
                }

                uint len;
                uint off = 0;
                if (val >= 0xf0000000)
                {
                    if (!Passbits(10))
                    {
                        break;
                    }
                    off = (val >> 22) & 0x3f;
                    if (off == (uint)Mppc.CtrlOffEob)
                    {
                        uint advance = 8 - (_l & 7);
                        if (advance < 8)
                        {
                            if (!Passbits(advance))
                            {
                                break;
                            }
                        }
                        oout.Append(_history, (int)histhead, (int)(_histptr - histhead));
                        if (_histptr == (uint)Mppc.MppcHistLen)
                        {
                            _histptr = 0;
                        }
                        histhead = _histptr;
                        continue;
                    }
                }
                else if (val >= 0xe0000000)
                {
                    if (!Passbits(12))
                    {
                        break;
                    }
                    off = ((val >> 20) & 0xff) + 64;
                }
                else if (val >= 0xc0000000)
                {
                    if (!Passbits(16))
                    {
                        break;
                    }
                    off = ((val >> 16) & 0x1fff) + 320;
                }


                val = Fetch();
                if (val < 0x80000000)
                {
                    if (!Passbits(1))
                    {
                        break;
                    }
                    len = 3;
                }
                else if (val < 0xc0000000)
                {
                    if (!Passbits(4))
                    {
                        break;
                    }
                    len = 4 | ((val >> 28) & 3);
                }
                else if (val < 0xe0000000)
                {
                    if (!Passbits(6))
                    {
                        break;
                    }
                    len = 8 | ((val >> 26) & 7);
                }
                else if (val < 0xf0000000)
                {
                    if (!Passbits(8))
                    {
                        break;
                    }
                    len = 16 | ((val >> 24) & 15);
                }
                else if (val < 0xf8000000)
                {
                    if (!Passbits(10))
                    {
                        break;
                    }
                    len = 32 | ((val >> 22) & 0x1f);
                }
                else if (val < 0xfc000000)
                {
                    if (!Passbits(12))
                    {
                        break;
                    }
                    len = 64 | ((val >> 20) & 0x3f);
                }
                else if (val < 0xfe000000)
                {
                    if (!Passbits(14))
                    {
                        break;
                    }
                    len = 128 | ((val >> 18) & 0x7f);
                }
                else if (val < 0xff000000)
                {
                    if (!Passbits(16))
                    {
                        break;
                    }
                    len = 256 | ((val >> 16) & 0xff);
                }
                else if (val < 0xff800000)
                {
                    if (!Passbits(18))
                    {
                        break;
                    }
                    len = 0x200 | ((val >> 14) & 0x1ff);
                }
                else if (val < 0xffc00000)
                {
                    if (!Passbits(20))
                    {
                        break;
                    }
                    len = 0x400 | ((val >> 12) & 0x3ff);
                }
                else if (val < 0xffe00000)
                {
                    if (!Passbits(22))
                    {
                        break;
                    }
                    len = 0x800 | ((val >> 10) & 0x7ff);
                }
                else if (val < 0xfff00000)
                {
                    if (!Passbits(24))
                    {
                        break;
                    }
                    len = 0x1000 | ((val >> 8) & 0xfff);
                }
                else
                {
                    _l    = _adjustL;
                    _rptr = _adjustRptr;
                    break;
                }

                if (_histptr < off || _histptr + len > (uint)Mppc.MppcHistLen)
                {
                    break;
                }
                // Array.Copy(history, histptr - off, history, histptr, histptr - histhead);
                LameCopy(_history, (int)_histptr, (int)(_histptr - off), (int)len);
                // Array.Copy(history, histptr - off, history, histptr, len);
                _histptr += len;
            }

            oout.Append(_history, (int)histhead, (int)(_histptr - histhead));
            _legacyIn.Erase(0, (int)_rptr);
            return(oout);
        }
Beispiel #2
0
 private OctetsStream(Octets o)
 {
     Data = o;
 }
Beispiel #3
0
 public static OctetsStream Wrap(Octets o)
 {
     return(new OctetsStream(o));
 }
Beispiel #4
0
 public OctetsStream(int size)
 {
     Data = new Octets(size);
 }
Beispiel #5
0
 public OctetsStream()
 {
     Data = new Octets();
 }
Beispiel #6
0
 public OctetsStream Marshal(Octets o)
 {
     MarshalSize(o.Count);
     Data.Append(o);
     return(this);
 }