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(simulator): sort exports
[e-mobility-charging-stations-simulator.git]
/
src
/
utils
/
CircularArray.ts
diff --git
a/src/utils/CircularArray.ts
b/src/utils/CircularArray.ts
index bf9553109f53bf8f2f9a687ab6cf9fadf13be3cb..ad25bf858b4197bc5c0789b478f89bba84b3ab6a 100644
(file)
--- a/
src/utils/CircularArray.ts
+++ b/
src/utils/CircularArray.ts
@@
-1,6
+1,11
@@
-const DEFAULT_CIRCULAR_ARRAY_SIZE = 2000;
+// Copyright Jerome Benoit. 2021-2023. All Rights Reserved.
-export default class CircularArray<T> extends Array<T> {
+const DEFAULT_CIRCULAR_ARRAY_SIZE = 1024;
+
+/**
+ * Array with a maximum length shifting items when full.
+ */
+export class CircularArray<T> extends Array<T> {
public size: number;
constructor(size: number = DEFAULT_CIRCULAR_ARRAY_SIZE, ...items: T[]) {
public size: number;
constructor(size: number = DEFAULT_CIRCULAR_ARRAY_SIZE, ...items: T[]) {
@@
-25,18
+30,16
@@
export default class CircularArray<T> extends Array<T> {
if (length > this.size) {
super.splice(this.size, items.length);
}
if (length > this.size) {
super.splice(this.size, items.length);
}
- return length;
+ return
this.
length;
}
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(
0,
concatenatedCircularArray.size = this.size;
if (concatenatedCircularArray.length > concatenatedCircularArray.size) {
concatenatedCircularArray.splice(
0,
- concatenatedCircularArray.length -
this
.size
+ concatenatedCircularArray.length -
concatenatedCircularArray
.size
);
}
return concatenatedCircularArray;
);
}
return concatenatedCircularArray;
@@
-44,7
+47,7
@@
export default 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);