- 
                Notifications
    You must be signed in to change notification settings 
- Fork 984
Add an entry to the installed programs on windows #2670
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
Conversation
| I have a few questions about how this should be implemented: 
 | 
| Taking your questions in order: 
 Ideally we'd get someone who actually uses Windows seriously, rather than treats it like a toy OS (me), to weigh in with some understanding of how people expect this kind of thing to present itself. Otherwise we're just going to be speculating as to what might be best, without being informed. Thank you for your work thus-far. | 
| About 1. and 2., I think it makes sense to call these functions in  
 About 4., I was mainly thinking about testing rustup while developing it and in the test suite. On Windows most programs just uninstall any previous version before installing themselves. I'm for adding uninstall information only if it doesn't already contain valid ones and only remove it if it points to the installation we're removing. I think rustup uninstall RUSTUP_HOME regardless of where is the called installation. Is this correct ? | 
| Sorry it has taken so long to get back to you on this one.  I'm struggling to cope with the fact that Windows is making us conflate global and local configuration to some extent.   | 
| I also think that it is not really needed nor useful to have multiple entries in the registry when there is multiple installations. IMO there should be one "main" installation in the registry, the one that was installed first and that's called when  | 
| So only set the uninstall in the registry if  | 
| I didn't implemented it that way, but I can do it so. What is currently implemented is: 
 And on uninstall, only remove the registry's entry if it points to the currently running executable. Is it better to check the state of env variables or that of the registry ? | 
| I'm afraid I'm not very good at reasoning out what a Windows user would expect here. @rbtcollins Do you happen to have any insight which might help? | 
        
          
                src/cli/self_update/windows.rs
              
                Outdated
          
        
      | use std::path::PathBuf; | ||
|  | ||
| let key = RegKey::predef(HKEY_CURRENT_USER) | ||
| .create_subkey(r"Software\Microsoft\Windows\CurrentVersion\Uninstall\rustup") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be Rustup, not rustup, as the project name is capitalised.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You're talking about the registry path, right ? What about the text displayed in the list of installed programs (rustup - Rust toolchain manager or Rustup - Rust toolchain manager)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
By the way, I can't see any place where the project name is capitalised.
rustup.rs:
rustup is an installer for...
rustup is an official Rust project.
README.md:
rustup: the Rust toolchain installer
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rustup please. We discussed this on discord prior to my saying this in the review; I realise the prior art in the repo may be inconsistent.
        
          
                src/cli/self_update/windows.rs
              
                Outdated
          
        
      | let mut path = utils::cargo_home()?; | ||
| path.push("bin\rustup.exe"); | ||
| let mut uninstall_cmd = path.into_os_string(); | ||
| uninstall_cmd.push(" self uninstall"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This doesn't seem to correctly quote the path if the home directory contains spaces. I'm not sure if we can use a REG_MULTI_SZ here? That would be better.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
REG_MULTI_SZ only use the first string as if it was a REG_SZ, so it doesn't help here. Quoting the path should work.
        
          
                src/cli/self_update/windows.rs
              
                Outdated
          
        
      |  | ||
| let root = RegKey::predef(HKEY_CURRENT_USER); | ||
|  | ||
| let key = match root.open_subkey(r"Software\Microsoft\Windows\CurrentVersion\Uninstall\rustup") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lets factor this out into a const or static
        
          
                src/cli/self_update/windows.rs
              
                Outdated
          
        
      | { | ||
| Ok(key) => key, | ||
| Err(ref e) if e.kind() == io::ErrorKind::NotFound => return Ok(()), | ||
| Err(e) => return Err(e).chain_err(|| ErrorKind::PermissionDenied), | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
error folding...
        
          
                src/cli/self_update/windows.rs
              
                Outdated
          
        
      | Err(e) => return Err(e).chain_err(|| ErrorKind::PermissionDenied), | ||
| }; | ||
|  | ||
| // Don't remove uninstall information from another installation | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should remove this: if someone has moved their homedir around for whatever reason, this logic will make it impossible to remove the entry from their programs list - and thats super annoying.
OTOH removing an entry thats not for a parallel install done using CARGO_HOME + RUSTUP_HOME variables, is somewhat harmless, since the user can still use rustup, and still uninstall directly, as long as we document that.
| @kinnison review done. rustup cannot be installed multiple times today. Well, not meaningfully. You just think it can :P. The PATH behaviour really means that rustup is only installed once: the first entry on the path wins, and anything else loses. Some Windows programs both add themselves to the registry PATH and offer a batch script to add themselves to the process environment block PATH by spawning a command shell, setting the variables and dropping the user into it, thus allowing the user to work around the PATH first-wins issue. So someone setting custom CARGO_HOME and RUSTUP_HOME - both on Windows and elsewhere - really is taking responsibility for managing the definition of installed, and I think our best bet is just to ignore that. | 
b2f0285    to
    3363086      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Once you've done this change please rebase - we don't want the incremental changes that lead the PR, just the clear set of changes.
        
          
                src/cli/self_update.rs
              
                Outdated
          
        
      | do_write_env_files()?; | ||
|  | ||
| if !opts.no_modify_path { | ||
| do_add_to_path()?; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the add to programs should be done first, before adding to path.
| .chain_err(|| ErrorKind::PermissionDenied)? | ||
| .0; | ||
|  | ||
| // Don't overwrite registry if Rustup is already installed | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not certain this is right, but for now lets leave it. I think it might be more that we want to determine default RUSTUP_HOME being overridden etc, and otherwise we should be writing the current correct value into the registry each time.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What would be the "current correct value"? As someone who overrides RUSTUP_HOME and use temporary installs of rustup in parallel of the standard one, I wouldn't want those temporary installs to replace the standard one in the registry.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A later install wont override a previous one, as long as the previous install is still installed.
However when uninstalling, the registry key will be unconditionally removed, and then recreated on the next install. See #2670 (comment)
By the way, any rustup self uninstall will unistall rustup in the current RUSTUP_HOME, regardless of where the executable you're running is.
Fixes #1618