org.reaktivity.command.log.internal.layouts.StreamsLayout Maven / Gradle / Ivy
/**
* Copyright 2016-2021 The Reaktivity Project
*
* The Reaktivity Project licenses this file to you 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 org.reaktivity.command.log.internal.layouts;
import static org.agrona.IoUtil.mapExistingFile;
import static org.agrona.IoUtil.unmap;
import java.io.File;
import java.nio.MappedByteBuffer;
import java.nio.file.Path;
import org.agrona.concurrent.AtomicBuffer;
import org.agrona.concurrent.UnsafeBuffer;
import org.reaktivity.command.log.internal.spy.OneToOneRingBufferSpy;
import org.reaktivity.command.log.internal.spy.RingBufferSpy;
import org.reaktivity.command.log.internal.spy.RingBufferSpy.SpyPosition;
public final class StreamsLayout extends Layout
{
private final RingBufferSpy streamsBuffer;
private StreamsLayout(
RingBufferSpy streamsBuffer)
{
this.streamsBuffer = streamsBuffer;
}
public RingBufferSpy streamsBuffer()
{
return streamsBuffer;
}
@Override
public void close()
{
unmap(streamsBuffer.buffer().byteBuffer());
}
public static final class Builder extends Layout.Builder
{
private Path path;
private boolean readonly;
private SpyPosition position;
public Builder path(
Path path)
{
this.path = path;
return this;
}
public Builder spyAt(
SpyPosition position)
{
this.position = position;
return this;
}
public Builder readonly(
boolean readonly)
{
this.readonly = readonly;
return this;
}
@Override
public StreamsLayout build()
{
final File layoutFile = path.toFile();
assert readonly;
final MappedByteBuffer mappedStreams = mapExistingFile(layoutFile, "streams");
final AtomicBuffer atomicStreams = new UnsafeBuffer(mappedStreams);
final OneToOneRingBufferSpy spy = new OneToOneRingBufferSpy(atomicStreams);
if (position != null)
{
spy.spyAt(position);
}
return new StreamsLayout(spy);
}
}
}