custom-permutation 1.1.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,108 +1,121 @@
1
- # Version
2
- 1.1.0
1
+ # Custom Permutation Generator
3
2
 
4
- # Fixed bugs
5
- 23.09.2024 - Edge cases are handled and the codespace is simplified.
6
- 25.09.2023 - unChoices did not reflect always, fixed now.
3
+ ## Usage
7
4
 
8
- # Custom Permutation Generator
5
+ ### 1.1. `require`
9
6
 
10
- ## 1.1. `require`
11
7
  ```ts
12
- const CustomPermutation = require('custom-permutation')
8
+ const CustomPermutation = require('custom-permutation');
13
9
  ```
14
- ## 1.2. ,`import`
10
+
11
+ ### 1.2. `import`
15
12
 
16
13
  ```ts
17
- import CustomPermutation from "custom-permutation";
14
+ import CustomPermutation from 'custom-permutation';
18
15
  ```
19
16
 
20
17
  ## 2. Constructor
18
+
21
19
  ```ts
22
- CustomPermutation(elList:[els...], choices:{ index: [els...]] }, nonChoices:{ index: [els...]] })
20
+ CustomPermutation(
21
+ elList:[],
22
+ choices:{ index: [] },
23
+ nonChoices:{ index: [] }
24
+ )
23
25
  ```
24
26
 
25
- ## 3. Usage explanation
27
+ ## 3. Usage explanied
26
28
 
27
29
  _example:_
28
30
 
29
31
  ```ts
30
- CustomPermutation(["a", "b", "c"], {1: ["a", "b"]}, {0: ["a"]})
32
+ CustomPermutation(['a', 'b', 'c'], { '1': ['a', 'b'] }, { '0': ['a'] });
31
33
  ```
32
34
 
33
35
  Permutate 3 elements which are "a", "b" and "c" with below rules
34
36
 
35
- __- choices rule:__
37
+ **`choices` rule:**
38
+
36
39
  ```json
37
40
  { "1": ["a", "b"] }
38
41
  ```
39
42
 
40
- At index=1 there can only be the element "a" or "b"
43
+ > At `index=1` there can only be the element `"a"` or `"b"`
44
+
45
+ **`nonChoices` rule:**
41
46
 
42
- __- nonChoices rule:__
43
47
  ```json
44
48
  { "0": ["a"] }
45
49
  ```
46
50
 
47
- At index=0 there can NOT be the element "a"
51
+ > At `index=0` there can NOT be the element `"a"`
48
52
 
49
53
  _Note: given index are considered as 0 based: [index=0, index=1, etc.]_
50
54
 
55
+ | index | all options | after customization |
56
+ | :---: | :-----------------: | :-----------------: |
57
+ | 0 | `"a"`, `"b"`, `"c"` | `"b"`, `"c"` |
58
+ | 1 | `"a"`, `"b"`, `"c"` | `"a"`, `"b"` |
59
+ | 2 | `"a"`, `"b"`, `"c"` | `"a"`, `"b"`, `"c"` |
60
+
51
61
  ## 4. Result set explanation:
52
62
 
53
- Let's see all permutations, and which ones are valid or not.
54
- - [ ] `["a", "b", "c"]` // violates nonChoices rule: _first element is `"a"`, but shouldn't be `"a"`
55
- - [ ] `["a", "c", "b"]` // violates nonChoices rule: _first element is `"a"`, but shouldn't be `"a"`_
56
- - [x] `["b", "a", "c"]`
57
- - [ ] `["b", "c", "a"]` // violates choices rule: _second element is `"c"` but `"a"` or `"b"` is desired_
58
- - [x] `["c", "a", "b"]`
59
- - [x] `["c", "b", "a"]`
63
+ Let's check all permutations, and see which ones are and are not valid.
64
+
65
+ | Permutation | Is valid | Violates | Description |
66
+ | :---------------: | :------: | :--------: | :--------------------------------------------: |
67
+ | `["a", "b", "c"]` | No | nonChoices | _first elemen can't be `"a"`_ |
68
+ | `["a", "c", "b"]` | No | nonChoices | _first elemen can't be `"a"`_ |
69
+ | `["b", "a", "c"]` | Yes | - | - |
70
+ | `["b", "c", "a"]` | No | choices | _second element is asked to be `"a"` or `"b"`_ |
71
+ | `["c", "a", "b"]` | Yes | - | - |
72
+ | `["c", "b", "a"]` | Yes | - | - |
60
73
 
