blob: 5394cfc71734d290c92cdc88c741032200a580a6 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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
*
* https://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.apache.plc4x.java.eip.readwrite;
import static org.apache.plc4x.java.spi.codegen.fields.FieldReaderFactory.*;
import static org.apache.plc4x.java.spi.codegen.fields.FieldWriterFactory.*;
import static org.apache.plc4x.java.spi.codegen.io.DataReaderFactory.*;
import static org.apache.plc4x.java.spi.codegen.io.DataWriterFactory.*;
import static org.apache.plc4x.java.spi.generation.StaticHelper.*;
import java.time.*;
import java.util.*;
import org.apache.plc4x.java.api.exceptions.*;
import org.apache.plc4x.java.api.value.*;
import org.apache.plc4x.java.spi.codegen.*;
import org.apache.plc4x.java.spi.codegen.fields.*;
import org.apache.plc4x.java.spi.codegen.io.*;
import org.apache.plc4x.java.spi.generation.*;
// Code generated by code-generation. DO NOT EDIT.
public class DataSegment extends PathSegment implements Message {
// Accessors for discriminator values.
public Byte getPathSegment() {
return (byte) 0x04;
}
// Properties.
protected final DataSegmentType segmentType;
// Arguments.
protected final IntegerEncoding order;
public DataSegment(DataSegmentType segmentType, IntegerEncoding order) {
super(order);
this.segmentType = segmentType;
this.order = order;
}
public DataSegmentType getSegmentType() {
return segmentType;
}
@Override
protected void serializePathSegmentChild(WriteBuffer writeBuffer) throws SerializationException {
PositionAware positionAware = writeBuffer;
boolean _lastItem = ThreadLocalHelper.lastItemThreadLocal.get();
int startPos = positionAware.getPos();
writeBuffer.pushContext("DataSegment");
// Simple Field (segmentType)
writeSimpleField(
"segmentType",
segmentType,
new DataWriterComplexDefault<>(writeBuffer),
WithOption.WithByteOrder(
(((order) == (IntegerEncoding.BIG_ENDIAN))
? ByteOrder.BIG_ENDIAN
: ByteOrder.LITTLE_ENDIAN)));
writeBuffer.popContext("DataSegment");
}
@Override
public int getLengthInBytes() {
return (int) Math.ceil((float) getLengthInBits() / 8.0);
}
@Override
public int getLengthInBits() {
int lengthInBits = super.getLengthInBits();
DataSegment _value = this;
boolean _lastItem = ThreadLocalHelper.lastItemThreadLocal.get();
// Simple field (segmentType)
lengthInBits += segmentType.getLengthInBits();
return lengthInBits;
}
public static PathSegmentBuilder staticParsePathSegmentBuilder(
ReadBuffer readBuffer, IntegerEncoding order) throws ParseException {
readBuffer.pullContext("DataSegment");
PositionAware positionAware = readBuffer;
int startPos = positionAware.getPos();
int curPos;
boolean _lastItem = ThreadLocalHelper.lastItemThreadLocal.get();
DataSegmentType segmentType =
readSimpleField(
"segmentType",
new DataReaderComplexDefault<>(
() -> DataSegmentType.staticParse(readBuffer, (IntegerEncoding) (order)),
readBuffer),
WithOption.WithByteOrder(
(((order) == (IntegerEncoding.BIG_ENDIAN))
? ByteOrder.BIG_ENDIAN
: ByteOrder.LITTLE_ENDIAN)));
readBuffer.closeContext("DataSegment");
// Create the instance
return new DataSegmentBuilderImpl(segmentType, order);
}
public static class DataSegmentBuilderImpl implements PathSegment.PathSegmentBuilder {
private final DataSegmentType segmentType;
private final IntegerEncoding order;
public DataSegmentBuilderImpl(DataSegmentType segmentType, IntegerEncoding order) {
this.segmentType = segmentType;
this.order = order;
}
public DataSegment build(IntegerEncoding order) {
DataSegment dataSegment = new DataSegment(segmentType, order);
return dataSegment;
}
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof DataSegment)) {
return false;
}
DataSegment that = (DataSegment) o;
return (getSegmentType() == that.getSegmentType()) && super.equals(that) && true;
}
@Override
public int hashCode() {
return Objects.hash(super.hashCode(), getSegmentType());
}
@Override
public String toString() {
WriteBufferBoxBased writeBufferBoxBased = new WriteBufferBoxBased(true, true);
try {
writeBufferBoxBased.writeSerializable(this);
} catch (SerializationException e) {
throw new RuntimeException(e);
}
return "\n" + writeBufferBoxBased.getBox().toString() + "\n";
}
}