UNPKG

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
/* 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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"}