cdk-lambda-subminute 2.0.611 → 2.0.613

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/.jsii CHANGED
@@ -4411,6 +4411,6 @@
4411
4411
  "symbolId": "src/cdk-lambda-subminute:SubminuteStateMachineProps"
4412
4412
  }
4413
4413
  },
4414
- "version": "2.0.611",
4415
- "fingerprint": "t8ifmCS5mZBmgIdl22Xhwn6VkibvIrNvPLT0nvNK8xI="
4414
+ "version": "2.0.613",
4415
+ "fingerprint": "lztMhTEUIL1tBfOkKTFeR65KyAPmeO5uxjpXRjxYHrI="
4416
4416
  }
@@ -45,7 +45,7 @@ class LambdaSubminute extends constructs_1.Construct {
45
45
  }
46
46
  exports.LambdaSubminute = LambdaSubminute;
47
47
  _a = JSII_RTTI_SYMBOL_1;
48
- LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.611" };
48
+ LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.613" };
49
49
  class IteratorLambda extends constructs_1.Construct {
50
50
  constructor(scope, name, props) {
51
51
  super(scope, name);
@@ -85,7 +85,7 @@ class IteratorLambda extends constructs_1.Construct {
85
85
  }
86
86
  exports.IteratorLambda = IteratorLambda;
87
87
  _b = JSII_RTTI_SYMBOL_1;
88
- IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.611" };
88
+ IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.613" };
89
89
  class SubminuteStateMachine extends constructs_1.Construct {
90
90
  constructor(scope, id, props) {
91
91
  super(scope, id);
@@ -160,5 +160,5 @@ class SubminuteStateMachine extends constructs_1.Construct {
160
160
  }
161
161
  exports.SubminuteStateMachine = SubminuteStateMachine;
162
162
  _c = JSII_RTTI_SYMBOL_1;
163
- SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.611" };
163
+ SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.613" };
164
164
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-lambda-subminute.js","sourceRoot":"","sources":["../src/cdk-lambda-subminute.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport events = require('aws-cdk-lib/aws-events');\nimport targets = require('aws-cdk-lib/aws-events-targets');\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\nimport { IFunction, Runtime, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { NodejsFunction } from 'aws-cdk-lib/aws-lambda-nodejs';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\nimport { Construct } from 'constructs';\n\nexport interface LambdaSubminuteProps {\n  /**\n   * The Lambda function that is going to be executed per time unit less than one minute.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * A pattern you want this statemachine to be executed.\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * @default cron(50/1 15-17 ? * * *) UTC+0 being run every minute starting from 15:00 PM to 17:00 PM.\n   */\n  readonly cronjobExpression?: string;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency?: number;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime?: number;\n}\n\nexport class LambdaSubminute extends Construct {\n  /**\n   * The Lambda function that plays the role of the iterator.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * The ARN of the state machine that executes the target Lambda function per time unit less than one minute.\n   */\n  readonly stateMachineArn: string;\n  constructor(parent: Construct, name: string, props: LambdaSubminuteProps) {\n    super(parent, name);\n    const iterator = new IteratorLambda(this, 'IteratorLambda', { targetFunction: props.targetFunction });\n    this.iteratorFunction = iterator.function;\n    const subminuteStateMachine = new SubminuteStateMachine(this, 'SubminuteStateMachine', {\n      stateMachineName: 'lambda-subminute-statemachine',\n      targetFunction: props.targetFunction,\n      iteratorFunction: this.iteratorFunction,\n      intervalTime: props.intervalTime ?? 10,\n      frequency: props.frequency ?? 6,\n    });\n    this.stateMachineArn = subminuteStateMachine.stateMachine.stateMachineArn;\n\n    const startRule = new events.Rule(this, 'StartSubminuteStateMachine', {\n      schedule: events.Schedule.expression(props.cronjobExpression ?? 'cron(50/1 15-17 ? * * *)'),\n      ruleName: 'subminute-statemachine-lambda-rule',\n      description: `A rule to run the subminute state machine, i.e. ${subminuteStateMachine.stateMachine.stateMachineName}`,\n    });\n    startRule.addTarget(new targets.SfnStateMachine(\n      subminuteStateMachine.stateMachine, {\n        input: events.RuleTargetInput.fromObject({\n          iterator: {\n            index: 0,\n            count: 6,\n          },\n        }),\n      }));\n  }\n}\n\nexport interface IteratorLambdaProps {\n  /**\n     * The Lambda function that is going to be executed per time unit less than one minute.\n     */\n  readonly targetFunction: IFunction;\n}\n\nexport class IteratorLambda extends Construct {\n  /**\n     * A Lambda function that plays the role of the iterator.\n     */\n  readonly function: IFunction;\n  constructor(scope: Construct, name: string, props: IteratorLambdaProps) {\n    super(scope, name);\n    const iteratorLambdaRole = new iam.Role(this, 'IteratorLambdaRole', {\n      assumedBy: new iam.CompositePrincipal(\n        new iam.ServicePrincipal('lambda.amazonaws.com'),\n      ),\n      description: 'An execution role for a Lambda function to invoke a target Lambda Function per time unit less than one minute',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXRayDaemonWriteAccess'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole'),\n      ],\n      roleName: 'Lambda-Iterator-Role',\n    });\n    cdk.DockerVolumeConsistency.CONSISTENT;\n\n\n    iteratorLambdaRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'TargetLambdaPermission',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [props.targetFunction.functionArn],\n    }));\n\n    this.function = new NodejsFunction(this, 'Iterator', {\n      functionName: 'lambda-subminute-iterator',\n      description: 'A function for breaking the limit of 1 minute with the CloudWatch Rules.',\n      logRetention: RetentionDays.THREE_MONTHS,\n      runtime: Runtime.NODEJS_18_X,\n      entry: fs.existsSync(path.join(__dirname, 'resources/iterator/iterator_agent.ts')) ? path.join(__dirname, 'resources/iterator/iterator_agent.ts') : path.join(__dirname, 'resources/iterator/iterator_agent.js'),\n      handler: 'lambdaHandler',\n      environment: {\n        TARGET_FN_NAME: props.targetFunction.functionName,\n      },\n      memorySize: 128,\n      role: iteratorLambdaRole,\n      timeout: cdk.Duration.seconds(58), // 1 min\n      tracing: Tracing.ACTIVE,\n    });\n  }\n}\n\nexport interface SubminuteStateMachineProps {\n  /**\n   * the name of the state machine.\n   */\n  readonly stateMachineName: string;\n  /**\n   * the Lambda function that executes your intention.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * the iterator Lambda function for the target Lambda function.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime: number;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency: number;\n}\n\nexport class SubminuteStateMachine extends Construct {\n  readonly stateMachine: sfn.StateMachine;\n  constructor(scope: Construct, id: string, props: SubminuteStateMachineProps) {\n    super(scope, id);\n    const stateMachineRole = this._createWorkFlowRole(\n      props.targetFunction.functionArn, props.iteratorFunction.functionArn);\n    const jobDefinition = this.createJobDefinition(props.iteratorFunction, props.intervalTime, props.frequency);\n    const stateMachine = new sfn.StateMachine(this, 'StateMachine', {\n      stateMachineName: props.stateMachineName,\n      definition: jobDefinition,\n      role: stateMachineRole,\n    });\n    this.stateMachine = stateMachine;\n  }\n\n  /**\n   * Creates a state machine for breaking the limit of 1 minute with the CloudWatch Rules.\n   *\n   * @param iteratorFunction The iterator Lambda function for the target Labmda funciton.\n   * @param intervalTime Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   * @param frequency How many times you intent to execute in a minute.\n   * @returns THe job definition for the state machine.\n   */\n  private createJobDefinition = (\n    iteratorFunction: IFunction, intervalTime: number, frequency: number): sfn.Chain => {\n    const configureCount = new sfn.Pass(this, 'ConfigureCount', {\n      result: sfn.Result.fromObject({\n        index: 0,\n        count: frequency,\n      }),\n      resultPath: '$.iterator',\n    });\n    const iterator = new tasks.LambdaInvoke(this, 'Iterator', {\n      lambdaFunction: iteratorFunction,\n      resultPath: '$.iterator',\n      resultSelector: {\n        'index.$': '$.Payload.index',\n        'count.$': '$.Payload.count',\n        'continue.$': '$.Payload.continue',\n      },\n    });\n    const wait = new sfn.Wait(this, 'Wait for the target Lambda function finished', {\n      time: sfn.WaitTime.duration(cdk.Duration.seconds(intervalTime)),\n    });\n    wait.next(iterator);\n    const done = new sfn.Pass(this, 'Done');\n\n    const isCountReached = new sfn.Choice(this, 'IsCountReached');\n    isCountReached.when(sfn.Condition.booleanEquals('$.iterator.continue', true), wait);\n    isCountReached.otherwise(done);\n    const jobDefinition = configureCount.next(iterator).next(isCountReached);\n    return jobDefinition;\n  };\n\n  /**\n   * Creates a role and corresponding policies for the subminute state machine.\n   *\n   * @param targetFunctionArn the ARN of the Lambda function that executes your intention.\n   * @param iteratorFunctionArn the ARN of the iterator Lambda function for the target Lambda function.\n   * @returns the role as the documentation indicates.\n   */\n  private _createWorkFlowRole = (targetFunctionArn: string, iteratorFunctionArn: string) => {\n    const workFlowExecutionRole = new iam.Role(this, 'StepFunctionExecutionRole', {\n      assumedBy: new iam.ServicePrincipal('states.amazonaws.com'),\n      description: 'Execute a workflow related to executing a Lambda function per time unit less than 1 minute.',\n    });\n    workFlowExecutionRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'LambdaInvokePermissions',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [\n        targetFunctionArn,\n        iteratorFunctionArn,\n      ],\n    }));\n    return workFlowExecutionRole;\n  };\n}"]}
@@ -11,6 +11,7 @@
11
11
  "GetIntrinsic",
12
12
  ],
13
13
  }],
14
+ "no-extra-parens": 0,
14
15
  "no-magic-numbers": 0,
15
16
  },
