deployable-awscdk-app-ts 0.1.383 → 0.1.385

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
@@ -7,11 +7,11 @@
7
7
  ]
8
8
  },
9
9
  "bundled": {
10
- "semver": "^7.6.0"
10
+ "semver": "^7.6.1"
11
11
  },
12
12
  "dependencies": {
13
13
  "constructs": "^10.3.0",
14
- "projen": "^0.81.7"
14
+ "projen": "^0.81.8"
15
15
  },
16
16
  "dependencyClosure": {
17
17
  "constructs": {
@@ -712,6 +712,6 @@
712
712
  "symbolId": "src/types:EnvironmentOptions"
713
713
  }
714
714
  },
715
- "version": "0.1.383",
716
- "fingerprint": "ZEVM78ITvGt8HYo0CbZR9J0VFvREWVE0TsZLSj3COyY="
715
+ "version": "0.1.385",
716
+ "fingerprint": "WAYOft4+LB7eFEbIMPrDF+Lo9eX9qluD66CvblQtizA="
717
717
  }
package/lib/index.js CHANGED
@@ -194,5 +194,5 @@ class DeployableAwsCdkTypeScriptApp extends projen_1.awscdk.AwsCdkTypeScriptApp
194
194
  }
195
195
  exports.DeployableAwsCdkTypeScriptApp = DeployableAwsCdkTypeScriptApp;
196
196
  _a = JSII_RTTI_SYMBOL_1;
