2021-05-20 23:08:38 +00:00
|
|
|
export class limitedArray {
|
2023-04-30 16:32:28 +00:00
|
|
|
_array: unknown[];
|
2021-05-20 23:08:38 +00:00
|
|
|
_limit: number;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to construct the LimitedArray
|
|
|
|
* Defaults to 100 when no size is passed in
|
|
|
|
* @param size
|
|
|
|
*/
|
|
|
|
constructor(size = 100) {
|
|
|
|
this._array = [];
|
|
|
|
this._limit = size;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add items to the end of an array
|
|
|
|
* @param item
|
|
|
|
*/
|
|
|
|
|
2023-04-30 16:32:28 +00:00
|
|
|
push(item: unknown): void {
|
2021-05-20 23:08:38 +00:00
|
|
|
this._array.push(item);
|
|
|
|
if (this._array.length > this._limit) this._array.shift();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the items within the array
|
|
|
|
* @returns {[]}
|
|
|
|
*/
|
2023-04-30 16:32:28 +00:00
|
|
|
get(): unknown[] {
|
2021-05-20 23:08:38 +00:00
|
|
|
return this._array;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Limits the size of the array
|
|
|
|
* @param size
|
|
|
|
*/
|
|
|
|
limit(size: number): void {
|
|
|
|
this._limit = size;
|
|
|
|
if (this._array.length > this._limit) this._array = this._array.slice(this._array.length - this._limit);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the length of the array
|
|
|
|
* @returns {number}
|
|
|
|
*/
|
|
|
|
length(): number {
|
|
|
|
return this._array.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bulk add an array to the array
|
|
|
|
* @param items
|
|
|
|
*/
|
2023-04-30 16:32:28 +00:00
|
|
|
add(items: unknown[]): void {
|
2021-05-20 23:08:38 +00:00
|
|
|
this._array = this._array.concat(items);
|
|
|
|
|
|
|
|
if (this._array.length > this._limit) this._array = this._array.slice(this._array.length - this._limit);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove an item from the beginning of an array
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
2023-04-30 16:32:28 +00:00
|
|
|
shift(): unknown {
|
2021-05-20 23:08:38 +00:00
|
|
|
return this._array.shift();
|
|
|
|
}
|
|
|
|
}
|