From 2239acc928848856d46e43347d158dede76a2c19 Mon Sep 17 00:00:00 2001 From: Benjamin Woodruff Date: Fri, 10 Jan 2025 15:43:59 -0800 Subject: [PATCH] Dedupe functions --- crates/next-core/src/next_client/context.rs | 24 ++------------- crates/next-core/src/next_server/context.rs | 33 ++------------------- crates/next-core/src/util.rs | 28 ++++++++++++++++- 3 files changed, 32 insertions(+), 53 deletions(-) diff --git a/crates/next-core/src/next_client/context.rs b/crates/next-core/src/next_client/context.rs index 3d2336f02d46dc..af930ae07c064b 100644 --- a/crates/next-core/src/next_client/context.rs +++ b/crates/next-core/src/next_client/context.rs @@ -4,7 +4,7 @@ use anyhow::Result; use turbo_rcstr::RcStr; use turbo_tasks::{FxIndexMap, ResolvedVc, Value, Vc}; use turbo_tasks_env::EnvMap; -use turbo_tasks_fs::{FileSystem, FileSystemPath}; +use turbo_tasks_fs::FileSystemPath; use turbopack::{ module_options::{ module_options_context::ModuleOptionsContext, CssOptionsContext, EcmascriptOptionsContext, @@ -19,7 +19,6 @@ use turbopack_core::{ CompileTimeDefineValue, CompileTimeDefines, CompileTimeInfo, DefineableNameSegment, FreeVarReference, FreeVarReferences, }, - condition::ContextCondition, environment::{BrowserEnvironment, Environment, ExecutionEnvironment}, free_var_references, resolve::{parse::Request, pattern::Pattern}, @@ -31,7 +30,6 @@ use turbopack_node::{ use super::transforms::get_next_client_transforms_rules; use crate::{ - embed_js::next_js_fs, mode::NextMode, next_build::get_postcss_package_mapping, next_client::runtime_entry::{RuntimeEntries, RuntimeEntry}, @@ -60,7 +58,7 @@ use crate::{ get_decorators_transform_options, get_jsx_transform_options, get_typescript_transform_options, }, - util::foreign_code_context_condition, + util::{foreign_code_context_condition, internal_assets_conditions}, }; fn defines(define_env: &FxIndexMap) -> CompileTimeDefines { @@ -212,24 +210,6 @@ pub async fn get_client_resolve_options_context( .cell()) } -async fn internal_assets_conditions() -> Result { - Ok(ContextCondition::any(vec![ - ContextCondition::InPath(next_js_fs().root().to_resolved().await?), - ContextCondition::InPath( - turbopack_ecmascript_runtime::embed_fs() - .root() - .to_resolved() - .await?, - ), - ContextCondition::InPath( - turbopack_node::embed_js::embed_fs() - .root() - .to_resolved() - .await?, - ), - ])) -} - #[turbo_tasks::function] pub async fn get_client_module_options_context( project_path: ResolvedVc, diff --git a/crates/next-core/src/next_server/context.rs b/crates/next-core/src/next_server/context.rs index 5df6583b073b58..9e23f49f07ae7c 100644 --- a/crates/next-core/src/next_server/context.rs +++ b/crates/next-core/src/next_server/context.rs @@ -4,7 +4,7 @@ use anyhow::{bail, Result}; use turbo_rcstr::RcStr; use turbo_tasks::{FxIndexMap, ResolvedVc, Value, Vc}; use turbo_tasks_env::{EnvMap, ProcessEnv}; -use turbo_tasks_fs::{FileSystem, FileSystemPath}; +use turbo_tasks_fs::FileSystemPath; use turbopack::{ module_options::{ CssOptionsContext, EcmascriptOptionsContext, JsxTransformOptions, ModuleOptionsContext, @@ -19,7 +19,6 @@ use turbopack_core::{ CompileTimeDefineValue, CompileTimeDefines, CompileTimeInfo, DefineableNameSegment, FreeVarReferences, }, - condition::ContextCondition, environment::{ Environment, ExecutionEnvironment, NodeJsEnvironment, NodeJsVersion, RuntimeVersions, }, @@ -41,7 +40,6 @@ use super::{ transforms::{get_next_server_internal_transforms_rules, get_next_server_transforms_rules}, }; use crate::{ - embed_js::next_js_fs, mode::NextMode, next_build::get_postcss_package_mapping, next_client::RuntimeEntries, @@ -71,8 +69,8 @@ use crate::{ get_typescript_transform_options, }, util::{ - foreign_code_context_condition, get_transpiled_packages, load_next_js_templateon, - NextRuntime, + foreign_code_context_condition, get_transpiled_packages, internal_assets_conditions, + load_next_js_templateon, NextRuntime, }, }; @@ -396,31 +394,6 @@ pub async fn get_server_compile_time_info( .await } -/// Determins if the module is an internal asset (i.e overlay, fallback) coming -/// from the embedded FS, don't apply user defined transforms. -/// -/// [TODO] turbopack specific embed fs should be handled by internals of -/// turbopack itself and user config should not try to leak this. However, -/// currently we apply few transform options subject to next.js's configuration -/// even if it's embedded assets. -async fn internal_assets_conditions() -> Result { - Ok(ContextCondition::any(vec![ - ContextCondition::InPath(next_js_fs().root().to_resolved().await?), - ContextCondition::InPath( - turbopack_ecmascript_runtime::embed_fs() - .root() - .to_resolved() - .await?, - ), - ContextCondition::InPath( - turbopack_node::embed_js::embed_fs() - .root() - .to_resolved() - .await?, - ), - ])) -} - #[turbo_tasks::function] pub async fn get_server_module_options_context( project_path: ResolvedVc, diff --git a/crates/next-core/src/util.rs b/crates/next-core/src/util.rs index e70ee92cdb1903..3d944b8e4028ec 100644 --- a/crates/next-core/src/util.rs +++ b/crates/next-core/src/util.rs @@ -13,7 +13,7 @@ use turbo_tasks::{ }; use turbo_tasks_fs::{ self, json::parse_json_rope_with_source_context, rope::Rope, util::join_path, File, - FileContent, FileSystemPath, + FileContent, FileSystem, FileSystemPath, }; use turbopack_core::{ asset::AssetContent, @@ -32,6 +32,7 @@ use turbopack_ecmascript::{ }; use crate::{ + embed_js::next_js_fs, next_config::{NextConfig, RouteHas}, next_import_map::get_next_package, next_manifests::MiddlewareMatcher, @@ -140,6 +141,31 @@ pub async fn foreign_code_context_condition( Ok(result) } +/// Determines if the module is an internal asset (i.e overlay, fallback) coming +/// from the embedded FS, don't apply user defined transforms. +/// +/// [TODO] turbopack specific embed fs should be handled by internals of +/// turbopack itself and user config should not try to leak this. However, +/// currently we apply few transform options subject to next.js's configuration +/// even if it's embedded assets. +pub async fn internal_assets_conditions() -> Result { + Ok(ContextCondition::any(vec![ + ContextCondition::InPath(next_js_fs().root().to_resolved().await?), + ContextCondition::InPath( + turbopack_ecmascript_runtime::embed_fs() + .root() + .to_resolved() + .await?, + ), + ContextCondition::InPath( + turbopack_node::embed_js::embed_fs() + .root() + .to_resolved() + .await?, + ), + ])) +} + #[derive( Default, PartialEq,