197
- DeployableAwsCdkTypeScriptApp[_a] = { fqn: "deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptApp", version: "0.1.383" };
197
+ DeployableAwsCdkTypeScriptApp[_a] = { fqn: "deployable-awscdk-app-ts.DeployableAwsCdkTypeScriptApp", version: "0.1.385" };
198
198
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {awscdk, Task, TextFile} from 'projen'\nimport {Job, JobPermission} from 'projen/lib/github/workflows-model'\nimport {CodeArtifactAuthProvider, CodeArtifactOptions, NodeProject} from 'projen/lib/javascript'\nimport * as steps from './steps'\nimport {DeployableAwsCdkTypeScriptAppOptions, DeployOptions, EnvironmentOptions} from './types'\nimport {getMajorNodeVersion} from './utils'\n\nexport * from './types'\nexport * as utils from './utils'\n\nexport class DeployableAwsCdkTypeScriptApp extends awscdk.AwsCdkTypeScriptApp {\n\n  /**\n   * Task to deploy your app.\n   */\n  public readonly deployWorkflowTask: Task\n\n  private readonly deployable: boolean\n  private readonly generateNvmrc: boolean\n  private readonly checkActiveDeployment: boolean\n  private readonly workflowNodeVersion?: string\n  protected deployOptions: DeployOptions\n  private readonly codeArtifactOptions?: CodeArtifactOptions\n\n  constructor(options: DeployableAwsCdkTypeScriptAppOptions) {\n    const deployable = options.release ?? true\n    super({\n      ...options,\n      release: deployable,\n    })\n    this.deployable = deployable\n    this.generateNvmrc = options.generateNvmrc ?? true\n    this.checkActiveDeployment = options.checkActiveDeployment ?? false\n    this.workflowNodeVersion = options.workflowNodeVersion\n    this.deployOptions = options.deployOptions ?? {environments: []}\n    this.codeArtifactOptions = options.codeArtifactOptions\n    this.addDevDeps('deployable-awscdk-app-ts')\n\n    if (!deployable)\n      this.logger.warn('The project is explicitly set to not release, make sure this is desired setting')\n\n    if (this.generateNvmrc && !this.workflowNodeVersion)\n      this.workflowNodeVersion = '14.18.1'\n\n    if (this.deployOptions.npmConfigEnvironment && this.majorNodeVersion >= 18)\n      throw new Error(`npmConfigEnvironment is not supported for node versions above version 18. Current version is ${this.nodeVersion}`)\n\n    const deployArgument = this.deployOptions.stackPattern ? ` ${this.deployOptions.stackPattern}`: ''\n    const deployCommand = `cdk deploy${deployArgument} ${this.getMethodArgument()} --require-approval never`\n    const requiredEnv = this.deployOptions.npmConfigEnvironment ? [`npm_config_${this.deployOptions.npmConfigEnvironment}`] : undefined\n    this.deployWorkflowTask = this.addTask('deploy:workflow', {\n      requiredEnv,\n      exec: deployCommand,\n    })\n    this.addTask('deploy:hotswap', {\n      requiredEnv,\n      exec: `${deployCommand} --hotswap`,\n    })\n  }\n\n  /**\n   * return the major node version set for the project\n   * @default 16\n   */\n  get majorNodeVersion(): number {\n    return getMajorNodeVersion(this.nodeVersion)\n  }\n\n  private getMethodArgument() {\n    return `--method ${this.deployOptions.method ?? 'change-set'}`\n  }\n\n  synth() {\n    if (this.deployable)\n      this.addDeployJobs()\n\n    if (this.generateNvmrc)\n      new TextFile(this, '.nvmrc', {\n        lines: [this.workflowNodeVersion ?? ''],\n      })\n\n    super.synth()\n  }\n\n  /**\n   * Add new environments to the application\n   * @param items list of environment options\n   */\n  addEnvironments(...items: EnvironmentOptions[]) {\n    this.deployOptions.environments.push(...items)\n  }\n\n  private updateEnvironments(newEnvironments: EnvironmentOptions[]) {\n    this.deployOptions = {\n      ...this.deployOptions,\n      environments: newEnvironments,\n    }\n  }\n\n  /**\n   * Updates the postDeployWorkflowScript for environments\n   * @param script the script to be added, for example \"post:deploy\"\n   * @param environmentNameFilter the name of environments to add the scripts to, if not provided or empty will update all\n   */\n  updatePostDeployWorkflowScriptToEnvironments(script: string, environmentNameFilter?: string[]) {\n    const newEnvironments = this.deployOptions.environments.map(environment => {\n      if (environmentNameFilter && environmentNameFilter.length > 0 && !environmentNameFilter.includes(environment.name))\n        return environment\n\n      return {\n        ...environment,\n        postDeployWorkflowScript: script,\n      }\n    })\n    this.updateEnvironments(newEnvironments)\n  }\n\n  /**\n   * Updates the preDeployWorkflowScript for environments\n   * @param script the script to be added, for example \"pre:deploy\"\n   * @param environmentNameFilter the name of environments to add the scripts to, if not provided or empty will update all\n   */\n  updatePreDeployWorkflowScriptToEnvironments(script: string, environmentNameFilter?: string[]) {\n    const newEnvironments = this.deployOptions.environments.map(environment => {\n      if (environmentNameFilter && environmentNameFilter.length > 0 && !environmentNameFilter.includes(environment.name))\n        return environment\n\n      return {\n        ...environment,\n        preDeployWorkflowScript: script,\n      }\n    })\n    this.updateEnvironments(newEnvironments)\n  }\n\n  private addDeployJobs() {\n\n    if (this.deployOptions.environments.length === 0)\n      this.logger.warn('The project does not have any environment set, make sure this is desired setting')\n\n    const include = this.deployOptions.environments.map(environmentOptions => {\n      const {awsCredentials} = environmentOptions\n\n      const assumeRole = awsCredentials.roleToAssume ? 'true' : 'false'\n\n      const assumeRoleSettings = awsCredentials.roleToAssume ? {\n        roleToAssume: awsCredentials.roleToAssume,\n        assumeRoleDurationSeconds: awsCredentials.assumeRoleDurationSeconds || 900,\n      }: undefined\n\n      const accessKeyIdSecretName = awsCredentials.accessKeyIdSecretName ?? 'AWS_ACCESS_KEY_ID'\n      const secretAccessKeySecretName = awsCredentials.secretAccessKeySecretName ?? 'AWS_SECRET_ACCESS_KEY'\n\n      const hasPostDeployTask = environmentOptions.postDeployWorkflowScript ? 'true' : 'false'\n      const hasPreDeployTask = environmentOptions.preDeployWorkflowScript ? 'true' : 'false'\n\n      return {\n        environment: environmentOptions.name,\n        accessKeyIdSecretName,\n        secretAccessKeySecretName,\n        region: awsCredentials.region,\n        assumeRole,\n        hasPostDeployTask,\n        postDeploymentScript: environmentOptions.postDeployWorkflowScript || '',\n        hasPreDeployTask,\n        preDeploymentScript: environmentOptions.preDeployWorkflowScript || '',\n        ...assumeRoleSettings,\n      }\n    })\n\n    const deployJobEnv = this.deployOptions.environmentVariableName ? {\n      [this.deployOptions.environmentVariableName]: '${{ matrix.environment }}',\n    } : undefined\n\n    const jobDefinition: Job = {\n      runsOn: ['ubuntu-latest'],\n      concurrency: '${{ matrix.environment }}-deploy',\n      needs: [\n        'release_github',\n      ],\n      permissions: {\n        contents: JobPermission.READ,\n        deployments: JobPermission.READ,\n        idToken: this.codeArtifactOptions?.authProvider === CodeArtifactAuthProvider.GITHUB_OIDC ? JobPermission.WRITE : undefined,\n      },\n      strategy: {\n        maxParallel: 1,\n        matrix: {\n          domain: {\n            environment: include.map(e => e.environment),\n          },\n          include,\n        },\n      },\n      environment: {\n        name: '${{ matrix.environment }}',\n      },\n      env: deployJobEnv,\n      steps: [],\n    }\n\n    jobDefinition.steps.push(steps.checkoutStep())\n\n    const {taskToRunPreInstall} = this.deployOptions\n    if (taskToRunPreInstall)\n      jobDefinition.steps.push(steps.preInstallDependenciesStep(taskToRunPreInstall, this.checkActiveDeployment))\n\n    jobDefinition.steps.push(...(this.package.project as NodeProject).renderWorkflowSetup())\n\n    if (this.checkActiveDeployment)\n      jobDefinition.steps.push(steps.checkActiveDeploymentStep())\n\n    jobDefinition.steps.push(...steps.setAwsCredentialsSteps(this.checkActiveDeployment, this.codeArtifactOptions?.authProvider))\n\n    if (this.deployOptions.npmConfigEnvironment)\n      jobDefinition.steps.push(steps.setNpmConfig(this.deployOptions.npmConfigEnvironment, '${{ matrix.environment }}', this.checkActiveDeployment))\n\n    jobDefinition.steps.push(steps.preDeploymentStep(this.checkActiveDeployment, this.package.packageManager))\n    jobDefinition.steps.push(steps.deploymentStep(this.checkActiveDeployment, this.package.packageManager))\n    jobDefinition.steps.push(steps.postDeploymentStep(this.checkActiveDeployment, this.package.packageManager))\n\n    this.release?.addJobs({deploy: jobDefinition})\n\n  }\n}"]}
@@ -25,7 +25,7 @@ semver.valid(semver.coerce('v2')) // '2.0.0'
25
25
  semver.valid(semver.coerce('42.6.7.9.3-alpha')) // '42.6.7'
