44require ( 'internal/modules/cjs/loader' ) ;
55
66const {
7+ ArrayPrototypeJoin,
8+ ArrayPrototypeMap,
9+ ArrayPrototypeReduce,
710 FunctionPrototypeCall,
11+ JSONStringify,
812 ObjectSetPrototypeOf,
13+ RegExpPrototypeSymbolReplace,
914 SafeWeakMap,
15+ encodeURIComponent,
16+ hardenRegExp,
1017} = primordials ;
1118
1219const {
@@ -498,7 +505,7 @@ class CustomizedModuleLoader {
498505 }
499506}
500507
501- let emittedExperimentalWarning = false ;
508+ let emittedLoaderFlagWarning = false ;
502509/**
503510 * A loader instance is used as the main entry point for loading ES modules. Currently, this is a singleton; there is
504511 * only one used for loading the main module and everything in its dependency graph, though separate instances of this
@@ -514,9 +521,24 @@ function createModuleLoader(useCustomLoadersIfPresent = true) {
514521 ! require ( 'internal/modules/esm/utils' ) . isLoaderWorker ( ) ) {
515522 const userLoaderPaths = getOptionValue ( '--experimental-loader' ) ;
516523 if ( userLoaderPaths . length > 0 ) {
517- if ( ! emittedExperimentalWarning ) {
518- emitExperimentalWarning ( 'Custom ESM Loaders' ) ;
519- emittedExperimentalWarning = true ;
524+ if ( ! emittedLoaderFlagWarning ) {
525+ const readableURIEncode = ( string ) => ArrayPrototypeReduce (
526+ [
527+ [ / ' / g, '%27' ] , // We need to URL-encode the single quote as it's the delimiter for the --import flag.
528+ [ / % 2 2 / g, '"' ] , // We can decode the double quotes to improve readability.
529+ [ / % 2 F / ig, '/' ] , // We can decode the slashes to improve readability.
530+ ] ,
531+ ( str , { 0 : regex , 1 : replacement } ) => RegExpPrototypeSymbolReplace ( hardenRegExp ( regex ) , str , replacement ) ,
532+ encodeURIComponent ( string ) ) ;
533+ process . emitWarning (
534+ '`--experimental-loader` may be removed in the future; instead use `register()`:\n' +
535+ `--import 'data:text/javascript,import { register } from "node:module"; import { pathToFileURL } from "node:url"; ${ ArrayPrototypeJoin (
536+ ArrayPrototypeMap ( userLoaderPaths , ( loader ) => `register(${ readableURIEncode ( JSONStringify ( loader ) ) } , pathToFileURL("./"))` ) ,
537+ '; ' ,
538+ ) } ;'`,
539+ 'ExperimentalWarning' ,
540+ ) ;
541+ emittedLoaderFlagWarning = true ;
520542 }
521543 customizations = new CustomizedModuleLoader ( ) ;
522544 }
0 commit comments