Add a --prerelease flag to the CLI (#217)

This commit is contained in:
Charlie Marsh 2023-10-29 11:39:30 -07:00 committed by GitHub
parent 7e7e9f8a0c
commit bae3c89ab1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 18 additions and 13 deletions

View file

@ -99,8 +99,8 @@ impl CandidateSelector {
// Determine the appropriate prerelease strategy for the current package.
let allow_prerelease = match &self.prerelease_strategy {
PreReleaseStrategy::DisallowAll => AllowPreRelease::No,
PreReleaseStrategy::AllowAll => AllowPreRelease::Yes,
PreReleaseStrategy::Disallow => AllowPreRelease::No,
PreReleaseStrategy::Allow => AllowPreRelease::Yes,
PreReleaseStrategy::IfNecessary => AllowPreRelease::IfNecessary,
PreReleaseStrategy::Explicit(packages) => {
if packages.contains(package_name) {

View file

@ -7,10 +7,10 @@ use puffin_package::package_name::PackageName;
#[cfg_attr(feature = "clap", derive(clap::ValueEnum))]
pub enum PreReleaseMode {
/// Disallow all pre-release versions.
DisallowAll,
Disallow,
/// Allow all pre-release versions.
AllowAll,
Allow,
/// Allow pre-release versions if all versions of a package are pre-release.
IfNecessary,
@ -30,10 +30,10 @@ pub enum PreReleaseMode {
#[derive(Debug)]
pub(crate) enum PreReleaseStrategy {
/// Disallow all pre-release versions.
DisallowAll,
Disallow,
/// Allow all pre-release versions.
AllowAll,
Allow,
/// Allow pre-release versions if all versions of a package are pre-release.
IfNecessary,
@ -50,8 +50,8 @@ pub(crate) enum PreReleaseStrategy {
impl PreReleaseStrategy {
pub(crate) fn from_mode(mode: PreReleaseMode, direct_dependencies: &[Requirement]) -> Self {
match mode {
PreReleaseMode::DisallowAll => Self::DisallowAll,
PreReleaseMode::AllowAll => Self::AllowAll,
PreReleaseMode::Disallow => Self::Disallow,
PreReleaseMode::Allow => Self::Allow,
PreReleaseMode::IfNecessary => Self::IfNecessary,
PreReleaseMode::Explicit => Self::Explicit(
direct_dependencies

View file

@ -295,7 +295,7 @@ async fn black_disallow_prerelease() -> Result<()> {
vec![],
vec![],
ResolutionMode::default(),
PreReleaseMode::DisallowAll,
PreReleaseMode::Disallow,
);
let resolver = Resolver::new(manifest, &MARKERS_311, &TAGS_311, &client, &DummyContext);
@ -339,7 +339,7 @@ async fn pylint_disallow_prerelease() -> Result<()> {
vec![],
vec![],
ResolutionMode::default(),
PreReleaseMode::DisallowAll,
PreReleaseMode::Disallow,
);
let resolver = Resolver::new(manifest, &MARKERS_311, &TAGS_311, &client, &DummyContext);
@ -361,7 +361,7 @@ async fn pylint_allow_prerelease() -> Result<()> {
vec![],
vec![],
ResolutionMode::default(),
PreReleaseMode::AllowAll,
PreReleaseMode::Allow,
);
let resolver = Resolver::new(manifest, &MARKERS_311, &TAGS_311, &client, &DummyContext);