26
26
  ```
27
27
 
28
- You can also just load the module for the function that you care about, if
28
+ You can also just load the module for the function that you care about if
29
29
  you'd like to minimize your footprint.
30
30
 
31
31
  ```js
@@ -78,8 +78,8 @@ const semverOutside = require('semver/ranges/outside')
78
78
  const semverGtr = require('semver/ranges/gtr')
79
79
  const semverLtr = require('semver/ranges/ltr')
80
80
  const semverIntersects = require('semver/ranges/intersects')
81
- const simplifyRange = require('semver/ranges/simplify')
82
- const rangeSubset = require('semver/ranges/subset')
81
+ const semverSimplifyRange = require('semver/ranges/simplify')
82
+ const semverRangeSubset = require('semver/ranges/subset')
83
83
  ```
84
84
 
85
85
  As a command-line utility:
@@ -144,7 +144,7 @@ A leading `"="` or `"v"` character is stripped off and ignored.
144
144
 
145
145
  ## Ranges
146
146
 
147
- A `version range` is a set of `comparators` which specify versions
147
+ A `version range` is a set of `comparators` that specify versions
148
148
  that satisfy the range.
149
149
 
150
150
  A `comparator` is composed of an `operator` and a `version`. The set
@@ -155,7 +155,7 @@ of primitive `operators` is:
155
155
  * `>` Greater than
156
156
  * `>=` Greater than or equal to
157
157
  * `=` Equal. If no operator is specified, then equality is assumed,
158
- so this operator is optional, but MAY be included.
158
+ so this operator is optional but MAY be included.
159
159
 
160
160
  For example, the comparator `>=1.2.7` would match the versions
161
161
  `1.2.7`, `1.2.8`, `2.5.3`, and `1.3.9`, but not the versions `1.2.6`
@@ -189,26 +189,26 @@ For example, the range `>1.2.3-alpha.3` would be allowed to match the
189
189
  version `1.2.3-alpha.7`, but it would *not* be satisfied by
190
190
  `3.4.5-alpha.9`, even though `3.4.5-alpha.9` is technically "greater
191
191
  than" `1.2.3-alpha.3` according to the SemVer sort rules. The version
192
- range only accepts prerelease tags on the `1.2.3` version. The
193
- version `3.4.5` *would* satisfy the range, because it does not have a
192
+ range only accepts prerelease tags on the `1.2.3` version.
193
+ Version `3.4.5` *would* satisfy the range because it does not have a
194
194
  prerelease flag, and `3.4.5` is greater than `1.2.3-alpha.7`.
195
195
 
196
- The purpose for this behavior is twofold. First, prerelease versions
196
+ The purpose of this behavior is twofold. First, prerelease versions
197
197
  frequently are updated very quickly, and contain many breaking changes
198
198
  that are (by the author's design) not yet fit for public consumption.
199
- Therefore, by default, they are excluded from range matching
199
+ Therefore, by default, they are excluded from range-matching
200
200
  semantics.
201
201
 
202
202
  Second, a user who has opted into using a prerelease version has
203
- clearly indicated the intent to use *that specific* set of
203
+ indicated the intent to use *that specific* set of
204
204
  alpha/beta/rc versions. By including a prerelease tag in the range,
205
205
  the user is indicating that they are aware of the risk. However, it
206
206
  is still not appropriate to assume that they have opted into taking a
207
207
  similar risk on the *next* set of prerelease versions.
208
208
 
209
209
  Note that this behavior can be suppressed (treating all prerelease
210
- versions as if they were normal versions, for the purpose of range
211
- matching) by setting the `includePrerelease` flag on the options
210
+ versions as if they were normal versions, for range-matching)
211
+ by setting the `includePrerelease` flag on the options
212
212
  object to any
213
213
  [functions](https://github.com/npm/node-semver#functions) that do
214
214
  range matching.
@@ -401,12 +401,12 @@ All methods and classes take a final `options` object argument. All
401
401
  options in this object are `false` by default. The options supported
402
402
  are:
403
403
 
404
- - `loose` Be more forgiving about not-quite-valid semver strings.
404
+ - `loose`: Be more forgiving about not-quite-valid semver strings.
405
405
  (Any resulting output will always be 100% strict compliant, of
406
406
  course.) For backwards compatibility reasons, if the `options`
407
407
  argument is a boolean value instead of an object, it is interpreted
408
408
  to be the `loose` param.
409
- - `includePrerelease` Set to suppress the [default
409
+ - `includePrerelease`: Set to suppress the [default
410
410
  behavior](https://github.com/npm/node-semver#prerelease-tags) of
411
411
  excluding prerelease tagged versions from ranges unless they are
412
412
  explicitly opted into.
@@ -415,16 +415,20 @@ Strict-mode Comparators and Ranges will be strict about the SemVer
415
415
  strings that they parse.
416
416
 
417
417
  * `valid(v)`: Return the parsed version, or null if it's not valid.
418
- * `inc(v, release)`: Return the version incremented by the release
419
- type (`major`, `premajor`, `minor`, `preminor`, `patch`,
418
+ * `inc(v, release, options, identifier, identifierBase)`:
419
+ Return the version incremented by the release
420
+ type (`major`, `premajor`, `minor`, `preminor`, `patch`,
420
421
  `prepatch`, or `prerelease`), or null if it's not valid
421
422
  * `premajor` in one call will bump the version up to the next major
422
423
  version and down to a prerelease of that major version.
423
424
  `preminor`, and `prepatch` work the same way.
424
- * If called from a non-prerelease version, the `prerelease` will work the
425
- same as `prepatch`. It increments the patch version, then makes a
425
+ * If called from a non-prerelease version, `prerelease` will work the
426
+ same as `prepatch`. It increments the patch version and then makes a
426
427
  prerelease. If the input version is already a prerelease it simply
427
428
  increments it.
429
+ * `identifier` can be used to prefix `premajor`, `preminor`,
430
+ `prepatch`, or `prerelease` version increments. `identifierBase`
431
+ is the base to be used for the `prerelease` identifier.
428
432
  * `prerelease(v)`: Returns an array of prerelease components, or null
429
433
  if none exist. Example: `prerelease('1.2.3-alpha.1') -> ['alpha', 1]`
430
434
  * `major(v)`: Return the major version number.
@@ -442,7 +446,7 @@ strings that they parse.
442
446
  * `lt(v1, v2)`: `v1 < v2`
443
447
  * `lte(v1, v2)`: `v1 <= v2`
444
448
  * `eq(v1, v2)`: `v1 == v2` This is true if they're logically equivalent,
445
- even if they're not the exact same string. You already know how to
449
+ even if they're not the same string. You already know how to
446
450
  compare strings.
447
451
  * `neq(v1, v2)`: `v1 != v2` The opposite of `eq`.
448
452
  * `cmp(v1, comparator, v2)`: Pass in a comparison string, and it'll call
@@ -451,15 +455,22 @@ strings that they parse.
451
455
  invalid comparison string is provided.
452
456
  * `compare(v1, v2)`: Return `0` if `v1 == v2`, or `1` if `v1` is greater, or `-1` if
453
457
  `v2` is greater. Sorts in ascending order if passed to `Array.sort()`.
454
- * `rcompare(v1, v2)`: The reverse of compare. Sorts an array of versions
458
+ * `rcompare(v1, v2)`: The reverse of `compare`. Sorts an array of versions
455
459
  in descending order when passed to `Array.sort()`.
456
460
  * `compareBuild(v1, v2)`: The same as `compare` but considers `build` when two versions
457
461
  are equal. Sorts in ascending order if passed to `Array.sort()`.
458
- `v2` is greater. Sorts in ascending order if passed to `Array.sort()`.
459
- * `diff(v1, v2)`: Returns difference between two versions by the release type
462
+ * `compareLoose(v1, v2)`: Short for ``compare(v1, v2, { loose: true })`.
463
+ * `diff(v1, v2)`: Returns the difference between two versions by the release type
460
464
  (`major`, `premajor`, `minor`, `preminor`, `patch`, `prepatch`, or `prerelease`),
