Skip to content

Releases: lukeed/resolve.exports

v2.0.3

02 Dec 16:33
6613167
Compare
Choose a tag to compare

Patches

Chores


Full Changelog: v2.0.2...v2.0.3

v2.0.2

23 Mar 19:01
Compare
Choose a tag to compare

Patches


Full Changelog: v2.0.1...v2.0.2

v2.0.1

06 Mar 19:04
Compare
Choose a tag to compare

Patches

  • Correctly handle subpath patterns where entries did not contain "*" for value injection (#26): 1a0164d, 5d9601d
    Thank you @bnussman for the test & report!

Chores


Full Changelog: v2.0.0...v2.0.1

v2.0.0

16 Jan 22:21
Compare
Choose a tag to compare

Breaking

  • Changed the resolve return signature from string | undefined to string[] | undefined:

    Previously resolve.exports could only return 1 string output. This ignored "imports" and "exports" entries that could return multiple resolved locations (aka "alternatives").

    Now resolve.exports supports arrayable entries and normalizes all outputs into arrays. This makes it easier for consumers to uniformly traverse the output (or simply take the first item).

Features

  • NEW Add imports function to resolve "imports" identifiers: #14

  • NEW Add exports function to resolve "exports" maps exclusively
    Note: This is identical to the resolve function from [email protected] release.

  • Converted the resolve function to be a convenience helper.
    Note: Its API signature is unchanged. However, it also now accepts import specifiers. If an import identifier (eg, #foo or <package>/#foo) is received, then the imports() function is invoked. Otherwise the exports() function is called.

  • Support array values (#17)

Chores

  • Converted source code to strict TypeScript
  • Add Node 16.x and 18.x to CI matrix

Full Changelog: v1.1.1...v2.0.0

v1.1.1

11 Jan 22:21
Compare
Choose a tag to compare

Patches

  • Handle subpath entry names that start with a dot (#20):
    Thank you @ErikMikkelson
  • Allow subpath patterns to include "*" anywhere (#16, #22): 7e41d63
  • Support null resolved values: (#16): d3bda82
  • Allow multiple "*" within the resolved value (#9):

All these fixes allow the following package.json example to be resolved correctly (according to the latest "exports" resolution specification):

{
  "name": "foobar",
  "exports": {
    // subpath w/ leading "."
    "./.ini": "./.ini",
    // nullable (private) values
    "./features/internal/*": null,
    "./features/*": "./src/features/*.js",
    "./features/private/*": null,
    // allow "*" anywhere in pattern
    "./views/*": "./src/views/*.js",
    "./views/*.jsx": "./src/views/*.jsx",
    "./views/*/template": "./src/views/*.html",
    // multiple wildcards in value
    "./es*": "./esm/*/GAP/*.js"
    // "foobar/es2015" => "./esm/2015/GAP/2015.js"
    // "foobar/es2015/a/b" => "./esm/2015/a/b/GAP/2015/a/b.js"
  }
}

Types

Chores

  • Add additional tests for subpath pattern depth (#23): 0bae61e
    Thank you @huntie
  • Add Node 16.x and 18x to CI testing matrix: 4908584

Full Changelog: v1.1.0...v1.1.1

v1.1.0

15 Oct 01:04
Compare
Choose a tag to compare

Features

  • Add unsafe option (#12, #13): 0b69d12
    Note: This option should not be used by most consumers, but is made available for edge cases. As the name suggests, this is "unsafe" and breaks away from the default Node resolve conditions.

Chores


Full Changelog: v1.0.2...v1.1.0

v1.0.2

12 Jan 20:52
Compare
Choose a tag to compare

Patches

  • Ensure subpath pattern entries are matched correctly (#4): 81ae07a
    Introduced faulty logic in #2 which made it such that any "match" that was 2 characters or less would accidentally be ignored.

v1.0.1

11 Jan 19:10
Compare
Choose a tag to compare

Patches

  • Add support for conditionals within directory mappings – both subpath and subpattern variants (#1, #2): a881ef8
    The following examples are now supported, in congruence with the Node.js algorithm (v12.20+):

    {
      "name": "foobar",
      "exports": {
        // subpath folder mapping
        "./features/": {
          "browser": {
            "import": "./browser.import/",
            "require": "./browser.require/"
          },
          "import": "./import/",
          "require": "./require/"
        },
        // subpath pattern mapping
        "./features/*": {
          "browser": {
            "import": "./browser.import/*.mjs",
            "require": "./browser.require/*.js"
          },
          "import": "./import/*.mjs",
          "require": "./require/*.js"
        }
      }
    }