refactor(tvix): remove usage of async-recursion

Rust 1.77 supports async recursion as long as there is some form of
indirection (ie. `Box::pin`). This removes the need to use the
async-recursion crate.

Change-Id: Ic9613ab7f32016f0103032a861edff92e2fb8b41
Reviewed-on: https://cl.tvl.fyi/c/depot/+/11596
Reviewed-by: flokli <flokli@flokli.de>
Autosubmit: Connor Brewster <cbrewster@hey.com>
Tested-by: BuildkiteCI
This commit is contained in:
Connor Brewster 2024-05-06 10:53:52 -05:00 committed by clbot
parent 01a4a2399c
commit da9bc274f3
8 changed files with 19 additions and 68 deletions

13
tvix/Cargo.lock generated
View file

@ -206,17 +206,6 @@ dependencies = [
"windows-sys 0.52.0", "windows-sys 0.52.0",
] ]
[[package]]
name = "async-recursion"
version = "1.0.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5fd55a5ba1179988837d24ab4c7cc8ed6efdeff578ede0416b4225a5fca35bd0"
dependencies = [
"proc-macro2",
"quote",
"syn 2.0.48",
]
[[package]] [[package]]
name = "async-signal" name = "async-signal"
version = "0.2.5" version = "0.2.5"
@ -4387,7 +4376,6 @@ name = "tvix-glue"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"async-compression", "async-compression",
"async-recursion",
"bstr", "bstr",
"bytes", "bytes",
"criterion", "criterion",
@ -4438,7 +4426,6 @@ dependencies = [
"anyhow", "anyhow",
"async-compression", "async-compression",
"async-process", "async-process",
"async-recursion",
"async-stream", "async-stream",
"bigtable_rs", "bigtable_rs",
"blake3", "blake3",

View file

@ -718,35 +718,6 @@ rec {
} }
]; ];
};
"async-recursion" = rec {
crateName = "async-recursion";
version = "1.0.5";
edition = "2018";
sha256 = "1l2vlgyaa9a2dd0y1vbqyppzsvpdr1y4rar4gn1qi68pl5dmmmaz";
procMacro = true;
authors = [
"Robert Usher <266585+dcchut@users.noreply.github.com>"
];
dependencies = [
{
name = "proc-macro2";
packageId = "proc-macro2";
usesDefaultFeatures = false;
}
{
name = "quote";
packageId = "quote";
usesDefaultFeatures = false;
}
{
name = "syn";
packageId = "syn 2.0.48";
usesDefaultFeatures = false;
features = [ "full" "parsing" "printing" "proc-macro" "clone-impls" ];
}
];
}; };
"async-signal" = rec { "async-signal" = rec {
crateName = "async-signal"; crateName = "async-signal";
@ -14098,10 +14069,6 @@ rec {
packageId = "async-compression"; packageId = "async-compression";
features = [ "tokio" "gzip" "bzip2" "xz" ]; features = [ "tokio" "gzip" "bzip2" "xz" ];
} }
{
name = "async-recursion";
packageId = "async-recursion";
}
{ {
name = "bstr"; name = "bstr";
packageId = "bstr"; packageId = "bstr";
@ -14300,10 +14267,6 @@ rec {
packageId = "async-compression"; packageId = "async-compression";
features = [ "tokio" "bzip2" "gzip" "xz" "zstd" ]; features = [ "tokio" "bzip2" "gzip" "xz" "zstd" ];
} }
{
name = "async-recursion";
packageId = "async-recursion";
}
{ {
name = "async-stream"; name = "async-stream";
packageId = "async-stream"; packageId = "async-stream";

View file

@ -1,4 +1,4 @@
{ {
"git+https://github.com/flokli/bigtable_rs?rev=0af404741dfc40eb9fa99cf4d4140a09c5c20df7#0.2.9": "1njjam1lx2xlnm7a41lga8601vmjgqz0fvc77x24gd04pc7avxll", "bigtable_rs 0.2.9 (git+https://github.com/flokli/bigtable_rs?rev=0af404741dfc40eb9fa99cf4d4140a09c5c20df7#0af404741dfc40eb9fa99cf4d4140a09c5c20df7)": "1njjam1lx2xlnm7a41lga8601vmjgqz0fvc77x24gd04pc7avxll",
"git+https://github.com/tvlfyi/wu-manber.git#wu-manber@0.1.0": "1zhk83lbq99xzyjwphv2qrb8f8qgfqwa5bbbvyzm0z0bljsjv0pd" "wu-manber 0.1.0 (git+https://github.com/tvlfyi/wu-manber.git#0d5b22bea136659f7de60b102a7030e0daaa503d)": "1zhk83lbq99xzyjwphv2qrb8f8qgfqwa5bbbvyzm0z0bljsjv0pd"
} }

View file

@ -5,7 +5,6 @@ edition = "2021"
[dependencies] [dependencies]
async-compression = { version = "0.4.9", features = ["tokio", "gzip", "bzip2", "xz"]} async-compression = { version = "0.4.9", features = ["tokio", "gzip", "bzip2", "xz"]}
async-recursion = "1.0.5"
bstr = "1.6.0" bstr = "1.6.0"
bytes = "1.4.0" bytes = "1.4.0"
data-encoding = "2.3.3" data-encoding = "2.3.3"

View file

@ -1,6 +1,5 @@
//! This module provides an implementation of EvalIO talking to tvix-store. //! This module provides an implementation of EvalIO talking to tvix-store.
use async_recursion::async_recursion;
use bytes::Bytes; use bytes::Bytes;
use futures::{StreamExt, TryStreamExt}; use futures::{StreamExt, TryStreamExt};
use nix_compat::nixhash::NixHash; use nix_compat::nixhash::NixHash;
@ -92,7 +91,6 @@ impl TvixStoreIO {
/// ///
/// In case there is no PathInfo yet, this means we need to build it /// In case there is no PathInfo yet, this means we need to build it
/// (which currently is stubbed out still). /// (which currently is stubbed out still).
#[async_recursion(?Send)]
#[instrument(skip(self, store_path), fields(store_path=%store_path), ret(level = Level::TRACE), err)] #[instrument(skip(self, store_path), fields(store_path=%store_path), ret(level = Level::TRACE), err)]
async fn store_path_to_node( async fn store_path_to_node(
&self, &self,

View file

@ -40,7 +40,6 @@ tracing-subscriber = { version = "0.3.16", features = ["env-filter", "json"] }
tvix-castore = { path = "../castore" } tvix-castore = { path = "../castore" }
url = "2.4.0" url = "2.4.0"
walkdir = "2.4.0" walkdir = "2.4.0"
async-recursion = "1.0.5"
reqwest = { version = "0.11.22", features = ["rustls-tls-native-roots", "stream"], default-features = false } reqwest = { version = "0.11.22", features = ["rustls-tls-native-roots", "stream"], default-features = false }
[dependencies.tonic-reflection] [dependencies.tonic-reflection]

View file

@ -1,4 +1,3 @@
use async_recursion::async_recursion;
use nix_compat::nar::reader::r#async as nar_reader; use nix_compat::nar::reader::r#async as nar_reader;
use tokio::{io::AsyncBufRead, sync::mpsc, try_join}; use tokio::{io::AsyncBufRead, sync::mpsc, try_join};
use tvix_castore::{ use tvix_castore::{
@ -54,10 +53,9 @@ where
Ok(node.rename("".into())) Ok(node.rename("".into()))
} }
#[async_recursion] async fn produce_nar_inner<BS>(
async fn produce_nar_inner<'a: 'async_recursion, 'r: 'async_recursion, BS>(
blob_service: BS, blob_service: BS,
node: nar_reader::Node<'a, 'r>, node: nar_reader::Node<'_, '_>,
path: PathBuf, path: PathBuf,
tx: mpsc::Sender<Result<IngestionEntry, Error>>, tx: mpsc::Sender<Result<IngestionEntry, Error>>,
) -> Result<IngestionEntry, Error> ) -> Result<IngestionEntry, Error>
@ -93,8 +91,13 @@ where
path.try_push(&entry.name) path.try_push(&entry.name)
.expect("Tvix bug: failed to join name"); .expect("Tvix bug: failed to join name");
let entry = let entry = Box::pin(produce_nar_inner(
produce_nar_inner(blob_service.clone(), entry.node, path, tx.clone()).await?; blob_service.clone(),
entry.node,
path,
tx.clone(),
))
.await?;
tx.send(Ok(entry)).await.map_err(|e| { tx.send(Ok(entry)).await.map_err(|e| {
Error::IO(std::io::Error::new(std::io::ErrorKind::BrokenPipe, e)) Error::IO(std::io::Error::new(std::io::ErrorKind::BrokenPipe, e))

View file

@ -1,7 +1,6 @@
use crate::utils::AsyncIoBridge; use crate::utils::AsyncIoBridge;
use super::RenderError; use super::RenderError;
use async_recursion::async_recursion;
use count_write::CountWrite; use count_write::CountWrite;
use nix_compat::nar::writer::r#async as nar_writer; use nix_compat::nar::writer::r#async as nar_writer;
use sha2::{Digest, Sha256}; use sha2::{Digest, Sha256};
@ -72,9 +71,8 @@ where
/// Process an intermediate node in the structure. /// Process an intermediate node in the structure.
/// This consumes the node. /// This consumes the node.
#[async_recursion]
async fn walk_node<BS, DS>( async fn walk_node<BS, DS>(
nar_node: nar_writer::Node<'async_recursion, '_>, nar_node: nar_writer::Node<'_, '_>,
proto_node: &castorepb::node::Node, proto_node: &castorepb::node::Node,
blob_service: BS, blob_service: BS,
directory_service: DS, directory_service: DS,
@ -164,9 +162,13 @@ where
.await .await
.map_err(RenderError::NARWriterError)?; .map_err(RenderError::NARWriterError)?;
(blob_service, directory_service) = (blob_service, directory_service) = Box::pin(walk_node(
walk_node(child_node, &proto_node, blob_service, directory_service) child_node,
.await?; &proto_node,
blob_service,
directory_service,
))
.await?;
} }
// close the directory // close the directory