461
465
  or null if the versions are the same.
462
466
 
467
+ ### Sorting
468
+
469
+ * `sort(versions)`: Returns a sorted array of versions based on the `compareBuild`
470
+ function.
471
+ * `rsort(versions)`: The reverse of `sort`. Returns an array of versions based on
472
+ the `compareBuild` function in descending order.
473
+
463
474
  ### Comparators
464
475
 
465
476
  * `intersects(comparator)`: Return true if the comparators intersect
@@ -473,19 +484,19 @@ strings that they parse.
473
484
  that satisfies the range, or `null` if none of them do.
474
485
  * `minSatisfying(versions, range)`: Return the lowest version in the list
475
486
  that satisfies the range, or `null` if none of them do.
476
- * `minVersion(range)`: Return the lowest version that can possibly match
487
+ * `minVersion(range)`: Return the lowest version that can match
477
488
  the given range.
478
- * `gtr(version, range)`: Return `true` if version is greater than all the
489
+ * `gtr(version, range)`: Return `true` if the version is greater than all the
479
490
  versions possible in the range.
480
- * `ltr(version, range)`: Return `true` if version is less than all the
491
+ * `ltr(version, range)`: Return `true` if the version is less than all the
481
492
  versions possible in the range.
482
493
  * `outside(version, range, hilo)`: Return true if the version is outside
