edits
[iotcloud.git] / version2 / src / C / CommitPart.cc
index 1394f321e6877491ab2230ac8c6b53738dc70f9a..c0d50fab9ba58298eb23911fd4cf216268fba2a8 100644 (file)
+#include "CommitPart.h"
+
+
+CommitPart::CommitPart(Slot* s, int64_t _machineId, int64_t _sequenceNumber, int64_t _transactionSequenceNumber, int _partNumber, Array<char>* _data, bool _isLastPart) :
+       Entry(s),
+       machineId(_machineId),
+       sequenceNumber(_sequenceNumber),
+       transactionSequenceNumber(_transactionSequenceNumber),
+       partNumber(_partNumber),
+       isLastPart(_isLastPart),
+       data(_data),
+       partId(new Pair<int64_t int32_t>(sequenceNumber, partNumber)),
+       commitId(new Pair<int64_t, int64_t>(machineId, sequenceNumber)) {
+}
 
-
-
-
-class CommitPart extends Entry {
-
-       // Max size of the part excluding the fixed size header
-       static final int MAX_NON_HEADER_SIZE = 512;
-
-
-       // Sequence number of the transaction this commit is for, -1 if not a cloud transaction
-       int64_t machineId = -1;         // Machine Id of the device that made the commit
-       int64_t sequenceNumber = -1;    // commit sequence number for this arbitrator
-       int64_t transactionSequenceNumber = -1;
-       int partNumber = -1;    // Parts position in the
-       bool isLastPart = false;
-       char[] data = NULL;
-
-       Pair<int64_t int32_t> partId = NULL;
-       Pair<int64_t, int64_t> commitId = NULL;
-
-
-       CommitPart(Slot s, int64_t _machineId, int64_t _sequenceNumber, int64_t _transactionSequenceNumber, int _partNumber, char[] _data, bool _isLastPart) {
-               super(s);
-               machineId = _machineId;
-               sequenceNumber = _sequenceNumber;
-               transactionSequenceNumber = _transactionSequenceNumber;
-               partNumber = _partNumber;
-               isLastPart = _isLastPart;
-               data = _data;
-
-               partId = new Pair<int64_t int32_t>(sequenceNumber, partNumber);
-               commitId = new Pair<int64_t, int64_t>(machineId, sequenceNumber);
-       }
-
-       int getSize() {
-               if (data == NULL) {
-                       return (3 * sizeof(int64_t)) + (2 * sizeof(int32_t)) + (2 * sizeof(char));
-               }
-               return (3 * sizeof(int64_t)) + (2 * sizeof(int32_t)) + (2 * sizeof(char)) + data.length;
-       }
-
-       void setSlot(Slot s) {
-               parentslot = s;
-       }
-
-       int getPartNumber() {
-               return partNumber;
+int CommitPart::getSize() {
+       if (data == NULL) {
+               return (3 * sizeof(int64_t)) + (2 * sizeof(int32_t)) + (2 * sizeof(char));
        }
+       return (3 * sizeof(int64_t)) + (2 * sizeof(int32_t)) + (2 * sizeof(char)) + data->length();
+}
 
-       int getDataSize() {
-               return data.length;
-       }
+void CommitPart::setSlot(Slot s) {
+       parentslot = s;
+}
 
-       char[] getData() {
-               return data;
-       }
+int CommitPart::getPartNumber() {
+       return partNumber;
+}
 
-       Pair<int64_t int32_t> getPartId() {
-               return partId;
-       }
+int CommitPart::getDataSize() {
+       return data->length();
+}
 
-       Pair<int64_t, int64_t> getCommitId() {
-               return commitId;
-       }
+Array<char> * CommitPart::getData() {
+       return data;
+}
 
-       bool isLastPart() {
-               return isLastPart;
-       }
+Pair<int64_t int32_t> * CommitPart::getPartId() {
+       return partId;
+}
 
-       int64_t getMachineId() {
-               return machineId;
-       }
+Pair<int64_t, int64_t> *CommitPart::getCommitId() {
+       return commitId;
+}
 
-       int64_t getTransactionSequenceNumber() {
-               return transactionSequenceNumber;
-       }
+bool CommitPart::isLastPart() {
+       return isLastPart;
+}
 
-       int64_t getSequenceNumber() {
-               return sequenceNumber;
-       }
+int64_t CommitPart::getMachineId() {
+       return machineId;
+}
 
-       static Entry decode(Slot s, ByteBuffer bb) {
-               int64_t machineId = bb->getLong();
-               int64_t sequenceNumber = bb->getLong();
-               int64_t transactionSequenceNumber = bb->getLong();
-               int partNumber = bb->getInt();
-               int dataSize = bb->getInt();
-               bool isLastPart = bb->get() == 1;
+int64_t CommitPart::getTransactionSequenceNumber() {
+       return transactionSequenceNumber;
+}
 
-               // Get the data
-               char[] data = new char[dataSize];
-               bb->get(data);
+int64_t CommitPart::getSequenceNumber() {
+       return sequenceNumber;
+}
 
-               return new CommitPart(s, machineId, sequenceNumber, transactionSequenceNumber, partNumber, data, isLastPart);
-       }
+Entry* CommitPart_decode(Slot* s, ByteBuffer* bb) {
+       int64_t machineId = bb->getLong();
+       int64_t sequenceNumber = bb->getLong();
+       int64_t transactionSequenceNumber = bb->getLong();
+       int partNumber = bb->getInt();
+       int dataSize = bb->getInt();
+       bool isLastPart = bb->get() == 1;
+       
+       // Get the data
+       Array<char> * data = new Array<char>(dataSize);
+       bb->get(data);
+       
+       return new CommitPart(s, machineId, sequenceNumber, transactionSequenceNumber, partNumber, data, isLastPart);
+}
 
-       void encode(ByteBuffer bb) {
-               bb->put(Entry.TypeCommitPart);
-               bb->putLong(machineId);
-               bb->putLong(sequenceNumber);
-               bb->putLong(transactionSequenceNumber);
-               bb->putInt(partNumber);
-               bb->putInt(data.length);
-
-               if (isLastPart) {
-                       bb->put((char)1);
-               } else {
-                       bb->put((char)0);
-               }
-
-               bb->put(data);
-       }
+void CommitPart::encode(ByteBuffer bb) {
+       bb->put(TypeCommitPart);
+       bb->putLong(machineId);
+       bb->putLong(sequenceNumber);
+       bb->putLong(transactionSequenceNumber);
+       bb->putInt(partNumber);
+       bb->putInt(data.length);
+       
+       if (isLastPart) {
+               bb->put((char)1);
+       } else {
+               bb->put((char)0);
+       }
+       
+       bb->put(data);
+}
 
-       char getType() {
-               return Entry.TypeCommitPart;
-       }
+char CommitPart::getType() {
+       return TypeCommitPart;
+}
 
-       Entry getCopy(Slot s) {
-               return new CommitPart(s, machineId, sequenceNumber, transactionSequenceNumber, partNumber, data, isLastPart);
-       }
+Entry *CommitPart::getCopy(Slot *s) {
+       return new CommitPart(s, machineId, sequenceNumber, transactionSequenceNumber, partNumber, data, isLastPart);
 }