io.nem.catapult.builders.ReceiptSourceBuilder Maven / Gradle / Ivy
/**
*** Copyright (c) 2016-present,
*** Jaguar0625, gimre, BloodyRookie, Tech Bureau, Corp. All rights reserved.
***
*** This file is part of Catapult.
***
*** Catapult is free software: you can redistribute it and/or modify
*** it under the terms of the GNU Lesser General Public License as published by
*** the Free Software Foundation, either version 3 of the License, or
*** (at your option) any later version.
***
*** Catapult is distributed in the hope that it will be useful,
*** but WITHOUT ANY WARRANTY; without even the implied warranty of
*** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
*** GNU Lesser General Public License for more details.
***
*** You should have received a copy of the GNU Lesser General Public License
*** along with Catapult. If not, see .
**/
package io.nem.symbol.catapult.builders;
import java.io.DataInputStream;
/** Binary layout for receipt source. */
public class ReceiptSourceBuilder implements Serializer {
/** Transaction primary source (e.g. index within block). */
private final int primaryId;
/** Transaction secondary source (e.g. index within aggregate). */
private final int secondaryId;
/**
* Constructor - Creates an object from stream.
*
* @param stream Byte stream to use to serialize the object.
*/
protected ReceiptSourceBuilder(final DataInputStream stream) {
try {
this.primaryId = Integer.reverseBytes(stream.readInt());
this.secondaryId = Integer.reverseBytes(stream.readInt());
} catch(Exception e) {
throw GeneratorUtils.getExceptionToPropagate(e);
}
}
/**
* Constructor.
*
* @param primaryId Transaction primary source (e.g. index within block).
* @param secondaryId Transaction secondary source (e.g. index within aggregate).
*/
protected ReceiptSourceBuilder(final int primaryId, final int secondaryId) {
this.primaryId = primaryId;
this.secondaryId = secondaryId;
}
/**
* Creates an instance of ReceiptSourceBuilder.
*
* @param primaryId Transaction primary source (e.g. index within block).
* @param secondaryId Transaction secondary source (e.g. index within aggregate).
* @return Instance of ReceiptSourceBuilder.
*/
public static ReceiptSourceBuilder create(final int primaryId, final int secondaryId) {
return new ReceiptSourceBuilder(primaryId, secondaryId);
}
/**
* Gets transaction primary source (e.g. index within block).
*
* @return Transaction primary source (e.g. index within block).
*/
public int getPrimaryId() {
return this.primaryId;
}
/**
* Gets transaction secondary source (e.g. index within aggregate).
*
* @return Transaction secondary source (e.g. index within aggregate).
*/
public int getSecondaryId() {
return this.secondaryId;
}
/**
* Gets the size of the object.
*
* @return Size in bytes.
*/
public int getSize() {
int size = 0;
size += 4; // primaryId
size += 4; // secondaryId
return size;
}
/**
* Creates an instance of ReceiptSourceBuilder from a stream.
*
* @param stream Byte stream to use to serialize the object.
* @return Instance of ReceiptSourceBuilder.
*/
public static ReceiptSourceBuilder loadFromBinary(final DataInputStream stream) {
return new ReceiptSourceBuilder(stream);
}
/**
* Serializes an object to bytes.
*
* @return Serialized bytes.
*/
public byte[] serialize() {
return GeneratorUtils.serialize(dataOutputStream -> {
dataOutputStream.writeInt(Integer.reverseBytes(this.getPrimaryId()));
dataOutputStream.writeInt(Integer.reverseBytes(this.getSecondaryId()));
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy