-
-
Notifications
You must be signed in to change notification settings - Fork 1k
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
Fix absolute paths for Cygwin #1970
Changes from 4 commits
63050db
0779f40
b6cd6cc
30f4aeb
05e8a92
75a8a04
a34b438
a27fe8b
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -47,6 +47,11 @@ deactivate () { | |
deactivate nondestructive | ||
|
||
VIRTUAL_ENV='__VIRTUAL_ENV__' | ||
|
||
if [ "$OSTYPE" = "cygwin" ]; then | ||
VIRTUAL_ENV=$(cygpath -u "$VIRTUAL_ENV") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. we should validate that cygpath is an existing command, and ignore if it fails 🤔 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I've tested the updated code on cygwin & msys, and it works for both. I've added the check to make sure cygpath exists before we invoke it. Do you mean that we should also ignore the error if invoking cygpath fails? I think we probably want to fail the operation in that case, don't we, since the virtualenv isn't going to work? |
||
fi | ||
|
||
export VIRTUAL_ENV | ||
|
||
_OLD_VIRTUAL_PATH="$PATH" | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -34,7 +34,7 @@ def generate(self, creator): | |
|
||
def replacements(self, creator, dest_folder): | ||
current_platform = sysconfig.get_platform() | ||
platforms = ["mingw", "cygwin", "msys"] | ||
platforms = ["mingw", "msys"] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I can remove this section of code entirely if you prefer, just wondered if this would be safer. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I mean someone needs to check if mings, msys works same/different, and if is there a cygpath there. There're also tests you need to ammend/remove. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I download MinGW/MSYS -- as I understand it, MSYS is an environment built on top of the MinGW tools (http://www.mingw.org/wiki/MSYS). The string that gets returned from Running it locally, it seems that MSYS wants paths in the form
So I think the current implementation is good for MSYS/MinGW. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would suffer though from the same problem as cygwin does. Does msys has it's own variant of cygpath that we should be using to offer same guarantees we're offering for cygwin? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. https://stackoverflow.com/a/12063651 has some detailed answer to this There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 👍 I can confirm that MSYS has cygpath, so we can approach it in the same way. |
||
if any(platform in current_platform for platform in platforms): | ||
pattern = re.compile("^([A-Za-z]):(.*)") | ||
match = pattern.match(str(creator.dest)) | ||
|
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.
No need for this empty line 👍