1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-14 18:08:52 -05:00

fix(npm): use original node regex in npm resolution (#17404)

Fixes regex for matching conditional exports in a package.
Updated to the same regex Node.js uses.
This commit is contained in:
Kiryl Dziamura 2023-01-14 00:57:24 +01:00 committed by Bartek Iwańczuk
parent 8e0c2f34fa
commit c7bff76c41
No known key found for this signature in database
GPG key ID: 0C6BCDDC3B3AD750
5 changed files with 9 additions and 2 deletions

View file

@ -1,10 +1,12 @@
import mod from "npm:@denotest/conditional-exports"; import mod from "npm:@denotest/conditional-exports";
import foo from "npm:@denotest/conditional-exports/foo.js";
import client from "npm:@denotest/conditional-exports/client"; import client from "npm:@denotest/conditional-exports/client";
import clientFoo from "npm:@denotest/conditional-exports/client/foo"; import clientFoo from "npm:@denotest/conditional-exports/client/foo";
import clientBar from "npm:@denotest/conditional-exports/client/bar"; import clientBar from "npm:@denotest/conditional-exports/client/bar";
import supportsESM from "npm:supports-esm"; import supportsESM from "npm:supports-esm";
console.log(mod); console.log(mod);
console.log(foo);
console.log(client); console.log(client);
console.log(clientFoo); console.log(clientFoo);
console.log(clientBar); console.log(clientBar);

View file

@ -7,6 +7,7 @@ Download http://localhost:4545/npm/registry/@ljharb/has-package-exports-patterns
Download http://localhost:4545/npm/registry/has-package-exports/has-package-exports-1.3.0.tgz Download http://localhost:4545/npm/registry/has-package-exports/has-package-exports-1.3.0.tgz
Download http://localhost:4545/npm/registry/supports-esm/supports-esm-1.0.0.tgz Download http://localhost:4545/npm/registry/supports-esm/supports-esm-1.0.0.tgz
{ hello: "from esm" } { hello: "from esm" }
{ hello: "from foo" }
{ hello: "from esm client" } { hello: "from esm client" }
{ hello: "from esm client foo" } { hello: "from esm client foo" }
{ hello: "from esm client bar" } { hello: "from esm client bar" }

View file

@ -0,0 +1,3 @@
export default {
hello: "from foo",
}

View file

@ -15,6 +15,7 @@
"./client/*": { "./client/*": {
"types": "./types/src/client/*.d.ts", "types": "./types/src/client/*.d.ts",
"import": "./esm/client/*.js" "import": "./esm/client/*.js"
} },
"./*": "./*"
} }
} }

View file

@ -339,7 +339,7 @@ fn resolve_package_target_string(
)); ));
} }
let invalid_segment_re = let invalid_segment_re =
Regex::new(r"(^|\|/)(..?|node_modules)(\|/|$)").expect("bad regex"); Regex::new(r"(^|\\|/)(\.\.?|node_modules)(\\|/|$)").expect("bad regex");
let pattern_re = Regex::new(r"\*").expect("bad regex"); let pattern_re = Regex::new(r"\*").expect("bad regex");
if !target.starts_with("./") { if !target.starts_with("./") {
if internal && !target.starts_with("../") && !target.starts_with('/') { if internal && !target.starts_with("../") && !target.starts_with('/') {