61
- So there are just 3 results that should be generated with this parameters.
74
+ So there are just **3** results that chould be generated with these parameters.
62
75
 
63
76
  ## 5. Complete example
64
77
 
65
- ### 1. Create permutation
78
+ ### 5.1. Create object from `CustomPermutation` class
66
79
 
67
80
  ```ts
68
- let customPerm = new CustomPermutation(
69
- ["a", "b", "c"],
70
- { "1": ["a", "b"] },
71
- { "0": ["a"] }
72
- );
81
+ let customPerm = new CustomPermutation(['a', 'b', 'c'], { '1': ['a', 'b'] }, { '0': ['a'] });
73
82
  ```
74
83
 
75
- ### 2. Get next value
84
+ ### 5.2. Get next value
76
85
 
77
- #### 2.1. Use with next
86
+ #### 5.2.1. With `next`
78
87
 
79
88
  ```ts
80
89
  let next = customPerm.next();
81
90
 
82
91
  while (next) {
83
- console.log(next)
84
- next = customPerm.next();
92
+ console.log(next);
93
+ next = customPerm.next();
85
94
  }
86
95
  ```
87
96
 
88
- #### 2.2. Or use with generator
97
+ #### 5.2.2. With `generator`
89
98
 
90
99
  ```ts
91
100
  let generator = customPerm.generator();
92
101
  let next = generator.next();
93
102
 
94
103
  while (!next.done) {
95
- console.log(next.value)
96
- next = generator.next();
104
+ console.log(next.value);
105
+ next = generator.next();
97
106
  }
98
107
  ```
99
108
 
100
- ### 3. Output
101
-
102
- __Console__
109
+ **Output:**
103
110
 