483
494
  the bounds of the range in either the high or low direction. The
484
495
  `hilo` argument must be either the string `'>'` or `'<'`. (This is
485
496
  the function called by `gtr` and `ltr`.)
486
- * `intersects(range)`: Return true if any of the ranges comparators intersect
497
+ * `intersects(range)`: Return true if any of the range comparators intersect.
487
498
  * `simplifyRange(versions, range)`: Return a "simplified" range that
488
- matches the same items in `versions` list as the range specified. Note
499
+ matches the same items in the `versions` list as the range specified. Note
489
500
  that it does *not* guarantee that it would match the same versions in all
490
501
  cases, only for the set of versions provided. This is useful when
491
502
  generating ranges by joining together multiple versions with `||`
@@ -498,7 +509,7 @@ strings that they parse.
498
509
  Note that, since ranges may be non-contiguous, a version might not be
499
510
  greater than a range, less than a range, *or* satisfy a range! For
500
511
  example, the range `1.2 <1.2.9 || >2.0.0` would have a hole from `1.2.9`
501
- until `2.0.0`, so the version `1.2.10` would not be greater than the
512
+ until `2.0.0`, so version `1.2.10` would not be greater than the
502
513
  range (because `2.0.1` satisfies, which is higher), nor less than the
503
514
  range (since `1.2.8` satisfies, which is lower), and it also does not
504
515
  satisfy the range.
@@ -511,13 +522,13 @@ range, use the `satisfies(version, range)` function.
511
522
  * `coerce(version, options)`: Coerces a string to semver if possible
512
523
 
513
524
  This aims to provide a very forgiving translation of a non-semver string to
514
- semver. It looks for the first digit in a string, and consumes all
525
+ semver. It looks for the first digit in a string and consumes all
515
526
  remaining characters which satisfy at least a partial semver (e.g., `1`,
516
527
  `1.2`, `1.2.3`) up to the max permitted length (256 characters). Longer
517
528
  versions are simply truncated (`4.6.3.9.2-alpha2` becomes `4.6.3`). All
518
529
  surrounding text is simply ignored (`v3.4 replaces v3.3.1` becomes
519
530
  `3.4.0`). Only text which lacks digits will fail coercion (`version one`
520
- is not valid). The maximum length for any semver component considered for
531
+ is not valid). The maximum length for any semver component considered for
521
532
  coercion is 16 characters; longer components will be ignored
522
533
  (`10000000000000000.4.7.4` becomes `4.7.4`). The maximum value for any
523
534
  semver component is `Number.MAX_SAFE_INTEGER || (2**53 - 1)`; higher value
@@ -593,7 +604,7 @@ eg), and then pull the module name into the documentation for that specific
593
604
  thing.
594
605
  -->
595
606
 
596
- You may pull in just the part of this semver utility that you need, if you
607
+ You may pull in just the part of this semver utility that you need if you
597
608
  are sensitive to packing and tree-shaking concerns. The main
598
609
  `require('semver')` export uses getter functions to lazily load the parts
599
610
  of the API that are used.
@@ -636,6 +647,8 @@ The following modules are available:
636
647
  * `require('semver/ranges/min-satisfying')`
637
648
  * `require('semver/ranges/min-version')`
