mirror of
https://github.com/pesde-pkg/pesde.git
synced 2025-04-05 11:20:55 +01:00
feat: remove old includes compat
Some checks are pending
Debug / Get build version (push) Waiting to run
Debug / Build for linux-x86_64 (push) Blocked by required conditions
Debug / Build for macos-aarch64 (push) Blocked by required conditions
Debug / Build for macos-x86_64 (push) Blocked by required conditions
Debug / Build for windows-x86_64 (push) Blocked by required conditions
Test & Lint / lint (push) Waiting to run
Some checks are pending
Debug / Get build version (push) Waiting to run
Debug / Build for linux-x86_64 (push) Blocked by required conditions
Debug / Build for macos-aarch64 (push) Blocked by required conditions
Debug / Build for macos-x86_64 (push) Blocked by required conditions
Debug / Build for windows-x86_64 (push) Blocked by required conditions
Test & Lint / lint (push) Waiting to run
This commit is contained in:
parent
6cf9f14649
commit
ccb2924362
3 changed files with 12 additions and 97 deletions
|
@ -11,6 +11,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
- Support using aliases of own dependencies for overrides by @daimond113
|
- Support using aliases of own dependencies for overrides by @daimond113
|
||||||
- Support ignoring parse errors in Luau files by @daimond113
|
- Support ignoring parse errors in Luau files by @daimond113
|
||||||
|
|
||||||
|
### Removed
|
||||||
|
- Remove old includes format compatibility by @daimond113
|
||||||
|
|
||||||
### Performance
|
### Performance
|
||||||
- Use `Arc` for more efficient cloning of multiple structs by @daimond113
|
- Use `Arc` for more efficient cloning of multiple structs by @daimond113
|
||||||
- Avoid cloning where possible by @daimond113
|
- Avoid cloning where possible by @daimond113
|
||||||
|
|
|
@ -4,30 +4,22 @@ use async_compression::Level;
|
||||||
use clap::Args;
|
use clap::Args;
|
||||||
use colored::Colorize;
|
use colored::Colorize;
|
||||||
use fs_err::tokio as fs;
|
use fs_err::tokio as fs;
|
||||||
#[allow(deprecated)]
|
|
||||||
use pesde::{
|
use pesde::{
|
||||||
manifest::{target::Target, DependencyType},
|
manifest::{target::Target, DependencyType},
|
||||||
matching_globs_old_behaviour,
|
matching_globs,
|
||||||
scripts::ScriptName,
|
scripts::ScriptName,
|
||||||
source::{
|
source::{
|
||||||
git_index::GitBasedSource,
|
git_index::GitBasedSource,
|
||||||
pesde::{specifier::PesdeDependencySpecifier, PesdePackageSource},
|
pesde::{specifier::PesdeDependencySpecifier, PesdePackageSource},
|
||||||
specifiers::DependencySpecifiers,
|
specifiers::DependencySpecifiers,
|
||||||
traits::PackageSource,
|
traits::{PackageSource, RefreshOptions, ResolveOptions},
|
||||||
workspace::{
|
workspace::{
|
||||||
specifier::{VersionType, VersionTypeOrReq},
|
specifier::{VersionType, VersionTypeOrReq},
|
||||||
WorkspacePackageSource,
|
WorkspacePackageSource,
|
||||||
},
|
},
|
||||||
IGNORED_DIRS, IGNORED_FILES,
|
PackageSources, IGNORED_DIRS, IGNORED_FILES,
|
||||||
},
|
},
|
||||||
Project, DEFAULT_INDEX_NAME, MANIFEST_FILE_NAME,
|
Project, RefreshedSources, DEFAULT_INDEX_NAME, MANIFEST_FILE_NAME,
|
||||||
};
|
|
||||||
use pesde::{
|
|
||||||
source::{
|
|
||||||
traits::{RefreshOptions, ResolveOptions},
|
|
||||||
PackageSources,
|
|
||||||
},
|
|
||||||
RefreshedSources,
|
|
||||||
};
|
};
|
||||||
use reqwest::{header::AUTHORIZATION, StatusCode};
|
use reqwest::{header::AUTHORIZATION, StatusCode};
|
||||||
use semver::VersionReq;
|
use semver::VersionReq;
|
||||||
|
@ -162,11 +154,11 @@ impl PublishCommand {
|
||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[allow(deprecated)]
|
let mut paths = matching_globs(
|
||||||
let mut paths = matching_globs_old_behaviour(
|
|
||||||
project.package_dir(),
|
project.package_dir(),
|
||||||
manifest.includes.iter().map(|s| s.as_str()),
|
manifest.includes.iter().map(|s| s.as_str()),
|
||||||
true,
|
true,
|
||||||
|
false,
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
.context("failed to get included files")?;
|
.context("failed to get included files")?;
|
||||||
|
|
86
src/lib.rs
86
src/lib.rs
|
@ -11,7 +11,7 @@ use crate::{
|
||||||
PackageSources,
|
PackageSources,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
use async_stream::stream;
|
use async_stream::try_stream;
|
||||||
use fs_err::tokio as fs;
|
use fs_err::tokio as fs;
|
||||||
use futures::Stream;
|
use futures::Stream;
|
||||||
use gix::sec::identity::Account;
|
use gix::sec::identity::Account;
|
||||||
|
@ -240,7 +240,7 @@ impl Project {
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
Ok(stream! {
|
Ok(try_stream! {
|
||||||
for path in members {
|
for path in members {
|
||||||
let manifest = fs::read_to_string(path.join(MANIFEST_FILE_NAME))
|
let manifest = fs::read_to_string(path.join(MANIFEST_FILE_NAME))
|
||||||
.await
|
.await
|
||||||
|
@ -249,92 +249,12 @@ impl Project {
|
||||||
errors::WorkspaceMembersError::ManifestDeser(path.clone(), Box::new(e))
|
errors::WorkspaceMembersError::ManifestDeser(path.clone(), Box::new(e))
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
yield Ok((path, manifest));
|
yield (path, manifest);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Gets all matching paths in a directory
|
|
||||||
#[deprecated(
|
|
||||||
since = "0.5.0-rc.13",
|
|
||||||
note = "use `matching_globs` instead, which does not have the old behaviour of including whole directories by their name (`src` instead of `src/**`)"
|
|
||||||
)]
|
|
||||||
#[instrument(ret, level = "trace")]
|
|
||||||
pub async fn matching_globs_old_behaviour<
|
|
||||||
'a,
|
|
||||||
P: AsRef<Path> + Debug,
|
|
||||||
I: IntoIterator<Item = &'a str> + Debug,
|
|
||||||
>(
|
|
||||||
dir: P,
|
|
||||||
globs: I,
|
|
||||||
relative: bool,
|
|
||||||
) -> Result<HashSet<PathBuf>, errors::MatchingGlobsError> {
|
|
||||||
let (negative_globs, positive_globs) = globs
|
|
||||||
.into_iter()
|
|
||||||
.partition::<Vec<_>, _>(|glob| glob.starts_with('!'));
|
|
||||||
|
|
||||||
let negative_globs = wax::any(
|
|
||||||
negative_globs
|
|
||||||
.into_iter()
|
|
||||||
.map(|glob| wax::Glob::new(&glob[1..]))
|
|
||||||
.collect::<Result<Vec<_>, _>>()?,
|
|
||||||
)?;
|
|
||||||
|
|
||||||
let (positive_globs, file_names) = positive_globs
|
|
||||||
.into_iter()
|
|
||||||
// only globs we can be sure of (maintaining compatibility with old "only file/dir name" system)
|
|
||||||
.partition::<Vec<_>, _>(|glob| glob.contains('/'));
|
|
||||||
let file_names = file_names.into_iter().collect::<HashSet<_>>();
|
|
||||||
|
|
||||||
let positive_globs = wax::any(
|
|
||||||
positive_globs
|
|
||||||
.into_iter()
|
|
||||||
.map(wax::Glob::new)
|
|
||||||
.collect::<Result<Vec<_>, _>>()?,
|
|
||||||
)?;
|
|
||||||
|
|
||||||
let mut read_dirs = vec![(fs::read_dir(dir.as_ref().to_path_buf()).await?, false)];
|
|
||||||
let mut paths = HashSet::new();
|
|
||||||
|
|
||||||
let mut is_root = true;
|
|
||||||
|
|
||||||
while let Some((mut read_dir, is_entire_dir_included)) = read_dirs.pop() {
|
|
||||||
while let Some(entry) = read_dir.next_entry().await? {
|
|
||||||
let path = entry.path();
|
|
||||||
let relative_path = path.strip_prefix(dir.as_ref()).unwrap();
|
|
||||||
let file_name = path.file_name().unwrap();
|
|
||||||
let is_filename_match =
|
|
||||||
is_root && file_name.to_str().is_some_and(|s| file_names.contains(s));
|
|
||||||
|
|
||||||
if entry.file_type().await?.is_dir() {
|
|
||||||
read_dirs.push((
|
|
||||||
fs::read_dir(&path).await?,
|
|
||||||
is_entire_dir_included || is_filename_match,
|
|
||||||
));
|
|
||||||
if is_filename_match {
|
|
||||||
tracing::warn!("directory name usage found for {}. this is deprecated and will be removed in the future", path.display());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_entire_dir_included || is_filename_match)
|
|
||||||
|| (positive_globs.is_match(relative_path)
|
|
||||||
&& !negative_globs.is_match(relative_path))
|
|
||||||
{
|
|
||||||
paths.insert(if relative {
|
|
||||||
relative_path.to_path_buf()
|
|
||||||
} else {
|
|
||||||
path.to_path_buf()
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
is_root = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(paths)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Gets all matching paths in a directory
|
/// Gets all matching paths in a directory
|
||||||
#[instrument(ret, level = "trace")]
|
#[instrument(ret, level = "trace")]
|
||||||
pub async fn matching_globs<'a, P: AsRef<Path> + Debug, I: IntoIterator<Item = &'a str> + Debug>(
|
pub async fn matching_globs<'a, P: AsRef<Path> + Debug, I: IntoIterator<Item = &'a str> + Debug>(
|
||||||
|
|
Loading…
Add table
Reference in a new issue