Skip to content

Conversation

@uranusjr
Copy link
Member

Close #6257. Still missing tests and docs, submitted for responses.

@pfmoore
Copy link
Member

pfmoore commented May 20, 2024

Better named --uploaded-before?

@uranusjr
Copy link
Member Author

Should probably be --exclude-uploaded-before. That’s sooo long though…

@pfmoore
Copy link
Member

pfmoore commented May 20, 2024

Hang on, does this only look at files uploaded before or after the provided date? My understanding of #6257 was that if you provided 1st January as the date, pip would ignore any files uploaded after that date.

So I'd write that as pip install foo --uploaded-before 01/01/2024.

Having said that, I agree it's still not completely obvious what's going on (that could be read as "install the latest version of foo that was uploaded before 1st Jan" and not constrain the dependencies...). UI is hard 🙁

@pradyunsg
Copy link
Member

pradyunsg commented May 20, 2024

Any reason to not use --exclude-newer instead here? It'll match what uv does, and we could also take the unambigous 2024-12-31 format.

@pfmoore
Copy link
Member

pfmoore commented May 20, 2024

Beyond "we didn't think of it"? Probably not...

Ah, it's what uv uses, that makes sense.

@uranusjr
Copy link
Member Author

I do kind of dislike that name though, it sounds too much like a boolean flag. --exclude-newer-than would be better. Not sure if it’s worthwhile to break compatibility.

@pfmoore
Copy link
Member

pfmoore commented May 20, 2024

I think the question of whether we should try to maintain option equivalence with uv is a bigger one, but one we should consider. I remain uncomfortable with the way that uv pip is sort-of-but-not-quite the same as pip, and I wish they'd not done that. But they did, and we have to live with that fact.

Thinking about --exclude-newer (which I hadn't before, beyond spotting that it was what uv used) I agree that it's not a good choice. It does indeed look like a boolean flag, rather than an option with an argument. If we want to be compatible with uv, I'd be inclined to work out what we think is the best name, and then ask them if they would be willing to change. If they say no, we can then decide whether we care more about compatibility or the option name.

Comment on lines +756 to +759
upload_before = datetime.datetime.fromisoformat(value)
# Assume local timezone if no offset is given in the ISO string.
if upload_before.tzinfo is None:
upload_before = upload_before.astimezone()
Copy link
Member

@pradyunsg pradyunsg May 21, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should use the utc timezone here, unconditionally. That's what we'll be comparing against coming out of PyPI's responses AFAICT.

@ofek
Copy link
Contributor

ofek commented Jun 11, 2024

Nice to see this happening!

My preference for the name would depend on its anticipated use. Say someone notes the date of successful environment creation or is using VCS metadata and wants to copy/paste. Would they be more or less likely to desire packages that were uploaded on that day?

My instinct would tell me that the inclusion of that date would be more desirable in which case I would prefer --exclude-newer-than. However, most people work in the morning and therefore it's possible a breaking change gets released in the evening or in a time zone further west. In that situation, the user would most certainly want to exclude that date in which case I would prefer --uploaded-before.

The former seems more intuitive but I just wanted to write down my thoughts 😄

@ichard26 ichard26 added this to the 25.0 milestone Nov 3, 2024
@ichard26 ichard26 removed this from the 25.0 milestone Dec 27, 2024
@notatallshaw
Copy link
Member

notatallshaw commented Jun 27, 2025

This PR code has rotted a little, @uranusjr are you still interested in finishing this off?

Seems most the discussion was just on the name bike shedding, which I don't have any strong opinions on. Was there a non-objectionable choice? --exclude-newer-than? I also don't think compatibility uv names is important for pip here, uv can always rename or add an alias if it's important for them.

@ichard26 ichard26 added the state: up for grabs (PR) Good idea, but needs a new champion as the PR author is busy or unreachable. label Jul 7, 2025
@notatallshaw
Copy link
Member

Created a new PR #13520 based on this branch.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

state: up for grabs (PR) Good idea, but needs a new champion as the PR author is busy or unreachable.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Install packages up to a certain date

6 participants