16
17
  }
@@ -5,6 +5,13 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [v1.0.2](https://github.com/ljharb/call-bind-apply-helpers/compare/v1.0.1...v1.0.2) - 2025-02-12
9
+
10
+ ### Commits
11
+
12
+ - [types] improve inferred types [`e6f9586`](https://github.com/ljharb/call-bind-apply-helpers/commit/e6f95860a3c72879cb861a858cdfb8138fbedec1)
13
+ - [Dev Deps] update `@arethetypeswrong/cli`, `@ljharb/tsconfig`, `@types/tape`, `es-value-fixtures`, `for-each`, `has-strict-mode`, `object-inspect` [`e43d540`](https://github.com/ljharb/call-bind-apply-helpers/commit/e43d5409f97543bfbb11f345d47d8ce4e066d8c1)
14
+
8
15
  ## [v1.0.1](https://github.com/ljharb/call-bind-apply-helpers/compare/v1.0.0...v1.0.1) - 2024-12-08
9
16
 
10
17
  ### Commits
@@ -1,46 +1,64 @@
1
1
  type RemoveFromTuple<
2
- Tuple extends unknown[],
2
+ Tuple extends readonly unknown[],
3
3
  RemoveCount extends number,
4
4
  Index extends 1[] = []
5
5
  > = Index["length"] extends RemoveCount
6
6
  ? Tuple
7
- : Tuple extends [first: unknown, ...infer Rest]
7
+ : Tuple extends [infer First, ...infer Rest]
8
8
  ? RemoveFromTuple<Rest, RemoveCount, [...Index, 1]>
9
9
  : Tuple;
10
10
 
11
11
  type ConcatTuples<
12
- Prefix extends unknown[],
13
- Suffix extends unknown[]
12
+ Prefix extends readonly unknown[],
13
+ Suffix extends readonly unknown[]
14
14
  > = [...Prefix, ...Suffix];
15
15
 
16
- type ReplaceThis<T, NewThis> = T extends (this: infer OldThis, ...args: infer A) => infer R
17
- ? (this: NewThis, ...args: A) => R
16
+ type ExtractFunctionParams<T> = T extends (this: infer TThis, ...args: infer P extends readonly unknown[]) => infer R
17
+ ? { thisArg: TThis; params: P; returnType: R }
18
18
  : never;
19
19
 
20
20
  type BindFunction<
21
+ T extends (this: any, ...args: any[]) => any,
21
22
  TThis,
22
- T extends (this: TThis, ...args: any[]) => any, // Allow specific types to propagate
23
- TBoundArgs extends unknown[],
23
+ TBoundArgs extends readonly unknown[],
24
24
  ReceiverBound extends boolean
25
- > = ReceiverBound extends true
26
- ? (...args: RemoveFromTuple<Parameters<T>, TBoundArgs["length"] & number>) => ReturnType<ReplaceThis<T, TThis>>
27
- : (...args: ConcatTuples<[TThis], RemoveFromTuple<Parameters<T>, TBoundArgs["length"] & number>>) => ReturnType<T>;
25
+ > = ExtractFunctionParams<T> extends {
26
+ thisArg: infer OrigThis;
27
+ params: infer P extends readonly unknown[];
28
+ returnType: infer R;
29
+ }
30
+ ? ReceiverBound extends true
31
+ ? (...args: RemoveFromTuple<P, Extract<TBoundArgs["length"], number>>) => R extends [OrigThis, ...infer Rest]
32
+ ? [TThis, ...Rest] // Replace `this` with `thisArg`
33
+ : R
34
+ : <U, RemainingArgs extends RemoveFromTuple<P, Extract<TBoundArgs["length"], number>>>(
35
+ thisArg: U,
36
+ ...args: RemainingArgs
37
+ ) => R extends [OrigThis, ...infer Rest]
38
+ ? [U, ...ConcatTuples<TBoundArgs, Rest>] // Preserve bound args in return type
39
+ : R
40
+ : never;
28
41
 
29
42
  declare function callBind<
30
- TThis,
31
- T extends (this: TThis, ...args: any[]) => any,
32
- TBoundArgs extends Partial<Parameters<T>>
43
+ const T extends (this: any, ...args: any[]) => any,
44
+ Extracted extends ExtractFunctionParams<T>,
45
+ const TBoundArgs extends Partial<Extracted["params"]> & readonly unknown[],
46
+ const TThis extends Extracted["thisArg"]
33
47
  >(
34
48
  args: [fn: T, thisArg: TThis, ...boundArgs: TBoundArgs]
35
- ): BindFunction<TThis, T, TBoundArgs, true>;
49
+ ): BindFunction<T, TThis, TBoundArgs, true>;
36
50
 
37
51
  declare function callBind<
38
- TThis,
39
- T extends (this: TThis, ...args: any[]) => any,
40
- TBoundArgs extends Partial<Parameters<T>>
52
+ const T extends (this: any, ...args: any[]) => any,
53
+ Extracted extends ExtractFunctionParams<T>,
54
+ const TBoundArgs extends Partial<Extracted["params"]> & readonly unknown[]
41
55
  >(
42
56
  args: [fn: T, ...boundArgs: TBoundArgs]
43
- ): BindFunction<TThis, T, TBoundArgs, false>;
57
+ ): BindFunction<T, Extracted["thisArg"], TBoundArgs, false>;
58
+
59
+ declare function callBind<const TArgs extends readonly unknown[]>(
60
+ args: [fn: Exclude<TArgs[0], Function>, ...rest: TArgs]
61
+ ): never;
44
62
 
45
- export as namespace callBind;
63
+ // export as namespace callBind;
46
64
  export = callBind;
@@ -6,7 +6,7 @@ var $TypeError = require('es-errors/type');
6
6
  var $call = require('./functionCall');
7
7
  var $actualApply = require('./actualApply');
8
8
 
9
- /** @type {import('.')} */
9
+ /** @type {(args: [Function, thisArg?: unknown, ...args: unknown[]]) => Function} TODO FIXME, find a way to use import('.') */
10
10
  module.exports = function callBindBasic(args) {
11
11
  if (args.length < 1 || typeof args[0] !== 'function') {
12
12
  throw new $TypeError('a function is required');
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "call-bind-apply-helpers",
3
- "version": "1.0.1",
3
+ "version": "1.0.2",
4
4
  "description": "Helper functions around Function call/apply/bind, for use in `call-bind`",
5
5
  "main": "index.js",
6
6
  "exports": {
@@ -41,24 +41,24 @@
41
41
  "function-bind": "^1.1.2"
42
42
  },
43
43
  "devDependencies": {
44
- "@arethetypeswrong/cli": "^0.17.1",
44
+ "@arethetypeswrong/cli": "^0.17.3",
45
45
  "@ljharb/eslint-config": "^21.1.1",
46
- "@ljharb/tsconfig": "^0.2.2",
46
+ "@ljharb/tsconfig": "^0.2.3",
47
47
  "@types/for-each": "^0.3.3",
48
48
  "@types/function-bind": "^1.1.10",
49
49
  "@types/object-inspect": "^1.13.0",
50
- "@types/tape": "^5.6.5",
50
+ "@types/tape": "^5.8.1",
51
51
  "auto-changelog": "^2.5.0",
52
52
  "encoding": "^0.1.13",
53
- "es-value-fixtures": "^1.5.0",
53
+ "es-value-fixtures": "^1.7.1",
54
54
  "eslint": "=8.8.0",
55
55
  "evalmd": "^0.0.19",
56
- "for-each": "^0.3.3",
57
- "has-strict-mode": "^1.0.1",
56
+ "for-each": "^0.3.5",
57
+ "has-strict-mode": "^1.1.0",
58
58
  "in-publish": "^2.0.1",
59
59
  "npmignore": "^0.3.1",
60
60
  "nyc": "^10.3.2",
61
- "object-inspect": "^1.13.3",
61
+ "object-inspect": "^1.13.4",
62
62
  "safe-publish-latest": "^2.0.0",
63
63
  "tape": "^5.9.0",
64
64
  "typescript": "next"
@@ -19,7 +19,7 @@ test('callBindBasic', function (t) {
19
19
  });
20
20
 
21
21
  var sentinel = { sentinel: true };
22
- /** @type {<T>(this: T, a: number, b: number) => [T | undefined, number, number]} */
22
+ /** @type {<T, A extends number, B extends number>(this: T, a: A, b: B) => [T | undefined, A, B]} */
23
23
  var func = function (a, b) {
24
24
  // eslint-disable-next-line no-invalid-this
25
25
  return [!hasStrictMode && this === global ? undefined : this, a, b];
@@ -28,10 +28,10 @@ test('callBindBasic', function (t) {
28
28
 
29
29
  /** type {(thisArg: unknown, a: number, b: number) => [unknown, number, number]} */
30
30
  var bound = callBind([func]);
31
- /** type {((a: number, b: number) => [sentinel, typeof a, typeof b])} */
31
+ /** type {((a: number, b: number) => [typeof sentinel, typeof a, typeof b])} */
32
32
  var boundR = callBind([func, sentinel]);
33
- /** type {((b: number) => [sentinel, number, typeof b])} */
34
- var boundArg = callBind([func, sentinel, 1]);
33
+ /** type {((b: number) => [typeof sentinel, number, typeof b])} */
34
+ var boundArg = callBind([func, sentinel, /** @type {const} */ (1)]);
35
35
 
36
36
  // @ts-expect-error
37
37
  t.deepEqual(bound(), [undefined, undefined, undefined], 'bound func with no args');
@@ -6,10 +6,12 @@
6
6
  "rules": {
7
7
  "eqeqeq": [2, "allow-null"],
8
8
  "func-name-matching": 0,
9
+ "func-style": 0,
9
10
  "indent": [2, 4],
10
11
  "max-nested-callbacks": [2, 3],
11
12
  "max-params": [2, 3],
12
13
  "max-statements": [2, 14],
14
+ "no-extra-parens": 0,
13
15
  "no-invalid-this": 1,
14
16
  "no-restricted-syntax": [2, "BreakStatement", "ContinueStatement", "DebuggerStatement", "LabeledStatement", "WithStatement"],
15
17
  },
@@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [v0.3.5](https://github.com/ljharb/for-each/compare/v0.3.4...v0.3.5) - 2025-02-10
9
+
10
+ ### Commits
11
+
12
+ - [New] add types [`6483c1e`](https://github.com/ljharb/for-each/commit/6483c1e9b6177e5ca9ba506188300c5a25de26c2)
13
+
8
14
  ## [v0.3.4](https://github.com/ljharb/for-each/compare/v0.3.3...v0.3.4) - 2025-01-24
9
15
 
10
16
  ### Commits
@@ -0,0 +1,35 @@
1
+ declare function forEach<O extends readonly unknown[], This = undefined>(
2
+ arr: O,
3
+ callback: (this: This | void, value: O[number], index: number, array: O) => void,
4
+ thisArg?: This,
5
+ ): void;
6
+
7
+ declare function forEach<O extends ArrayLike<unknown>, This = undefined>(
8
+ arr: O,
9
+ callback: (this: This | void, value: O[number], index: number, array: O) => void,
10
+ thisArg?: This,
11
+ ): void;
12
+
13
+ declare function forEach<O extends object, This = undefined>(
14
+ obj: O,
15
+ callback: (this: This | void, value: O[keyof O], key: keyof O, obj: O) => void,
16
+ thisArg?: This,
17
+ ): void;
18
+
19
+ declare function forEach<O extends string, This = undefined>(
20
+ str: O,
21
+ callback: (this: This | void, value: O[number], index: number, str: O) => void,
22
+ thisArg: This,
23
+ ): void;
24
+
25
+ export = forEach;
26
+
27
+ declare function forEachInternal<O, C extends (this: This | void, value: unknown, index: PropertyKey, obj: O) => void, This = undefined>(
28
+ value: O,
29
+ callback: C,
30
+ thisArg?: This,
31
+ ): void;
32
+
33
+ declare namespace forEach {
34
+ export type _internal = typeof forEachInternal;
35
+ }
@@ -5,6 +5,7 @@ var isCallable = require('is-callable');
5
5
  var toStr = Object.prototype.toString;
6
6
  var hasOwnProperty = Object.prototype.hasOwnProperty;
7
7
 
8
+ /** @type {<This, A extends readonly unknown[]>(arr: A, iterator: (this: This | void, value: A[number], index: number, arr: A) => void, receiver: This | undefined) => void} */
8
9
  var forEachArray = function forEachArray(array, iterator, receiver) {
9
10
  for (var i = 0, len = array.length; i < len; i++) {
10
11
  if (hasOwnProperty.call(array, i)) {
@@ -17,6 +18,7 @@ var forEachArray = function forEachArray(array, iterator, receiver) {
17
18
  }
18
19
  };
19
20
 
21
+ /** @type {<This, S extends string>(string: S, iterator: (this: This | void, value: S[number], index: number, string: S) => void, receiver: This | undefined) => void} */
20
22
  var forEachString = function forEachString(string, iterator, receiver) {
21
23
  for (var i = 0, len = string.length; i < len; i++) {
22
24
  // no such thing as a sparse string.
@@ -28,6 +30,7 @@ var forEachString = function forEachString(string, iterator, receiver) {
28
30
  }
29
31
  };
30
32
 
33
+ /** @type {<This, O>(obj: O, iterator: (this: This | void, value: O[keyof O], index: keyof O, obj: O) => void, receiver: This | undefined) => void} */
31
34
  var forEachObject = function forEachObject(object, iterator, receiver) {
32
35
  for (var k in object) {
33
36
  if (hasOwnProperty.call(object, k)) {
@@ -40,7 +43,13 @@ var forEachObject = function forEachObject(object, iterator, receiver) {
40
43
  }
41
44
  };
42
45
 
43
- var forEach = function forEach(list, iterator, thisArg) {
46
+ /** @type {(x: unknown) => x is readonly unknown[]} */
47
+ function isArray(x) {
48
+ return toStr.call(x) === '[object Array]';
49
+ }
50
+
51
+ /** @type {import('.')._internal} */
52
+ module.exports = function forEach(list, iterator, thisArg) {
44
53
  if (!isCallable(iterator)) {
45
54
  throw new TypeError('iterator must be a function');
46
55
  }
@@ -50,7 +59,7 @@ var forEach = function forEach(list, iterator, thisArg) {
50
59
  receiver = thisArg;
51
60
  }
52
61
 
53
- if (toStr.call(list) === '[object Array]') {
62
+ if (isArray(list)) {
54
63
  forEachArray(list, iterator, receiver);
55
64
  } else if (typeof list === 'string') {
56
65
  forEachString(list, iterator, receiver);
@@ -58,5 +67,3 @@ var forEach = function forEach(list, iterator, thisArg) {
58
67
  forEachObject(list, iterator, receiver);
59
68
  }
60
69
  };
61
-
62
- module.exports = forEach;
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "for-each",
3
- "version": "0.3.4",
3
+ "version": "0.3.5",
4
4
  "description": "A better forEach",
5
5
  "keywords": [],
6
6
  "author": "Raynos <raynos2@gmail.com>",
@@ -34,6 +34,7 @@
34
34
  "tests-only": "nyc tape 'test/*.js'",
35
35
  "posttest": "npx npm@\">= 10.2\" audit --production",
36
36
  "lint": "eslint --ext=js,mjs .",
37
+ "postlint": "tsc && attw -P",
37
38
  "version": "auto-changelog && git add CHANGELOG.md",
38
39
  "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
39
40
  },
@@ -41,12 +42,17 @@
41
42
  "is-callable": "^1.2.7"
42
43
  },
43
44
  "devDependencies": {
45
+ "@arethetypeswrong/cli": "^0.17.3",
44
46
  "@ljharb/eslint-config": "^21.1.1",
47
+ "@ljharb/tsconfig": "^0.2.3",
48
+ "@types/is-callable": "^1.1.2",
49
+ "@types/tape": "^5.8.1",
45
50
  "auto-changelog": "^2.5.0",
46
51
  "eslint": "=8.8.0",
47
52
  "npmignore": "^0.3.1",
48
53
  "nyc": "^10.3.2",
49
- "tape": "^5.9.0"
54
+ "tape": "^5.9.0",
55
+ "typescript": "next"
50
56
  },
51
57
  "testling": {
52
58
  "files": "test/test.js"
@@ -6,6 +6,7 @@ var forEach = require('../');
6
6
  test('forEach calls each iterator', function (t) {
7
7
  var count = 0;
8
8
  t.plan(4);
9
+
9
10
  forEach({ a: 1, b: 2 }, function (value, key) {
10
11
  if (count === 0) {
11
12
  t.equal(value, 1);
@@ -29,26 +30,40 @@ test('forEach calls iterator with correct this value', function (t) {
29
30
  });
30
31
 
31
32
  test('second argument: iterator', function (t) {
33
+ /** @type {unknown[]} */
32
34
  var arr = [];
35
+
36
+ // @ts-expect-error
33
37
  t['throws'](function () { forEach(arr); }, TypeError, 'undefined is not a function');
38
+ // @ts-expect-error
34
39
  t['throws'](function () { forEach(arr, null); }, TypeError, 'null is not a function');
40
+ // @ts-expect-error
35
41
  t['throws'](function () { forEach(arr, ''); }, TypeError, 'string is not a function');
42
+ // @ts-expect-error
36
43
  t['throws'](function () { forEach(arr, /a/); }, TypeError, 'regex is not a function');
44
+ // @ts-expect-error
37
45
  t['throws'](function () { forEach(arr, true); }, TypeError, 'true is not a function');
46
+ // @ts-expect-error
38
47
  t['throws'](function () { forEach(arr, false); }, TypeError, 'false is not a function');
48
+ // @ts-expect-error
39
49
  t['throws'](function () { forEach(arr, NaN); }, TypeError, 'NaN is not a function');
50
+ // @ts-expect-error
40
51
  t['throws'](function () { forEach(arr, 42); }, TypeError, '42 is not a function');
52
+
41
53
  t.doesNotThrow(function () { forEach(arr, function () {}); }, 'function is a function');
54
+ // @ts-expect-error TODO fixme
42
55
  t.doesNotThrow(function () { forEach(arr, setTimeout); }, 'setTimeout is a function');
56
+
43
57
  /* eslint-env browser */
44
58
  if (typeof window !== 'undefined') {
45
59
  t.doesNotThrow(function () { forEach(arr, window.alert); }, 'alert is a function');
46
60
  }
61
+
47
62
  t.end();
48
63
  });
49
64
 
50
65
  test('array', function (t) {
51
- var arr = [1, 2, 3];
66
+ var arr = /** @type {const} */ ([1, 2, 3]);
52
67
 
53
68
  t.test('iterates over every item', function (st) {
54
69
  var index = 0;
@@ -60,36 +75,44 @@ test('array', function (t) {
60
75
  t.test('first iterator argument', function (st) {
61
76
  var index = 0;
62
77
  st.plan(arr.length);
78
+
63
79
  forEach(arr, function (item) {
64
80
  st.equal(arr[index], item, 'item ' + index + ' is passed as first argument');
65
81
  index += 1;
66
82
  });
83
+
67
84
  st.end();
68
85
  });
69
86
 
70
87
  t.test('second iterator argument', function (st) {
71
88
  var counter = 0;
72
89
  st.plan(arr.length);
73
- forEach(arr, function (item, index) {
90
+
91
+ forEach(arr, function (_item, index) {
74
92
  st.equal(counter, index, 'index ' + index + ' is passed as second argument');
75
93
  counter += 1;
76
94
  });
95
+
77
96
  st.end();
78
97
  });
79
98
 
80
99
  t.test('third iterator argument', function (st) {
81
100
  st.plan(arr.length);
82
- forEach(arr, function (item, index, array) {
101
+
102
+ forEach(arr, function (_item, _index, array) {
83
103
  st.deepEqual(arr, array, 'array is passed as third argument');
84
104
  });
105
+
85
106
  st.end();
86
107
  });
87
108
 
88
109
  t.test('context argument', function (st) {
89
110
  var context = {};
111
+
90
112
  forEach([], function () {
91
113
  st.equal(this, context, '"this" is the passed context');
92
114
  }, context);
115
+
93
116
  st.end();
94
117
  });
95
118
 
@@ -102,62 +125,77 @@ test('object', function (t) {
102
125
  b: 2,
103
126
  c: 3
104
127
  };
105
- var keys = ['a', 'b', 'c'];
128
+ var keys = /** @type {const} */ (['a', 'b', 'c']);
106
129
 
107
- var F = function F() {
130
+ /** @constructor */
131
+ function F() {
108
132
  this.a = 1;
109
133
  this.b = 2;
110
- };
134
+ }
111
135
  F.prototype.c = 3;
112
- var fKeys = ['a', 'b'];
136
+ var fKeys = /** @type {const} */ (['a', 'b']);
113
137
 
114
138
  t.test('iterates over every object literal key', function (st) {
115
139
  var counter = 0;
140
+
116
141
  forEach(obj, function () { counter += 1; });
142
+
117
143
  st.equal(counter, keys.length, 'iterated ' + counter + ' times');
144
+
118
145
  st.end();
119
146
  });
120
147
 
121
148
  t.test('iterates only over own keys', function (st) {
122
149
  var counter = 0;
150
+
123
151
  forEach(new F(), function () { counter += 1; });
152
+
124
153
  st.equal(counter, fKeys.length, 'iterated ' + fKeys.length + ' times');
154
+
125
155
  st.end();
126
156
  });
127
157
 
128
158
  t.test('first iterator argument', function (st) {
129
159
  var index = 0;
130
160
  st.plan(keys.length);
161
+
131
162
  forEach(obj, function (item) {
132
163
  st.equal(obj[keys[index]], item, 'item at key ' + keys[index] + ' is passed as first argument');
133
164
  index += 1;
134
165
  });
166
+
135
167
  st.end();
136
168
  });
137
169
 
138
170
  t.test('second iterator argument', function (st) {
139
171
  var counter = 0;
140
172
  st.plan(keys.length);
141
- forEach(obj, function (item, key) {
173
+
174
+ forEach(obj, function (_item, key) {
142
175
  st.equal(keys[counter], key, 'key ' + key + ' is passed as second argument');
143
176
  counter += 1;
144
177
  });
178
+
145
179
  st.end();
146
180
  });
147
181
 
148
182
  t.test('third iterator argument', function (st) {
149
183
  st.plan(keys.length);
150
- forEach(obj, function (item, key, object) {
184
+
185
+ forEach(obj, function (_item, _key, object) {
151
186
  st.deepEqual(obj, object, 'object is passed as third argument');
152
187
  });
188
+
153
189
  st.end();
154
190
  });
155
191
 
156
192
  t.test('context argument', function (st) {
157
193
  var context = {};
194
+
158
195
  forEach({}, function () {
159
196
  st.equal(this, context, '"this" is the passed context');
160
197
  }, context);
198
+
161
199
  st.end();
162
200
  });
163
201
 
@@ -165,17 +203,22 @@ test('object', function (t) {
165
203
  });
166
204
 
167
205
  test('string', function (t) {
168
- var str = 'str';
206
+ var str = /** @type {const} */ ('str');
207
+
169
208
  t.test('second iterator argument', function (st) {
170
209
  var counter = 0;
171
210
  st.plan((str.length * 2) + 1);
211
+
172
212
  forEach(str, function (item, index) {
173
213
  st.equal(counter, index, 'index ' + index + ' is passed as second argument');
174
214
  st.equal(str.charAt(index), item);
175
215
  counter += 1;
176
216
  });
217
+
177
218
  st.equal(counter, str.length, 'iterates ' + str.length + ' times');
219
+
178
220
  st.end();
179
221
  });
222
+
180
223
  t.end();
181
224
  });
@@ -0,0 +1,8 @@
1
+ {
2
+ "extends": "@ljharb/tsconfig",
3
+ "compilerOptions": {
4
+ },
5
+ "exclude": [
6
+ "coverage",
7
+ ],
8
+ }
package/package.json CHANGED
@@ -57,7 +57,7 @@
57
57
  "jsii-docgen": "^10.5.0",
58
58
  "jsii-pacmak": "^1.106.0",
59
59
  "jsii-rosetta": "5.4.x",
60
- "projen": "^0.91.8",
60
+ "projen": "^0.91.9",
61
61
  "source-map-support": "^0.5.21",
62
62
  "ts-jest": "^27",
63
63
  "typescript": "^4.9.5"
@@ -91,7 +91,7 @@
91
91
  "publishConfig": {
92
92
  "access": "public"
93
93
  },
94
- "version": "2.0.611",
94
+ "version": "2.0.613",
95
95
  "jest": {
96
96
  "coverageProvider": "v8",
97
97
  "testMatch": [