From 158a740033e95cb2d889faae3b704ad7e6d0c674 Mon Sep 17 00:00:00 2001 From: Tobias Koppers Date: Wed, 4 Sep 2024 20:00:59 +0200 Subject: [PATCH] [Turbopack] transient when the self argument is transient (#69657) ### What? For calls with self argument, we also need to flag a task a transient when the self argument is transient. --- .../crates/turbo-tasks-macros/src/func.rs | 23 +++++++++++++++---- .../crates/turbo-tasks/src/macro_helpers.rs | 14 ++++++++++- turbopack/crates/turbo-tasks/src/raw_vc.rs | 7 ++++++ 3 files changed, 39 insertions(+), 5 deletions(-) diff --git a/turbopack/crates/turbo-tasks-macros/src/func.rs b/turbopack/crates/turbo-tasks-macros/src/func.rs index ae0c6129d1f92..e7354961854f3 100644 --- a/turbopack/crates/turbo-tasks-macros/src/func.rs +++ b/turbopack/crates/turbo-tasks-macros/src/func.rs @@ -324,6 +324,18 @@ impl TurboFn { } } + pub fn persistence_with_this(&self) -> impl ToTokens { + if self.local_cells { + quote! { + turbo_tasks::TaskPersistence::LocalCells + } + } else { + quote! { + turbo_tasks::macro_helpers::get_non_local_persistence_from_inputs_and_this(this, &*inputs) + } + } + } + fn converted_this(&self) -> Option { self.this.as_ref().map(|Input { ty: _, ident }| { parse_quote! { @@ -361,17 +373,18 @@ impl TurboFn { let output = &self.output; let assertions = self.get_assertions(); let inputs = self.input_idents(); - let persistence = self.persistence(); + let persistence = self.persistence_with_this(); parse_quote! { { #assertions let inputs = std::boxed::Box::new((#(#inputs,)*)); + let this = #converted_this; let persistence = #persistence; <#output as turbo_tasks::task::TaskOutput>::try_from_raw_vc( turbo_tasks::trait_call( *#trait_type_id_ident, std::borrow::Cow::Borrowed(stringify!(#ident)), - #converted_this, + this, inputs as std::boxed::Box, persistence, ) @@ -385,18 +398,19 @@ impl TurboFn { pub fn static_block(&self, native_function_id_ident: &Ident) -> Block { let output = &self.output; let inputs = self.input_idents(); - let persistence = self.persistence(); let assertions = self.get_assertions(); if let Some(converted_this) = self.converted_this() { + let persistence = self.persistence_with_this(); parse_quote! { { #assertions let inputs = std::boxed::Box::new((#(#inputs,)*)); + let this = #converted_this; let persistence = #persistence; <#output as turbo_tasks::task::TaskOutput>::try_from_raw_vc( turbo_tasks::dynamic_this_call( *#native_function_id_ident, - #converted_this, + this, inputs as std::boxed::Box, persistence, ) @@ -404,6 +418,7 @@ impl TurboFn { } } } else { + let persistence = self.persistence(); parse_quote! { { #assertions diff --git a/turbopack/crates/turbo-tasks/src/macro_helpers.rs b/turbopack/crates/turbo-tasks/src/macro_helpers.rs index 1e9313826069e..fef19848c5b05 100644 --- a/turbopack/crates/turbo-tasks/src/macro_helpers.rs +++ b/turbopack/crates/turbo-tasks/src/macro_helpers.rs @@ -9,7 +9,8 @@ pub use super::{ manager::{find_cell_by_type, notify_scheduled_tasks, spawn_detached_for_testing}, }; use crate::{ - debug::ValueDebugFormatString, task::TaskOutput, ResolvedValue, TaskInput, TaskPersistence, Vc, + debug::ValueDebugFormatString, task::TaskOutput, RawVc, ResolvedValue, TaskInput, + TaskPersistence, Vc, }; #[inline(never)] @@ -31,6 +32,17 @@ pub fn get_non_local_persistence_from_inputs(inputs: &impl TaskInput) -> TaskPer } } +pub fn get_non_local_persistence_from_inputs_and_this( + this: RawVc, + inputs: &impl TaskInput, +) -> TaskPersistence { + if this.is_transient() || inputs.is_transient() { + TaskPersistence::Transient + } else { + TaskPersistence::Persistent + } +} + pub fn assert_returns_resolved_value() where ReturnType: TaskOutput>, diff --git a/turbopack/crates/turbo-tasks/src/raw_vc.rs b/turbopack/crates/turbo-tasks/src/raw_vc.rs index a844df4d47723..b50dd5ac627f3 100644 --- a/turbopack/crates/turbo-tasks/src/raw_vc.rs +++ b/turbopack/crates/turbo-tasks/src/raw_vc.rs @@ -79,6 +79,13 @@ impl RawVc { } } + pub fn is_transient(&self) -> bool { + match self { + RawVc::TaskOutput(task) | RawVc::TaskCell(task, _) => task.is_transient(), + RawVc::LocalCell(_, _) => true, + } + } + pub(crate) fn into_read(self) -> ReadRawVcFuture { // returns a custom future to have something concrete and sized // this avoids boxing in IntoFuture