metaapi.cloud-sdk
Version:
SDK for MetaApi, a professional cloud forex API which includes MetaTrader REST API and MetaTrader websocket API. Supports both MetaTrader 5 (MT5) and MetaTrader 4 (MT4). CopyFactory copy trading API included. (https://metaapi.cloud)
184 lines (183 loc) • 18.2 kB
JavaScript
/* jscs:disable */ /* eslint-disable */ "use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
function createNewNode_(key) {
return {
key: key,
weight: 1,
height: 0,
left: null,
right: null
};
}
var comparer_ = function(a, b) {
if (a < b) return -1;
if (a > b) return 1;
return 0;
};
function height_(p) {
return p ? p.height : 0;
}
function weight_(p) {
return p ? p.weight : 0;
}
function bFactor_(p) {
return height_(p.right) - height_(p.left);
}
function countHeightAndWeight_(p) {
var hl = height_(p.left);
var hr = height_(p.right);
p.height = (hl > hr ? hl : hr) + 1;
var wl = weight_(p.left);
var wr = weight_(p.right);
p.weight = wl + wr + 1;
}
function rotateRight_(p) {
var q = p.left;
p.left = q.right;
q.right = p;
countHeightAndWeight_(p);
countHeightAndWeight_(q);
return q;
}
function rotateLeft_(q) {
var p = q.right;
q.right = p.left;
p.left = q;
countHeightAndWeight_(q);
countHeightAndWeight_(p);
return p;
}
function balance_(p) {
countHeightAndWeight_(p);
if (bFactor_(p) === 2) {
if (bFactor_(p.right) < 0) p.right = rotateRight_(p.right);
return rotateLeft_(p);
}
if (bFactor_(p) === -2) {
if (bFactor_(p.left) > 0) p.left = rotateLeft_(p.left);
return rotateRight_(p);
}
return p;
}
function count_(p, k) {
return upperBound_(p, k) - lowerBound_(p, k);
}
function at_(p, k) {
if (!p) return null;
var wl = weight_(p.left);
if (wl <= k && k < wl + 1) return p.key;
else if (k < wl) return at_(p.left, k);
else return at_(p.right, k - wl - 1);
}
function getMinimum_(p) {
if (!p) return null;
return p.left ? getMinimum_(p.left) : p;
}
function getMaximum_(p) {
if (!p) return null;
return p.right ? getMaximum_(p.right) : p;
}
function removeMinimun_(p) {
if (!p.left) return p.right;
p.left = removeMinimun_(p.left);
return balance_(p);
}
function toArray_(p) {
var arr = [];
if (p.left) arr = arr.concat(toArray_(p.left));
arr.push(p.key);
if (p.right) arr = arr.concat(toArray_(p.right));
return arr;
}
var AVLTree = function(comparer) {
if (!comparer) comparer = comparer_;
var AVL = {
root: null,
comparer_: comparer,
size: function() {
return weight_(AVL.root);
},
min: function() {
var p = getMinimum_(AVL.root);
if (p) return p.key;
return null;
},
max: function() {
var p = getMaximum_(AVL.root);
if (p) return p.key;
return null;
},
lowerBound: function(k) {
return AVL.lowerBound_(AVL.root, k);
},
lowerBound_ (p, k) {
if (!p) return 0;
var cmp = AVL.comparer_(k, p.key);
if (cmp <= 0) return AVL.lowerBound_(p.left, k);
else if (cmp > 0) return weight_(p.left) + AVL.lowerBound_(p.right, k) + 1;
},
upperBound: function(k) {
return AVL.upperBound_(AVL.root, k);
},
upperBound_ (p, k) {
if (!p) return 0;
var cmp = AVL.comparer_(k, p.key);
if (cmp < 0) return AVL.upperBound_(p.left, k);
else if (cmp >= 0) return weight_(p.left) + AVL.upperBound_(p.right, k) + 1;
},
count: function(k) {
return count_(AVL.root, k);
},
at: function(k) {
return at_(AVL.root, k);
},
insert: function(k) {
AVL.root = AVL.insert_(AVL.root, k);
},
insert_ (p, k) {
if (!p) return createNewNode_(k);
var cmp = AVL.comparer_(k, p.key);
if (cmp < 0) p.left = AVL.insert_(p.left, k);
else if (cmp >= 0) p.right = AVL.insert_(p.right, k);
return balance_(p);
},
remove: function(k) {
AVL.root = AVL.remove_(AVL.root, k);
},
remove_ (p, k) {
if (!p) return null;
var cmp = AVL.comparer_(k, p.key);
if (cmp < 0) p.left = AVL.remove_(p.left, k);
else if (cmp > 0) p.right = AVL.remove_(p.right, k);
else {
var q = p.left;
var r = p.right;
if (!r) return q;
var min = getMinimum_(r);
min.right = removeMinimun_(r);
min.left = q;
return balance_(min);
}
return balance_(p);
},
removeAt: function(k) {
var val = AVL.at(k);
AVL.root = AVL.remove_(AVL.root, val);
},
toArray: function() {
if (AVL.root === null) return [];
return toArray_(AVL.root);
}
};
return AVL;
};
const _default = AVLTree;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["/* jscs:disable */\n/* eslint-disable */\n\n'use strict';\n\nfunction createNewNode_(key) {\n  return {\n    key: key,\n    weight: 1,\n    height: 0,\n    left: null,\n    right: null\n  };\n}\n\nvar comparer_ = function(a, b) {\n  if (a < b) return -1;\n  if (a > b) return 1;\n  return 0;\n}\n\nfunction height_(p) {\n  return p ? p.height : 0;\n}\n\nfunction weight_(p) {\n  return p ? p.weight : 0;\n}\n\nfunction bFactor_(p) {\n  return height_(p.right) - height_(p.left);\n}\n\nfunction countHeightAndWeight_(p) {\n  var hl = height_(p.left);\n  var hr = height_(p.right);\n  p.height = (hl > hr ? hl : hr) + 1;\n\n  var wl = weight_(p.left);\n  var wr = weight_(p.right);\n  p.weight = wl + wr + 1;\n}\n\nfunction rotateRight_(p) {\n  var q = p.left;\n  p.left = q.right;\n  q.right = p;\n  countHeightAndWeight_(p);\n  countHeightAndWeight_(q);\n  return q;\n}\n\nfunction rotateLeft_(q) {\n  var p = q.right;\n  q.right = p.left;\n  p.left = q;\n  countHeightAndWeight_(q);\n  countHeightAndWeight_(p);\n  return p;\n}\n\nfunction balance_(p) {\n  countHeightAndWeight_(p);\n  if (bFactor_(p) === 2) {\n    if (bFactor_(p.right) < 0)\n      p.right = rotateRight_(p.right);\n    return rotateLeft_(p);\n  }\n  if (bFactor_(p) === -2) {\n    if (bFactor_(p.left) > 0)\n      p.left = rotateLeft_(p.left);\n    return rotateRight_(p);\n  }\n  return p;\n}\n\nfunction count_(p, k) {\n  return upperBound_(p, k) - lowerBound_(p, k);\n}\n\nfunction at_(p, k) {\n  if (!p) return null;\n  var wl = weight_(p.left);\n  if (wl <= k && k < wl + 1) return p.key;\n  else if (k < wl) return at_(p.left, k);\n  else return at_(p.right, k - wl - 1);\n}\n\nfunction getMinimum_(p) {\n  if (!p) return null;\n  return p.left ? getMinimum_(p.left) : p;\n}\n\nfunction getMaximum_(p) {\n  if (!p) return null;\n  return p.right ? getMaximum_(p.right) : p;\n}\n\nfunction removeMinimun_(p) {\n  if (!p.left) return p.right;\n  p.left = removeMinimun_(p.left);\n  return balance_(p);\n}\n\nfunction toArray_(p) {\n  var arr = [];\n  if (p.left) arr = arr.concat(toArray_(p.left));\n  arr.push(p.key);\n  if (p.right) arr = arr.concat(toArray_(p.right));\n  return arr;\n}\n\nvar AVLTree = function(comparer) {\n  if (!comparer) comparer = comparer_;\n  var AVL = {\n    root: null,\n    comparer_: comparer,\n\n    size: function() {\n      return weight_(AVL.root);\n    },\n\n    min: function() {\n      var p = getMinimum_(AVL.root);\n      if (p) return p.key;\n      return null;\n    },\n\n    max: function() {\n      var p = getMaximum_(AVL.root);\n      if (p) return p.key;\n      return null;\n    },\n\n    lowerBound: function(k) {\n      return AVL.lowerBound_(AVL.root, k);\n    },\n    lowerBound_(p, k) {\n      if (!p) return 0;\n      var cmp = AVL.comparer_(k, p.key);\n\n      if (cmp <= 0) return AVL.lowerBound_(p.left, k);\n      else if (cmp > 0) return weight_(p.left) + AVL.lowerBound_(p.right, k) + 1;\n    },\n\n    upperBound: function(k) {\n      return AVL.upperBound_(AVL.root, k);\n    },\n\n    upperBound_(p, k) {\n      if (!p) return 0;\n      var cmp = AVL.comparer_(k, p.key);\n\n      if (cmp < 0) return AVL.upperBound_(p.left, k);\n      else if (cmp >= 0) return weight_(p.left) + AVL.upperBound_(p.right, k) + 1;\n    },\n\n    count: function(k) {\n      return count_(AVL.root, k);\n    },\n\n    at: function(k) {\n      return at_(AVL.root, k);\n    },\n\n    insert: function(k) {\n      AVL.root = AVL.insert_(AVL.root, k);\n    },\n\n    insert_(p, k) {\n      if (!p) return createNewNode_(k);\n      var cmp = AVL.comparer_(k, p.key);\n\n      if (cmp < 0) p.left = AVL.insert_(p.left, k);\n      else if (cmp >= 0) p.right = AVL.insert_(p.right, k);\n      return balance_(p);\n    },\n\n    remove: function(k) {\n      AVL.root = AVL.remove_(AVL.root, k);\n    },\n\n    remove_(p, k) {\n      if (!p) return null;\n      var cmp = AVL.comparer_(k, p.key);\n\n      if (cmp < 0) p.left = AVL.remove_(p.left, k);\n      else if (cmp > 0) p.right = AVL.remove_(p.right, k);\n      else {\n        var q = p.left;\n        var r = p.right;\n        if (!r) return q;\n\n        var min = getMinimum_(r);\n        min.right = removeMinimun_(r);\n        min.left = q;\n        return balance_(min);\n      }\n      return balance_(p);\n    },\n\n    removeAt: function(k) {\n      var val = AVL.at(k);\n      AVL.root = AVL.remove_(AVL.root, val);\n    },\n\n    toArray: function() {\n      if (AVL.root === null) return [];\n      return toArray_(AVL.root);\n    }\n  }\n  return AVL;\n}\n\nexport default AVLTree;\n"],"names":["createNewNode_","key","weight","height","left","right","comparer_","a","b","height_","p","weight_","bFactor_","countHeightAndWeight_","hl","hr","wl","wr","rotateRight_","q","rotateLeft_","balance_","count_","k","upperBound_","lowerBound_","at_","getMinimum_","getMaximum_","removeMinimun_","toArray_","arr","concat","push","AVLTree","comparer","AVL","root","size","min","max","lowerBound","cmp","upperBound","count","at","insert","insert_","remove","remove_","r","removeAt","val","toArray"],"mappings":"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"}