omf-sdk
omf-sdk copied to clipboard
Can't find installed candidates in fish
I have no idea if this could be related to omf-sdk, but I'm at a loss here. I can find candidates in zsh, but in fish sdkman is unaware of them. Same user.
The shell with syntax highlighting is fish:
data:image/s3,"s3://crabby-images/9da84/9da84b360efdada50417366d874a72edb05f532e" alt="Screen Shot 2021-02-04 at 16 52 52"
data:image/s3,"s3://crabby-images/dd82b/dd82b9ceb9200c61af6e0cc0ac838d9016af34b7" alt="Screen Shot 2021-02-04 at 16 57 18"
data:image/s3,"s3://crabby-images/8a33d/8a33df0c54437df56f756dda25f176a44ac75143" alt="Screen Shot 2021-02-04 at 16 54 32"
I can't link candidates in fish either. It says "Invalid path" even though it's not malformed and sdk in zsh accepted it:
data:image/s3,"s3://crabby-images/5a0ee/5a0eed1f21d8871271f4f11950a23b724db22d3f" alt="Screen Shot 2021-02-04 at 17 03 33"
TL; DR: SDKMAN_DIR must be defined in bash. This is what my sdk.fish
does now:
bash -c "SDKMAN_DIR=$sdkman_prefix && source $sdkman_prefix/bin/sdkman-init.sh && sdk $argv"
data:image/s3,"s3://crabby-images/4393c/4393c67d4558724e1904e28e12acd51f34e30f74" alt="Screen Shot 2021-02-04 at 20 42 36"
data:image/s3,"s3://crabby-images/92b9e/92b9eb01d802b3255a960e14e13ec3d94877cc89" alt="Screen Shot 2021-02-04 at 20 57 41"
@deather, would you be open to a PR with this change?
This comment gave me the clue. Since the bash omf-sdk starts (sdk.fish) is not a login shell, it doesn't run any of the profile scripts which would set SDKMAN_DIR
. It doesn't have any of the variables I set in fish either.
I don't really understand why sdkman behaves like this if SDKMAN_DIR
isn't set though, since what I have set is actually the default location, or why this solved the "Invalid path" problem.
Hi @gabrielfeo,
Thanks to take the time to post the bug. Normally that is the init.fish
which set the SDKMAN_DIR
automatically. The only thing that I see why this variable is not set, it is due to fenv
is missing.
- Can you check first if
fenv
is installed with this commandtype fenv
or checking if the folder.local/share/omf/pkg/
exists ? - Can you post the result of
env | grep SDK
in fish andbash -c "env" | grep SDK
?
We don't use the bash as login shell (-l option if I understood). I want to understand where is the problem before create the PR.
Thank you for your help. SDKMAN_DIR is indeed defined:
data:image/s3,"s3://crabby-images/91a72/91a72731cccc0595550833a1bd19558902047e82" alt="Screen Shot 2021-02-05 at 19 21 53"
data:image/s3,"s3://crabby-images/4d714/4d714d4f01900b6b222b654658b38199835334cf" alt="Screen Shot 2021-02-05 at 19 37 13"
data:image/s3,"s3://crabby-images/cd1e9/cd1e974d07248d8ee410496d4d651de4d5bf36cb" alt="Screen Shot 2021-02-05 at 19 37 26"
I have a lot to learn about shells. I'd appreciate it if you could confirm if I got this right.
-
SDKMAN_DIR
will get passed down tobash
because you export it -
fenv
makes sure when sdkman changes JAVA_HOME from withinbash
, the change gets passed up tofish
Back to the problem, I now have no clue as to why re-defining the variable solves the issue:
data:image/s3,"s3://crabby-images/3f62f/3f62f3904d2dbc8ad050bb4f439a2e8b4f90a3d6" alt="Screen Shot 2021-02-05 at 19 35 56"
Your understanding is good about fenv, and export. If you read man set
you will find more information about the option. The trick you purposed is to define SDKMAN_DIR
for one session of bash.
The only thing we don't check is the .bash_profile
and the .bashrc
. Wen you use bash
it loads automatically some files like these two.
- Can you try
bash --norc --noprofile -c "source $sdkman_prefix/bin/sdkman-init.sh && sdk l java | grep '>>>'"
? - Can you paste the content of the
.bashrc
file ?
Here are the outputs of those commands. I don't have a .bashrc
. I do have a .bash_profile
, but it's probably irrelevant because it's not run in a non-login shell, according to this doc.
data:image/s3,"s3://crabby-images/f6f63/f6f6339c29956e6ce233f865ffaf1d785288bcc8" alt="Screen Shot 2021-02-08 at 17 43 28"
I just setup fish, omf and omf-sdk on another Mac to test this, and I had no issues. It's probably something local, maybe due to my home directory on this machine being in a non-standard location.
When you said your home directory is not standard, you have redefined it with these kind of command https://stackoverflow.com/a/26427748/1595433 ? or you just change the $HOME
variable ?
Can you give me the output of bash -c "echo $HOME"
, bash -c "echo ~"
and bash -c "ls -la ~ | grep .sdkman"
?
I moved my home directory using macOS's System Preferences:
data:image/s3,"s3://crabby-images/0d69a/0d69a2ee0dbaf93214060b9976174cd8cf66ce02" alt="Screen Shot 2021-02-15 at 20 26 40"
data:image/s3,"s3://crabby-images/330d8/330d8e1061a2687f232d17ae7f62c2efaf00e9fd" alt="Screen Shot 2021-02-15 at 20 25 08"