From f1eb162d5702f04a2666a0a158332bcc28266cef Mon Sep 17 00:00:00 2001 From: Tobias Koppers Date: Mon, 29 Jul 2024 14:50:37 +0200 Subject: [PATCH] fix symlinks and dotfiles while reading glob (#8865) ### Description * fix dot files handling while reading glob fix symlink handling while reading glob * fix symlink handling while reading glob ### Testing Instructions --- crates/turbo-tasks-fs/src/read_glob.rs | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/crates/turbo-tasks-fs/src/read_glob.rs b/crates/turbo-tasks-fs/src/read_glob.rs index 829ae206bf6b5..69d1dbc2afd69 100644 --- a/crates/turbo-tasks-fs/src/read_glob.rs +++ b/crates/turbo-tasks-fs/src/read_glob.rs @@ -46,27 +46,31 @@ async fn read_glob_internal( let glob_value = glob.await?; match &*dir { DirectoryContent::Entries(entries) => { - for item in entries.iter() { - match item { - (segment, DirectoryEntry::Directory(path)) => { + for (segment, entry) in entries.iter() { + if !include_dot_files && segment.starts_with('.') { + continue; + } + let entry = entry.resolve_symlink().await?; + match entry { + DirectoryEntry::Directory(path) => { let full_path = format!("{prefix}{segment}"); let full_path_prefix: RcStr = format!("{full_path}/").into(); if glob_value.execute(&full_path) { result .results - .insert(full_path.clone(), DirectoryEntry::Directory(*path)); + .insert(full_path.clone(), DirectoryEntry::Directory(path)); } if glob_value.execute(&full_path_prefix) { result.inner.insert( full_path, - read_glob_inner(full_path_prefix, *path, glob, include_dot_files), + read_glob_inner(full_path_prefix, path, glob, include_dot_files), ); } } - (segment, entry) => { + entry => { let full_path = format!("{prefix}{segment}"); if glob_value.execute(&full_path) { - result.results.insert(full_path, *entry); + result.results.insert(full_path, entry); } } }