-
Notifications
You must be signed in to change notification settings - Fork 72
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Optionally don't redownload/reinstall a file if it exists #984
Comments
I think this is a good idea overall :-) I don't see it being quite as straightforward to implement as we may hope, at least not in a way that's generic for most (any?) downloaded file. The place you've suggested, in
ReShade may already have this check, to some extent, but on the DLLs themselves. I think it does redownload ReShade but it won't reinstall if the version doesn't need an update. I believe this was the cause of auto update ReShade not working if ReShade Addon was used, but I might be remembering wrong. SpecialK does not check at all though to my understanding.
Users can still remove the files manually in the meantime, but this could be a good convenience factor. I tried to write out my implementation concerns, but honestly, I just have no idea if any of the proposed ideas would in all scenarios. I think it starts off ok, for archive names we can tell wget not to download if the file already exists. When the file already exists and has a fixed name though, a timestamp check might be a little bit... unreliable? I guess even if the archive created/updated time are not tracked properly on downloaded files, there shouldn't really be a case where the downloaded files have a mismatch, as newer files would always be newer than the time they were downloaded at, otherwise the newer file would've been downloaded in the first place. My thoughts on this overall are: I'm all for this change if it can be done, and if you're willing to work on it absolutely go for it and I'll try to help however I can, though I would also say that I'm glad I'm not the one attempting this 😅 Thanks for taking the initiative on this one. For implementation, feel free to start with trying this out for one tool initially. You could pick SpecialK if you wanted. I guess the steps would be:
We would have to be careful for this network timestamp check though. It's very important that it's a toggle, in case for other tools (i.e. x64dbg) a user manually places an archive, which could be newer if just placed than the one from the download link. It would be pretty awesome if you could do this, I think I would end up bashing my head against the keyboard trying to figure this one out. You've already done a great deal of investigation work and seem to have a reasonable idea of where to go from here, which is a lot further than I would've gotten I think. Thank you for considering this :-) |
If all else fails, we could potentially try to implement some way to compare files using an md5 hash check, with that and all of the following behind the toggle you mentioned. If we have to, we could download the existing file under a different name (change We could also, in theory, check the files in the archive before extracting them to see if they are actually different, either with a version check like we do for ReShade or with a checksum like above. This and the above are less reliable I think because they don't necessarily tell you whether the file is newer or older, just if they are different in some way. Although this would still handle the corruption case, it would not handle the case where an archive may have been downloaded elsewhere even if it is more or less the same, i.e. it might contain different a couple of extra files. And both of these would be a last resort, since it means we'd download the archives anyway, we just wouldn't use them if the version did not match. Also, I alluded to this with very rough my SpecialK implementation outline, but this check no matter how we implement it will only work if the archive is already present for us to compare against. That's not necessarily an issue but it may require a change in behaviour when implementing this, like we'd need for SpecialK. |
No promises this will turn into a proper PR that can be merged, but I at least want to get the research and at least try to implement this Maybe I pave the way for someone else to pick up where I left off, or maybe I teach someone how to not do this lol. I am actually surprised by how many a simple tools like Just out of curiosity, do you prefer we stick to maybe one of those tools can compare checksums with the remote file or something? Another research topic for latter I guess ( I honestly have no clue lol) |
Yup, there is no hurry with this, and I want to reiterate again that I'm very glad you're even considering looking at this. Anything we discuss here will not go to waste, as it'll either serve as a reference for why this was not implemented, or just like you said, it'll be a springboard for someone else.
Honestly, not really 😅 I have no particular attachment. If SteamOS has curl, and if it makes anything easier I'd say go for it. I'm fairly sure it does though and I think the SteamGridDB stuff uses curl. If there's something else you want to use, try to keep it "light" if at all possible, in that it has few dependencies, or the dependencies are things we already have or reasonable things to expect most systems to have. Ideally, a new dependency would be something that can have its binary dragged and dropped into the STL deps folder on SteamOS. We'd also have to be mindful of downstream packages for STL and how it may impact them. Having said all that, I really doubt we're going to end up in territory like that. Curl is pretty much everywhere and is lighter than some of our other dependcies, I have no issue if you can use that to do the job better. The above is in case you find some external dependency that makes this a billion times easier, we'll have to evaluate it a little 🙂 Honestly, I'm just very happy someone else is interested in contributing :-) But there's no time pressure on this, it's not massively critical or anything, so don't feel like you have to rush. And of course let me know if you need help with anything! |
So to recap this ticket:
|
Yeah I think that would make the most sense probably in misc options above reset log is where I would put it
I belive there is a function that handles and the downloading with wget if I remember correctly in the code (it been a while since I looked at it 😅 ) I believe I got as far creating a config variable for the toggle in yad and adding a conditional into the wget function to add the EDIT: NVM there is no generic download function. I was testing on this https://github.com/sonic2kk/steamtinkerlaunch/blob/dd9cd5343e02985b10cd4a397d66a9fd21847cba/steamtinkerlaunch#L15628 which is called every time we want to get the latest version from GitHub |
There is a generic download function but there is a variable for |
System Information
As was discussed previously
It may be beneficial (though in many cases negligible, to be honest) to only download updates to specific tools like SpecialK when there is an update.
I want to use this issue to brainstorm ideas for my possible PR.
Doing a bit of googling, I found it is possible to tell Wget not to download a file if it already exists.
https://www.reddit.com/r/wget/comments/34nxry/will_wget_overwrite_files_if_theyre_already/
so, in theory, could we not add the option
-nc
tosteamtinkerlaunch/steamtinkerlaunch
Line 824 in ca5f569
That way, steamtinkerlaunch will not redownload already existing files.
This should be a toggle, with the default behavior being to overwrite files.
The reasoning is overwriting files can be helpful if the file gets corrupted, and usually, these downloads are only a few MB anyway.
The other half of this would be not to install tools like Reshade or Specialk if the version installed is already up to date
This should probably be a separate PR, and you can use this: https://github.com/sonic2kk/steamtinkerlaunch/wiki/PEV-PE32-file-analysis.
Let me know if I misunderstood anything or if this is a horrible idea lol 😅
EDIT:
One glaring flaw I should have thought through, what if the filename in the download link is always the same?
For example,
myexample.com/myfile.zip
is always the latest version ofmyfile.zip
?in the case of specialk nightlys this is not a problem I think as the redirected URL will always have the version in the URL
EDIT2:
seems we can use the
-N
option which seems to check the timestamp of the remote file vs the localhttps://stackoverflow.com/a/16840827
The text was updated successfully, but these errors were encountered: