All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.zeebe.logstreams.snapshot.BaseValueSnapshotSupport Maven / Gradle / Ivy

There is a newer version: 0.16.4
Show newest version
/*
 * Copyright © 2017 camunda services GmbH ([email protected])
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.zeebe.logstreams.snapshot;

import java.io.InputStream;
import java.io.OutputStream;

import io.zeebe.logstreams.spi.ComposableSnapshotSupport;
import io.zeebe.msgpack.spec.MsgPackReader;
import io.zeebe.msgpack.spec.MsgPackWriter;
import io.zeebe.msgpack.value.BaseValue;
import io.zeebe.util.StreamUtil;
import org.agrona.ExpandableArrayBuffer;

public class BaseValueSnapshotSupport implements ComposableSnapshotSupport
{

    protected final BaseValue value;
    protected final MsgPackWriter writer = new MsgPackWriter();
    protected final MsgPackReader reader = new MsgPackReader();

    /*
     * This implementation via an intermediate buffer is not the most efficient, because
     * it requires an extra intermediate copy of the serialized value; directly writing/reading to/from the
     * streams would be more efficient, but extending MsgPackReader/Writer is no quick win
     * (=> reading primitives instead of single bytes; byte order; skipping values efficiently).
     *
     * This implementation should be ok for rather small objects.
     */
    protected final ExpandableArrayBuffer ioBuffer = new ExpandableArrayBuffer();

    public BaseValueSnapshotSupport(BaseValue value)
    {
        this.value = value;
    }

    @Override
    public long writeSnapshot(OutputStream outputStream) throws Exception
    {
        writer.wrap(ioBuffer, 0);
        final int length = value.getEncodedLength();
        value.write(writer);
        outputStream.write(ioBuffer.byteArray(), 0, length);
        return length;
    }

    @Override
    public void recoverFromSnapshot(InputStream inputStream) throws Exception
    {
        final int length = StreamUtil.read(inputStream, ioBuffer, 0);
        reader.wrap(ioBuffer, 0, length);
        value.read(reader);
    }

    @Override
    public void reset()
    {
        value.reset();
    }

    @Override
    public long snapshotSize()
    {
        return value.getEncodedLength();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy