hazelcast-client
Version:
Hazelcast - open source In-Memory Data Grid - client for NodeJS
48 lines • 2.22 kB
JavaScript
var ClientMessage = require('../ClientMessage');
var BitsUtil_1 = require('../BitsUtil');
var MapMessageType_1 = require('./MapMessageType');
var REQUEST_TYPE = MapMessageType_1.MapMessageType.MAP_EXECUTEWITHPREDICATE;
var RESPONSE_TYPE = 117;
var RETRYABLE = false;
var MapExecuteWithPredicateCodec = (function () {
function MapExecuteWithPredicateCodec() {
}
MapExecuteWithPredicateCodec.calculateSize = function (name, entryProcessor, predicate) {
var dataSize = 0;
dataSize += BitsUtil_1.BitsUtil.calculateSizeString(name);
dataSize += BitsUtil_1.BitsUtil.calculateSizeData(entryProcessor);
dataSize += BitsUtil_1.BitsUtil.calculateSizeData(predicate);
return dataSize;
};
MapExecuteWithPredicateCodec.encodeRequest = function (name, entryProcessor, predicate) {
var clientMessage = ClientMessage.newClientMessage(this.calculateSize(name, entryProcessor, predicate));
clientMessage.setMessageType(REQUEST_TYPE);
clientMessage.setRetryable(RETRYABLE);
clientMessage.appendString(name);
clientMessage.appendData(entryProcessor);
clientMessage.appendData(predicate);
clientMessage.updateFrameLength();
return clientMessage;
};
MapExecuteWithPredicateCodec.decodeResponse = function (clientMessage, toObjectFunction) {
if (toObjectFunction === void 0) { toObjectFunction = null; }
var parameters = { 'response': null };
var responseSize = clientMessage.readInt32();
var response = [];
for (var responseIndex = 0; responseIndex < responseSize; responseIndex++) {
var responseItem;
var responseItemKey;
var responseItemVal;
responseItemKey = clientMessage.readData();
responseItemVal = clientMessage.readData();
responseItem = [responseItemKey, responseItemVal];
response.push(responseItem);
}
parameters['response'] = response;
return parameters;
};
return MapExecuteWithPredicateCodec;
}());
exports.MapExecuteWithPredicateCodec = MapExecuteWithPredicateCodec;
//# sourceMappingURL=MapExecuteWithPredicateCodec.js.map
;