repositories
/
e-mobility-charging-stations-simulator.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
refactor: cleanup async lock API
[e-mobility-charging-stations-simulator.git]
/
src
/
utils
/
CircularArray.ts
diff --git
a/src/utils/CircularArray.ts
b/src/utils/CircularArray.ts
index 93dacdb0ee8d421f592ff6b05e31ef1b23b9acc4..fb73ced97d3ccca0610158d049b2acc828693a67 100644
(file)
--- a/
src/utils/CircularArray.ts
+++ b/
src/utils/CircularArray.ts
@@
-1,6
+1,10
@@
-export const DEFAULT_CIRCULAR_ARRAY_SIZE = 2000;
+// Copyright Jerome Benoit. 2021-2023. All Rights Reserved.
-/** Array with a maximum length shifting items when full. */
+const DEFAULT_CIRCULAR_ARRAY_SIZE = 1024;
+
+/**
+ * Array with a maximum length and shifting items when full.
+ */
export class CircularArray<T> extends Array<T> {
public size: number;
export class CircularArray<T> extends Array<T> {
public size: number;
@@
-30,9
+34,7
@@
export class CircularArray<T> extends Array<T> {
}
public concat(...items: (T | ConcatArray<T>)[]): CircularArray<T> {
}
public concat(...items: (T | ConcatArray<T>)[]): CircularArray<T> {
- const concatenatedCircularArray = super.concat(
- items as T[]
- ) as CircularArray<T>;
+ const concatenatedCircularArray = super.concat(items as T[]) as CircularArray<T>;
concatenatedCircularArray.size = this.size;
if (concatenatedCircularArray.length > concatenatedCircularArray.size) {
concatenatedCircularArray.splice(
concatenatedCircularArray.size = this.size;
if (concatenatedCircularArray.length > concatenatedCircularArray.size) {
concatenatedCircularArray.splice(
@@
-45,7
+47,7
@@
export class CircularArray<T> extends Array<T> {
public splice(start: number, deleteCount?: number, ...items: T[]): T[] {
let itemsRemoved: T[];
public splice(start: number, deleteCount?: number, ...items: T[]): T[] {
let itemsRemoved: T[];
- if (arguments.length >= 3 &&
typeof deleteCount !== 'undefined'
) {
+ if (arguments.length >= 3 &&
deleteCount !== undefined
) {
itemsRemoved = super.splice(start, deleteCount);
// FIXME: that makes the items insert not in place
this.push(...items);
itemsRemoved = super.splice(start, deleteCount);
// FIXME: that makes the items insert not in place
this.push(...items);
@@
-77,9
+79,12
@@
export class CircularArray<T> extends Array<T> {
return this.length === this.size;
}
return this.length === this.size;
}
- private checkSize(size: number) {
+ private checkSize(size: number): void {
+ if (!Number.isSafeInteger(size)) {
+ throw new TypeError(`Invalid circular array size: ${size} is not a safe integer`);
+ }
if (size < 0) {
if (size < 0) {
- throw new RangeError(
'Invalid circular array size'
);
+ throw new RangeError(
`Invalid circular array size: ${size} < 0`
);
}
}
}
}
}
}