104
111
  ```sh
105
112
  ["b", "a", "c"]
106
113
  ["c", "a", "b"]
107
114
  ["c", "b", "a"]
108
- ```
115
+ ```
116
+
117
+ ## Fixed bugs
118
+
119
+ 11.06.2026 - Better typing implemented and more test coverage added.
120
+ 23.09.2024 - Edge cases are handled and the codespace is simplified.
121
+ 25.09.2023 - unChoices did not reflect always, fixed now.
@@ -1,12 +1,12 @@
1
1
  import { CustomPermutationGenerator } from './CustomPermutationGenerator';
2
- export default class CustomPermutation {
2
+ export default class CustomPermutation<T> {
3
3
  private listToPermutate;
4
4
  private choices;
5
5
  private nonChoices;
6
6
  private elementsOrderAbsolute?;
7
7
  private passFn?;
8
- customPermGen: CustomPermutationGenerator;
9
- constructor(listToPermutate: any[], choices: object, nonChoices: object, elementsOrderAbsolute?: any[], passFn?: (items: any[]) => boolean);
10
- next(): any;
11
- generator(): Generator<any, void, unknown>;
8
+ customPermGen: CustomPermutationGenerator<T>;
9
+ constructor(listToPermutate: T[], choices: Record<number, T[]>, nonChoices: Record<number, T[]>, elementsOrderAbsolute?: number[] | undefined, passFn?: ((items: T[]) => boolean) | undefined);
10
+ next(): T[] | null;
11
+ generator(): Generator<T[], void, unknown>;
12
12
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CustomPermutation.js","sourceRoot":"","sources":["../src/CustomPermutation.ts"],"names":[],"mappings":";;AAAA,6EAA0E;AAE1E,MAAqB,iBAAiB;IAGpC,YACU,eAAsB,EACtB,OAAe,EACf,UAAkB,EAClB,qBAA6B,EAC7B,MAAkC;QAJlC,oBAAe,GAAf,eAAe,CAAO;QACtB,YAAO,GAAP,OAAO,CAAQ;QACf,eAAU,GAAV,UAAU,CAAQ;QAClB,0BAAqB,GAArB,qBAAqB,CAAQ;QAC7B,WAAM,GAAN,MAAM,CAA4B;QAE1C,IAAI,CAAC,CAAA,qBAAqB,aAArB,qBAAqB,uBAArB,qBAAqB,CAAE,MAAM,CAAA,EAAE;YAClC,qBAAqB,GAAG,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;SACtE;QAED,IAAI,CAAC,aAAa,GAAG,IAAI,uDAA0B,CACjD,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,MAAM,CACZ,CAAC;IACJ,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,CAAC,SAAS;QACR,IAAI,QAAQ,GAAG,IAAI,CAAC;QAEpB,OAAO,IAAI,EAAE;YACX,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;YACrC,IAAI,QAAQ,EAAE;gBACZ,MAAM,QAAQ,CAAC;aAChB;iBAAM;gBACL,MAAM;aACP;SACF;IACH,CAAC;CACF;AAvCD,oCAuCC"}
1
+ {"version":3,"file":"CustomPermutation.js","sourceRoot":"","sources":["../src/CustomPermutation.ts"],"names":[],"mappings":";;AAAA,6EAA0E;AAE1E,MAAqB,iBAAiB;IAGpC,YACU,eAAoB,EACpB,OAA4B,EAC5B,UAA+B,EAC/B,qBAAgC,EAChC,MAAgC;QAJhC,oBAAe,GAAf,eAAe,CAAK;QACpB,YAAO,GAAP,OAAO,CAAqB;QAC5B,eAAU,GAAV,UAAU,CAAqB;QAC/B,0BAAqB,GAArB,qBAAqB,CAAW;QAChC,WAAM,GAAN,MAAM,CAA0B;QAExC,IAAI,CAAC,CAAA,qBAAqB,aAArB,qBAAqB,uBAArB,qBAAqB,CAAE,MAAM,CAAA,EAAE,CAAC;YACnC,qBAAqB,GAAG,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,CAAC,aAAa,GAAG,IAAI,uDAA0B,CACjD,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,MAAM,CACZ,CAAC;IACJ,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,CAAC,SAAS;QACR,IAAI,QAAQ,GAAG,IAAI,CAAC;QAEpB,OAAO,IAAI,EAAE,CAAC;YACZ,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;YACrC,IAAI,QAAQ,EAAE,CAAC;gBACb,MAAM,QAAQ,CAAC;YACjB,CAAC;iBAAM,CAAC;gBACN,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAvCD,oCAuCC"}
@@ -1,32 +1,38 @@
1
- export declare class CustomPermutationGenerator {
1
+ import { PermutationGeneratorForSet } from './PermutationGeneratorForSet';
2
+ export declare class CustomPermutationGenerator<T> {
2
3
  private elementList;
3
4
  private choicesByIndex;
4
5
  private nonChoicesByIndex;
5
6
  private elementsOrderAbsolute?;
6
7
  private passFunction?;
7
- set: any[];
8
- permutationGenOfSet: any;
8
+ set: T[];
9
+ permutationGenOfSet: PermutationGeneratorForSet;
9
10
  nextIndexList: number[];
10
- finalChoicesByIndexInSet: {};
11
- history: any[];
12
- historyHashes: any[];
13
- current: any[];
11
+ finalChoicesByIndexInSet: {
12
+ [key: string]: number[];
13
+ };
14
+ history: T[][];
15
+ historyHashes: string[];
16
+ current: T[];
14
17
  cursor: number;
15
- constructor(elementList: any[], choicesByIndex?: object, nonChoicesByIndex?: object, elementsOrderAbsolute?: any[], passFunction?: (items: any[]) => boolean);
18
+ constructor(elementList: T[], choicesByIndex: Record<number, T[]>, nonChoicesByIndex: Record<number, T[]>, elementsOrderAbsolute?: number[] | undefined, passFunction?: ((items: T[]) => boolean) | undefined);
16
19
  removeNonChoicesIndexes(): void;
17
20
  setChoicesIndexesInSet(): void;
18
- getAllIndexesOfElementInList(el: any, list: any): any[];
21
+ getAllIndexesOfElementInList(el: unknown, list: unknown[]): number[];
19
22
  completeRestOfIndexes(): void;
20
- extendIndexesOfSameElements(choicesByIndex: any, indexesOfSameElements: any): void;
21
- prev(): any;
22
- next(): any;
23
- nextDistinct(): any;
23
+ extendIndexesOfSameElements(choicesByIndex: Record<string | number, any[]>, indexesOfSameElements: Record<number, number[]>): void;
24
+ prev(): T[] | undefined;
25
+ next(): T[] | null;
26
+ nextDistinct(): {
27
+ value: T[] | undefined;
28
+ done: boolean;
29
+ };
24
30
  saveCurrentToHistory(): void;
25
- getHash(elList: any[]): string;
26
- getElementListByInitialListIndexes(indexes: any): any[];
31
+ getHash(elList: T[]): string;
32
+ getElementListByInitialListIndexes(indexes: number[]): T[];
27
33
  reset(): void;
28
- getSet(): any[];
34
+ getSet(): T[];
29
35
  isEmpty(): boolean;
30
- getCurrent(): any;
31
- last(): any;
36
+ getCurrent(): T[] | null;
37
+ last(): T[];
32
38
  }
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CustomPermutationGenerator = void 0;
4
4
  const PermutationGeneratorForSet_1 = require("./PermutationGeneratorForSet");
5
5
  class CustomPermutationGenerator {
6
- constructor(elementList, choicesByIndex = {}, nonChoicesByIndex = {}, elementsOrderAbsolute, passFunction) {
6
+ constructor(elementList, choicesByIndex, nonChoicesByIndex, elementsOrderAbsolute, passFunction) {
7
7
  this.elementList = elementList;
8
8
  this.choicesByIndex = choicesByIndex;
9
9
  this.nonChoicesByIndex = nonChoicesByIndex;
@@ -45,7 +45,7 @@ class CustomPermutationGenerator {
45
45
  .map((x, i) => i);
46
46
  Object.keys(this.nonChoicesByIndex).forEach((key) => {
47
47
  let indexes = allIndexes.slice();
48
- for (const el of this.nonChoicesByIndex[key]) {
48
+ for (const el of this.nonChoicesByIndex[+key]) {
49
49
  const indexesToRemove = this.getAllIndexesOfElementInList(el, this.elementList);
50
50
  indexes = indexes.filter((x) => indexesToRemove.indexOf(x) < 0);
51
51
  }
@@ -54,11 +54,11 @@ class CustomPermutationGenerator {
54
54
  }
55
55
  setChoicesIndexesInSet() {
56
56
  for (const key in this.choicesByIndex) {
57
- if (!this.choicesByIndex[key]) {
57
+ if (!this.choicesByIndex[+key]) {
58
58
  continue;
59
59
  }
60
60
  let indexesInList = [];
61
- for (const el of this.choicesByIndex[key]) {
61
+ for (const el of this.choicesByIndex[+key]) {
62
62
  indexesInList = indexesInList.concat(this.getAllIndexesOfElementInList(el, this.elementList));
63
63
  }
64
64
  this.finalChoicesByIndexInSet[key] = indexesInList;
@@ -105,17 +105,20 @@ class CustomPermutationGenerator {
105
105
  // cursor-1 is current, cursor-2 is prev
106
106
  return this.history[--this.cursor - 1];
107
107
  }
108
+ return undefined;
108
109
  }
109
110
  next() {
110
- let nextDistinctPerm = this.nextDistinct();
111
- return !nextDistinctPerm.done ? nextDistinctPerm.value : null;
111
+ var _a;
112
+ const nextDistinctPerm = this.nextDistinct();
113
+ return !nextDistinctPerm.done ? ((_a = nextDistinctPerm.value) !== null && _a !== void 0 ? _a : null) : null;
112
114
  }
113
115
  nextDistinct() {
116
+ var _a;
114
117
  if (this.cursor < this.history.length) {
115
118
  return { value: this.history[this.cursor++], done: false };
116
119
  }
117
120
  const nextPerm = this.permutationGenOfSet.next();
118
- this.nextIndexList = nextPerm.value;
121
+ this.nextIndexList = (_a = nextPerm.value) !== null && _a !== void 0 ? _a : [];
119
122
  let elList;
120
123
  if (this.nextIndexList && this.nextIndexList.length > 0) {
121
124
  elList = this.getElementListByInitialListIndexes(nextPerm.value);
@@ -139,13 +142,7 @@ class CustomPermutationGenerator {
139
142
  this.cursor++;
140
143
  }
141
144
  getHash(elList) {
142
- let hash = '';
143
- for (let i = 0; i < elList.length; i++) {
144
- for (let j = 0; j < i + 1; j++) {
145
- hash += String(elList[i]);
146
- }
147
- }
148
- return hash;
145
+ return JSON.stringify(elList);
149
146
  }
150
147
  getElementListByInitialListIndexes(indexes) {
151
148
  if (!indexes || !indexes.length) {
@@ -153,10 +150,7 @@ class CustomPermutationGenerator {
153
150
  }
154
151
  const elList = [];
155
152
  indexes.forEach((index) => {
156
- // if(this.elementList[index]) // Can be added, but costly
157
- {
158
- elList.push(this.elementList[index]);
159
- }
153
+ elList.push(this.elementList[index]);
160
154
  });
161
155
  return elList;
162
156
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CustomPermutationGenerator.js","sourceRoot":"","sources":["../src/CustomPermutationGenerator.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CustomPermutationGenerator.js","sourceRoot":"","sources":["../src/CustomPermutationGenerator.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,7 @@
1
+ type ChoiceEntry = {
2
+ index: number;
3
+ length: number;
4
+ };
1
5
  export declare class PermutationGeneratorForSet {
2
6
  private elementList;
3
7
  private indexList;
@@ -5,31 +9,29 @@ export declare class PermutationGeneratorForSet {
5
9
  private indexesOfSameElements?;
6
10
  private actualOrderOfElements?;
7
11
  private passFunction?;
8
- choicesArraysInitial: any[];
9
- choicesArrays: any[];
12
+ choicesArraysInitial: number[][];
13
+ choicesArrays: number[][];
10
14
  size: number;
11
- currentIndsOfChoices: any[];
15
+ currentIndsOfChoices: number[];
12
16
  currentElInd: number;
13
- newPerm: any[];
14
- initialIndexList: any[];
15
- indexesAndChoicesCountsSortedByLength: any;
16
- indexesAndChoicesCounts: any[];
17
- visitedDict: {};
18
- constructor(elementList: any[], indexList: any[], choicesByIndex?: object, indexesOfSameElements?: any, actualOrderOfElements?: any[], passFunction?: (items: any[]) => boolean);
19
- isNewPermutationPassingFunction(currentEl: any, elIndInPerm: any): boolean;
17
+ newPerm: (number | null)[];
18
+ initialIndexList: number[];
19
+ indexesAndChoicesCountsSortedByLength: ChoiceEntry[];
20
+ indexesAndChoicesCounts: ChoiceEntry[];
21
+ visitedDict: Record<number, boolean>;
22
+ constructor(elementList: any[], indexList: number[], choicesByIndex?: Record<string, number[]> | undefined, indexesOfSameElements?: Record<number, number[]> | undefined, actualOrderOfElements?: number[] | undefined, passFunction?: ((items: any[]) => boolean) | undefined);
23
+ isNewPermutationPassingFunction(currentEl: number, elIndInPerm: number): boolean;
20
24
  reorderListAndChoicesAccordingToChoicesCount(): void;
21
25
  initChoicesArray(): void;
22
26
  init(): void;
23
27
  next(): {
24
28
  done: boolean;
25
- value?: undefined;
26
- } | {
27
- done: boolean;
28
- value: any[];
29
+ value?: number[];
29
30
  };
30
- getNextPerm(): any[];
31
- goBack(newPerm: any, choicesArrayWithIndexes: any, selectedIndexesForPerm: any, elInd: any): any;
32
- getAndSetPossibleNextElementForNewPerm(newPerm: any, choices: any, currentIndsInChoices: any, elInd: any): any;
33
- validateParameters(elementSet: any, choicesByIndex: any): boolean;
34
- revertResultPermToInitialOrder(newPerm: any): any[];
31
+ getNextPerm(): (number | null)[] | undefined;
32
+ goBack(newPerm: (number | null)[], choicesArrayWithIndexes: number[][], selectedIndexesForPerm: number[], elInd: number): boolean;
33
+ getAndSetPossibleNextElementForNewPerm(newPerm: (number | null)[], choices: number[], currentIndsInChoices: number[], elInd: number): number | undefined;
34
+ validateParameters(elementSet: number[], choicesByIndex?: object): boolean;
35
+ revertResultPermToInitialOrder(newPerm: (number | null)[]): (number | null)[];
35
36
  }
37
+ export {};
@@ -9,13 +9,15 @@ class PermutationGeneratorForSet {
9
9
  this.indexesOfSameElements = indexesOfSameElements;
10
10
  this.actualOrderOfElements = actualOrderOfElements;
11
11
  this.passFunction = passFunction;
12
- this.choicesArraysInitial = []; // possible choices for each element for requested permutations
13
- this.choicesArrays = []; // possible choices for each element for requested permutations
12
+ this.choicesArraysInitial = [];
13
+ this.choicesArrays = [];
14
14
  this.size = 0;
15
- this.currentIndsOfChoices = []; // indice array of current perm to compose
16
- this.currentElInd = 0; // indice of current elemet to add in perm list
15
+ this.currentIndsOfChoices = [];
16
+ this.currentElInd = 0;
17
17
  this.newPerm = [];
18
- this.initialIndexList = []; // original set for new permutation
18
+ this.initialIndexList = [];
19
+ this.indexesAndChoicesCountsSortedByLength = [];
20
+ this.indexesAndChoicesCounts = [];
19
21
  this.visitedDict = {};
20
22
  this.actualOrderOfElements =
21
23
  this.actualOrderOfElements ||
@@ -45,7 +47,7 @@ class PermutationGeneratorForSet {
45
47
  if (this.passFunction) {
46
48
  const elArray = [];
47
49
  actualOrderedNewPerm.forEach((elInd, i) => (elArray[i] = this.elementList[elInd]));
48
- const passed = this.passFunction(elArray.filter((x) => x)); // Remove nulls, since some array elements are undefined when building
50
+ const passed = this.passFunction(elArray.filter((x) => x !== undefined && x !== null)); // Remove nulls, since some array elements are undefined when building
49
51
  return passed;
50
52
  }
51
53
  return true;
@@ -67,12 +69,11 @@ class PermutationGeneratorForSet {
67
69
  this.choicesArraysInitial = JSON.parse(JSON.stringify(this.choicesArrays));
68
70
  }
69
71
  initChoicesArray() {
72
+ var _a, _b;
70
73
  this.choicesArrays = [];
71
74
  this.choicesArraysInitial = [];
72
75
  for (let i = 0; i < this.indexList.length; i++) {
73
- this.choicesArrays.push(this.choicesByIndex[i] && this.choicesByIndex[i].length
74
- ? this.choicesByIndex[i].slice()
75
- : this.indexList.slice());
76
+ this.choicesArrays.push(((_b = (_a = this.choicesByIndex) === null || _a === void 0 ? void 0 : _a[i]) === null || _b === void 0 ? void 0 : _b.length) ? this.choicesByIndex[i].slice() : this.indexList.slice());
76
77
  this.choicesArraysInitial.push(this.choicesArrays[i].slice());
77
78
  }
78
79
  }
@@ -93,18 +94,16 @@ class PermutationGeneratorForSet {
93
94
  }
94
95
  next() {
95
96
  let nextPerm = this.getNextPerm();
96
- if ((nextPerm === null || nextPerm === void 0 ? void 0 : nextPerm.length) > 0) {
97
- while (nextPerm.filter((x) => x || x === 0).length < nextPerm.length) {
98
- nextPerm = this.getNextPerm();
99
- if (!nextPerm || nextPerm.length === 0) {
100
- return { done: true };
101
- }
102
- }
103
- return { done: false, value: this.revertResultPermToInitialOrder(nextPerm) };
104
- }
105
- else {
97
+ if (!nextPerm || nextPerm.length === 0) {
106
98
  return { done: true };
107
99
  }
100
+ while (nextPerm.filter((x) => x || x === 0).length < nextPerm.length) {
101
+ nextPerm = this.getNextPerm();
102
+ if (!nextPerm || nextPerm.length === 0) {
103
+ return { done: true };
104
+ }
105
+ }
106
+ return { done: false, value: this.revertResultPermToInitialOrder(nextPerm) };
108
107
  }
109
108
  getNextPerm() {
110
109
  for (let i = this.size - 1; i >= 0 && i < this.size; i++) {
@@ -123,7 +122,7 @@ class PermutationGeneratorForSet {
123
122
  }
124
123
  else {
125
124
  this.newPerm[i] = el;
126
- this.visitedDict[this.newPerm[i]] = true;
125
+ this.visitedDict[el] = true;
127
126
  }
128
127
  }
129
128
  return this.newPerm.slice();
@@ -154,6 +153,7 @@ class PermutationGeneratorForSet {
154
153
  }
155
154
  }
156
155
  }
156
+ return false;
157
157
  }
158
158
  getAndSetPossibleNextElementForNewPerm(newPerm, choices, currentIndsInChoices, elInd) {
159
159
  if (currentIndsInChoices[elInd] < 0) {
@@ -168,7 +168,11 @@ class PermutationGeneratorForSet {
168
168
  }
169
169
  newPerm[elInd] = choices[currentIndsInChoices[elInd]];
170
170
  this.visitedDict[newPerm[elInd]] = true;
171
- this.choicesArrays[elInd] = this.choicesArrays[elInd].filter((x) => this.indexesOfSameElements[newPerm[elInd]] && this.indexesOfSameElements[newPerm[elInd]].indexOf(x) === -1);
171
+ this.choicesArrays[elInd] = this.choicesArrays[elInd].filter((x) => {
172
+ var _a;
173
+ return ((_a = this.indexesOfSameElements) === null || _a === void 0 ? void 0 : _a[newPerm[elInd]]) &&
174
+ this.indexesOfSameElements[newPerm[elInd]].indexOf(x) === -1;
175
+ });
172
176
  return choices[currentIndsInChoices[elInd]];
173
177
  }
174
178
  else {
@@ -1 +1 @@
1
- {"version":3,"file":"PermutationGeneratorForSet.js","sourceRoot":"","sources":["../src/PermutationGeneratorForSet.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"PermutationGeneratorForSet.js","sourceRoot":"","sources":["../src/PermutationGeneratorForSet.ts"],"names":[],"mappings":"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"}
package/lib/demo.d.ts ADDED
@@ -0,0 +1 @@
1
+ export {};
package/lib/demo.js ADDED
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const CustomPermutation_1 = require("./CustomPermutation");
4
+ let customPerm = new CustomPermutation_1.default([], {}, {});
5
+ while (true) {
6
+ const next = customPerm.next();
7
+ if (!next) {
8
+ break;
9
+ }
10
+ console.log(next);
11
+ }
12
+ //# sourceMappingURL=demo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"demo.js","sourceRoot":"","sources":["../src/demo.ts"],"names":[],"mappings":";;AAAA,2DAAoD;AAEpD,IAAI,UAAU,GAAG,IAAI,2BAAiB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AACnD,OAAO,IAAI,EAAE,CAAC;IACZ,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;IAE/B,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM;IACR,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AACpB,CAAC"}
package/lib/index.d.ts CHANGED
@@ -1 +1 @@
1
- export {};
1
+ export { default } from './CustomPermutation';
package/lib/index.js CHANGED
@@ -1,14 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const CustomPermutation_1 = require("./CustomPermutation");
4
- let customPerm = new CustomPermutation_1.default([], {}, {});
5
- let count = 0;
6
- while (true) {
7
- let next = customPerm.next();
8
- if (!next) {
9
- break;
10
- }
11
- count++;
12
- }
13
- module.exports = CustomPermutation_1.default;
3
+ exports.default = void 0;
4
+ var CustomPermutation_1 = require("./CustomPermutation");
5
+ Object.defineProperty(exports, "default", { enumerable: true, get: function () { return CustomPermutation_1.default; } });
14
6
  //# sourceMappingURL=index.js.map
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAAA,2DAAoD;AAEpD,IAAI,UAAU,GAAG,IAAI,2BAAiB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AACnD,IAAI,KAAK,GAAG,CAAC,CAAC;AAEd,OAAO,IAAI,EAAE;IACX,IAAI,IAAI,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;IAE7B,IAAI,CAAC,IAAI,EAAE;QACT,MAAM;KACP;IAED,KAAK,EAAE,CAAC;CACT;AAED,MAAM,CAAC,OAAO,GAAG,2BAAiB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,yDAA8C;AAArC,4GAAA,OAAO,OAAA"}
package/package.json CHANGED
@@ -1,6 +1,9 @@
1
1
  {
2
2
  "name": "custom-permutation",
3
- "version": "1.1.0",
3
+ "version": "1.1.1",
4
+ "engines": {
5
+ "node": ">=18.0.0"
6
+ },
4
7
  "description": "Permutation generator with custom options.",
5
8
  "main": "lib/index.js",
6
9
  "types": "lib/index.d.ts",
@@ -8,12 +11,13 @@
8
11
  "test": "jest --config jestconfig.json",
9
12
  "build": "tsc",
10
13
  "format": "prettier --write \"src/**/*.ts\"",
11
- "lint": "tslint -p tsconfig.json",
14
+ "lint": "eslint src",
12
15
  "prepare": "npm run build",
13
16
  "prepublishOnly": "npm test && npm run preversion",
14
- "preversion": "true || npm run lint",
17
+ "preversion": "npm run lint",
15
18
  "version": "npm run format && git add -A src",
16
- "postversion": "git push && git push --tags"
19
+ "postversion": "git push && git push --tags",
20
+ "demo": "ts-node src/demo.ts"
17
21
  },
18
22
  "repository": {
19
23
  "type": "git",
@@ -29,19 +33,22 @@
29
33
  "Permutation with Options"
30
34
  ],
31
35
  "author": "@yilmazhasan",
32
- "license": "ISC",
36
+ "license": "GPL-3.0",
33
37
  "bugs": {
34
38
  "url": "https://github.com/yilmazhasan/custom-permutation/issues"
35
39
  },
36
40
  "homepage": "https://github.com/yilmazhasan/custom-permutation#readme",
37
41
  "devDependencies": {
38
- "@types/jest": "^26.0.23",
39
- "jest": "^27.0.6",
40
- "prettier": "^2.3.2",
41
- "ts-jest": "^27.0.3",
42
+ "@types/jest": "^29.5.14",
43
+ "@types/node": "^25.9.3",
44
+ "@typescript-eslint/eslint-plugin": "^8.61.0",
45
+ "@typescript-eslint/parser": "^8.61.0",
46
+ "eslint": "^10.4.1",
47
+ "eslint-config-prettier": "^10.1.8",
48
+ "jest": "^29.7.0",
49
+ "prettier": "^3.8.4",
50
+ "ts-jest": "^29.4.11",
42
51
  "ts-node": "^10.9.2",
43
- "tslint": "^6.1.3",
44
- "tslint-config-prettier": "^1.18.0",
45
- "typescript": "^4.3.5"
52
+ "typescript": "^5.9.3"
46
53
  }
47
54
  }