638
649
  * `require('semver/ranges/outside')`
650
+ * `require('semver/ranges/simplify')`
651
+ * `require('semver/ranges/subset')`
639
652
  * `require('semver/ranges/to-comparators')`
640
653
  * `require('semver/ranges/valid')`
641
654
 
@@ -119,7 +119,11 @@ const main = () => {
119
119
  return fail()
120
120
  }
121
121
  }
122
- return success(versions)
122
+ versions
123
+ .sort((a, b) => semver[reverse ? 'rcompare' : 'compare'](a, b, options))
124
+ .map(v => semver.clean(v, options))
125
+ .map(v => inc ? semver.inc(v, inc, options, identifier, identifierBase) : v)
126
+ .forEach(v => console.log(v))
123
127
  }
124
128
 
125
129
  const failInc = () => {
@@ -129,19 +133,6 @@ const failInc = () => {
129
133
 
130
134
  const fail = () => process.exit(1)
131
135
 
132
- const success = () => {
133
- const compare = reverse ? 'rcompare' : 'compare'
134
- versions.sort((a, b) => {
135
- return semver[compare](a, b, options)
136
- }).map((v) => {
137
- return semver.clean(v, options)
138
- }).map((v) => {
139
- return inc ? semver.inc(v, inc, options, identifier, identifierBase) : v
140
- }).forEach((v, i, _) => {
141
- console.log(v)
142
- })
143
- }
144
-
145
136
  const help = () => console.log(
146
137
  `SemVer ${version}
147
138
 
@@ -198,8 +198,8 @@ class Range {
198
198
 
199
199
  module.exports = Range
200
200
 
201
- const LRU = require('lru-cache')
202
- const cache = new LRU({ max: 1000 })
201
+ const LRU = require('../internal/lrucache')
202
+ const cache = new LRU()
203
203
 
204
204
  const parseOptions = require('../internal/parse-options')
205
205
  const Comparator = require('./comparator')
@@ -470,9 +470,10 @@ const replaceGTE0 = (comp, options) => {
470
470
  // 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
471
471
  // 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do
472
472
  // 1.2 - 3.4 => >=1.2.0 <3.5.0-0
473
+ // TODO build?
473
474
  const hyphenReplace = incPr => ($0,
474
475
  from, fM, fm, fp, fpr, fb,
475
- to, tM, tm, tp, tpr, tb) => {
476
+ to, tM, tm, tp, tpr) => {
476
477
  if (isX(fM)) {
477
478
  from = ''
478
479
  } else if (isX(fm)) {
@@ -158,7 +158,7 @@ class SemVer {
158
158
  do {
159
159
  const a = this.build[i]
160
160
  const b = other.build[i]
161
- debug('prerelease compare', i, a, b)
161
+ debug('build compare', i, a, b)
162
162
  if (a === undefined && b === undefined) {
163
163
  return 0
164
164
  } else if (b === undefined) {
@@ -0,0 +1,45 @@
1
+ class LRUCache {
2
+ constructor () {
3
+ this.max = 1000
4
+ this.map = new Map()
5
+ }
6
+
7
+ get (key) {
8
+ const value = this.map.get(key)
9
+ if (value === undefined) {
10
+ return undefined
11
+ } else {
12
+ // Remove the key from the map and add it to the end
13
+ this.map.delete(key)
14
+ this.map.set(key, value)
15
+ return value
16
+ }
17
+ }
18
+
19
+ delete (key) {
20
+ if (this.map.has(key)) {
21
+ this.map.delete(key)
22
+ return true
23
+ } else {
24
+ return false
25
+ }
26
+ }
27
+
28
+ set (key, value) {
29
+ const deleted = this.delete(key)
30
+
31
+ if (!deleted && value !== undefined) {
32
+ // If cache is full, delete the least recently used item
33
+ if (this.map.size >= this.max) {
34
+ const firstKey = this.map.keys().next().value
35
+ this.delete(firstKey)
36
+ }
37
+
38
+ this.map.set(key, value)
39
+ }
40
+
41
+ return this
42
+ }
43
+ }
44
+
45
+ module.exports = LRUCache
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "semver",
3
- "version": "7.6.0",
3
+ "version": "7.6.1",
4
4
  "description": "The semantic version parser used by npm.",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -14,13 +14,14 @@
14
14
  },
15
15
  "devDependencies": {
16
16
  "@npmcli/eslint-config": "^4.0.0",
17
- "@npmcli/template-oss": "4.21.3",
17
+ "@npmcli/template-oss": "4.22.0",
18
+ "benchmark": "^2.1.4",
18
19
  "tap": "^16.0.0"
19
20
  },
20
21
  "license": "ISC",
21
22
  "repository": {
22
23
  "type": "git",
23
- "url": "https://github.com/npm/node-semver.git"
24
+ "url": "git+https://github.com/npm/node-semver.git"
24
25
  },
25
26
  "bin": {
26
27
  "semver": "bin/semver.js"
@@ -47,13 +48,10 @@
47
48
  "engines": {
48
49
  "node": ">=10"
49
50
  },
50
- "dependencies": {
51
- "lru-cache": "^6.0.0"
52
- },
53
51
  "author": "GitHub Inc.",
54
52
  "templateOSS": {
55
53
  "//@npmcli/template-oss": "This file is partially managed by @npmcli/template-oss. Edits may be overwritten.",
56
- "version": "4.21.3",
54
+ "version": "4.22.0",
57
55
  "engines": ">=10",
58
56
  "distPaths": [
59
57
  "classes/",
@@ -71,7 +69,8 @@
71
69
  "/ranges/",
72
70
  "/index.js",
73
71
  "/preload.js",
74
- "/range.bnf"
72
+ "/range.bnf",
73
+ "/benchmarks"
75
74
  ],
76
75
  "publish": "true"
77
76
  }
package/package.json CHANGED
@@ -52,10 +52,10 @@
52
52
  "jest-junit": "^15",
53
53
  "jsii": "5.x",
54
54
  "jsii-diff": "^1.98.0",
55
- "jsii-docgen": "^10.4.5",
55
+ "jsii-docgen": "^10.4.7",
56
56
  "jsii-pacmak": "^1.98.0",
57
57
  "jsii-rosetta": "5.x",
58
- "projen": "^0.81.7",
58
+ "projen": "^0.81.8",
59
59
  "standard-version": "^9",
60
60
  "ts-jest": "^29.1.2",
61
61
  "ts-node": "^10.9.2",
@@ -64,11 +64,11 @@
64
64
  },
65
65
  "peerDependencies": {
66
66
  "constructs": "^10.3.0",
67
- "projen": "^0.81.7"
67
+ "projen": "^0.81.8"
68
68
  },
69
69
  "dependencies": {
70
- "projen": "^0.81.7",
71
- "semver": "^7.6.0"
70
+ "projen": "^0.81.8",
71
+ "semver": "^7.6.1"
72
72
  },
73
73
  "bundledDependencies": [
74
74
  "semver"
@@ -81,7 +81,7 @@
81
81
  ],
82
82
  "main": "lib/index.js",
83
83
  "license": "Apache-2.0",
84
- "version": "0.1.383",
84
+ "version": "0.1.385",
85
85
  "jest": {
86
86
  "testMatch": [
87
87
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
@@ -1,15 +0,0 @@
1
- The ISC License
2
-
3
- Copyright (c) Isaac Z. Schlueter and Contributors
4
-
5
- Permission to use, copy, modify, and/or distribute this software for any
6
- purpose with or without fee is hereby granted, provided that the above
7
- copyright notice and this permission notice appear in all copies.
8
-
9
- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10
- WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11
- MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12
- ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13
- WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14
- ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
15
- IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
@@ -1,166 +0,0 @@
1
- # lru cache
2
-
3
- A cache object that deletes the least-recently-used items.
4
-
5
- [![Build Status](https://travis-ci.org/isaacs/node-lru-cache.svg?branch=master)](https://travis-ci.org/isaacs/node-lru-cache) [![Coverage Status](https://coveralls.io/repos/isaacs/node-lru-cache/badge.svg?service=github)](https://coveralls.io/github/isaacs/node-lru-cache)
6
-
7
- ## Installation:
8
-
9
- ```javascript
10
- npm install lru-cache --save
11
- ```
12
-
13
- ## Usage:
14
-
15
- ```javascript
16
- var LRU = require("lru-cache")
17
- , options = { max: 500
18
- , length: function (n, key) { return n * 2 + key.length }
19
- , dispose: function (key, n) { n.close() }
20
- , maxAge: 1000 * 60 * 60 }
21
- , cache = new LRU(options)
22
- , otherCache = new LRU(50) // sets just the max size
23
-
24
- cache.set("key", "value")
25
- cache.get("key") // "value"
26
-
27
- // non-string keys ARE fully supported
28
- // but note that it must be THE SAME object, not
29
- // just a JSON-equivalent object.
30
- var someObject = { a: 1 }
31
- cache.set(someObject, 'a value')
32
- // Object keys are not toString()-ed
33
- cache.set('[object Object]', 'a different value')
34
- assert.equal(cache.get(someObject), 'a value')
35
- // A similar object with same keys/values won't work,
36
- // because it's a different object identity
37
- assert.equal(cache.get({ a: 1 }), undefined)
38
-
39
- cache.reset() // empty the cache
40
- ```
41
-
42
- If you put more stuff in it, then items will fall out.
43
-
44
- If you try to put an oversized thing in it, then it'll fall out right
45
- away.
46
-
47
- ## Options
48
-
49
- * `max` The maximum size of the cache, checked by applying the length
50
- function to all values in the cache. Not setting this is kind of
51
- silly, since that's the whole purpose of this lib, but it defaults
52
- to `Infinity`. Setting it to a non-number or negative number will
53
- throw a `TypeError`. Setting it to 0 makes it be `Infinity`.
54
- * `maxAge` Maximum age in ms. Items are not pro-actively pruned out
55
- as they age, but if you try to get an item that is too old, it'll
56
- drop it and return undefined instead of giving it to you.
57
- Setting this to a negative value will make everything seem old!
58
- Setting it to a non-number will throw a `TypeError`.
59
- * `length` Function that is used to calculate the length of stored
60
- items. If you're storing strings or buffers, then you probably want
61
- to do something like `function(n, key){return n.length}`. The default is
62
- `function(){return 1}`, which is fine if you want to store `max`
63
- like-sized things. The item is passed as the first argument, and
64
- the key is passed as the second argumnet.
65
- * `dispose` Function that is called on items when they are dropped
66
- from the cache. This can be handy if you want to close file
67
- descriptors or do other cleanup tasks when items are no longer
68
- accessible. Called with `key, value`. It's called *before*
69
- actually removing the item from the internal cache, so if you want
70
- to immediately put it back in, you'll have to do that in a
71
- `nextTick` or `setTimeout` callback or it won't do anything.
72
- * `stale` By default, if you set a `maxAge`, it'll only actually pull
73
- stale items out of the cache when you `get(key)`. (That is, it's
74
- not pre-emptively doing a `setTimeout` or anything.) If you set
75
- `stale:true`, it'll return the stale value before deleting it. If
76
- you don't set this, then it'll return `undefined` when you try to
77
- get a stale entry, as if it had already been deleted.
78
- * `noDisposeOnSet` By default, if you set a `dispose()` method, then
79
- it'll be called whenever a `set()` operation overwrites an existing
80
- key. If you set this option, `dispose()` will only be called when a
81
- key falls out of the cache, not when it is overwritten.
82
- * `updateAgeOnGet` When using time-expiring entries with `maxAge`,
83
- setting this to `true` will make each item's effective time update
84
- to the current time whenever it is retrieved from cache, causing it
85
- to not expire. (It can still fall out of cache based on recency of
86
- use, of course.)
87
-
88
- ## API
89
-
90
- * `set(key, value, maxAge)`
91
- * `get(key) => value`
92
-
93
- Both of these will update the "recently used"-ness of the key.
94
- They do what you think. `maxAge` is optional and overrides the
95
- cache `maxAge` option if provided.
96
-
97
- If the key is not found, `get()` will return `undefined`.
98
-
99
- The key and val can be any value.
100
-
101
- * `peek(key)`
102
-
103
- Returns the key value (or `undefined` if not found) without
104
- updating the "recently used"-ness of the key.
105
-
106
- (If you find yourself using this a lot, you *might* be using the
107
- wrong sort of data structure, but there are some use cases where
108
- it's handy.)
109
-
110
- * `del(key)`
111
-
112
- Deletes a key out of the cache.
113
-
114
- * `reset()`
115
-
116
- Clear the cache entirely, throwing away all values.
117
-
118
- * `has(key)`
119
-
120
- Check if a key is in the cache, without updating the recent-ness
121
- or deleting it for being stale.
122
-
123
- * `forEach(function(value,key,cache), [thisp])`
124
-
125
- Just like `Array.prototype.forEach`. Iterates over all the keys
126
- in the cache, in order of recent-ness. (Ie, more recently used
127
- items are iterated over first.)
128
-
129
- * `rforEach(function(value,key,cache), [thisp])`
130
-
131
- The same as `cache.forEach(...)` but items are iterated over in
132
- reverse order. (ie, less recently used items are iterated over
133
- first.)
134
-
135
- * `keys()`
136
-
137
- Return an array of the keys in the cache.
138
-
139
- * `values()`
140
-
141
- Return an array of the values in the cache.
142
-
143
- * `length`
144
-
145
- Return total length of objects in cache taking into account
146
- `length` options function.
147
-
148
- * `itemCount`
149
-
150
- Return total quantity of objects currently in cache. Note, that
151
- `stale` (see options) items are returned as part of this item
152
- count.
153
-
154
- * `dump()`
155
-
156
- Return an array of the cache entries ready for serialization and usage
157
- with 'destinationCache.load(arr)`.
158
-
159
- * `load(cacheEntriesArray)`
160
-
161
- Loads another cache entries array, obtained with `sourceCache.dump()`,
162
- into the cache. The destination cache is reset before loading new entries
163
-
164
- * `prune()`
165
-
166
- Manually iterates over the entire cache proactively pruning old entries