Files

120 lines
2.4 KiB
JavaScript
Raw Permalink Normal View History

/**
* Created by Strawmanbobi
* 2014-03-14
*/
let Map = function() {
this.elements = [];
};
Map.prototype.size = function() {
return this.elements.length;
};
Map.prototype.isEmpty = function() {
return (this.elements.length < 1);
};
Map.prototype.clear = function() {
this.elements = [];
};
Map.prototype.put = function(_key, _value) {
this.elements.push( {
key : _key,
value : _value
});
};
Map.prototype.remove = function(_key) {
let bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key) {
this.elements.splice(i, 1);
return true;
}
}
} catch (e) {
bln = false;
}
return bln;
};
Map.prototype.get = function(_key) {
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key) {
return this.elements[i].value;
}
}
} catch (e) {
return null;
}
};
Map.prototype.set = function(_key, _value) {
for(i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key) {
this.elements[i].value = _value;
return;
}
}
this.elements.push({
key : _key,
value : _value
});
};
Map.prototype.element = function(_index) {
if (_index < 0 || _index >= this.elements.length) {
return null;
}
return this.elements[_index];
};
Map.prototype.containsKey = function(_key) {
let bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key) {
bln = true;
}
}
} catch (e) {
bln = false;
}
return bln;
};
Map.prototype.containsValue = function(_value) {
let bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].value == _value) {
bln = true;
}
}
} catch (e) {
bln = false;
}
return bln;
};
Map.prototype.values = function() {
let arr = [];
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].value);
}
return arr;
};
Map.prototype.keys = function() {
let arr = [];
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].key);
}
return arr;
};
module.exports = Map;