-
-
Notifications
You must be signed in to change notification settings - Fork 23
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
Fish support (closes #8, closes #27) #65
Conversation
Ooh, exciting! At first glance this looks very clean, well done. I'll try to do a detailed review in the near future (next few weeks at work are unfortunately crunch time), but in general I think combining this with figuring out #57 will make for a good v0.5.0 milestone target.
I'm not too worried about that, now that I have a vscode devcontainer setup (de534d9 ) it should be easy enough to add fish binary to it. I may eventually extract that to a generic Docker container for running integration tests to make life easier for folks who don't use vscode as well. |
I'm not that familiar with vscode's devcontainers, but have added fish to the dockerfile - seems to work ok... |
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.
Nice. I'm really impressed with the clean CI integration too. Some initial review comments on minor implementation details.
The other primary thing I'd like to discuss is scmpuff init -s --shell=fish
feels a bit unwieldy from a UX perspective. Thinking out loud here, but what do you think of deprecating the old -s, --show
entirely, and replacing it with this new -s, --shell
. The default flag value could remain sh, so it would remain reverse compatible for anyone with a scmpuff init -s
flag in their bash profile or whatnot.
The one old use case this would break (I believe) would be anyone using the long form --show
, but I think we could still preserve that without breakage even by making a deprecated --show
Flag pointing to the same function, and marking it Hidden
so it doesn't show up in help.
What do you think?
Sounds good, I'll update it. I'd wondered about making it default to guessing the value from |
... I've actually found the Deprecating // --show (deprecated in favor of --shell)
InitCmd.Flags().BoolVar(
&outputScript,
"show", false,
"Output scmpuff initialization scripts",
)
InitCmd.Flags().MarkHidden("show") But I've been trying to implement the // --shell
InitCmd.Flags().StringVarP(
&shellType,
"shell", "s", "",
"Set shell type - 'sh' (for bash/zsh), or 'fish'",
)
InitCmd.Flag("shell").NoOptDefVal = "sh" NoOptDefVal is necessary to allow the arg-less I've added |
Weird bug. (Additionally, your idea of parsing |
Okay, I tried cleaning up the help string a bit in 963104b to try to make the setup instructions show up in more places. Play around with it and let me know how it feels to you. With this, I think it may be acceptable to live with the error condition if someone omits the |
Yep, looks good to me |
Okay, I refactored the script collection handling a little bit to make it more robust for the future, automatically lowercase the passed shell name (to make it match easier in case someone is outputting from something strange), and added a rudimentary default shell detection based on your idea (we should probably still prompt folks to manually specify in the setup instructions, but I think having this detection makes the simple I'm also going to merge #64 and update the version of Cobra, and rebase so we can do manual verification on the most recent version. Take a look and play around with it and see if I broke anything. I'm also curious if we are missing anything in the UX/documentation that could make things clearer for folks. |
To use, append `scmpuff init -s --shell=fish | source` to your `~/.config/fish/config.fish` file. Fish scripts are based on https://github.com/arbelt/fish-plugin-scmpuff
The entire directory *should* be ignored in our settings, but it doesnt seem to be picking up, so manually ignoring the one rule for now.
With the stricter code-signing requirements on M1 macs, `cp`ing the binary exposes a bug in Apple code-signing where trying to execute the resulting binary immediately exits with "Killed: 9" By rm-ing then cp-ing, the destination file gets a new inode number and avoids this problem. https://developer.apple.com/documentation/security/updating_mac_software
Looks good. I did run into some problems with |
Having used SCM Breeze for years and recently switching to Fish shell, I'm keeping a close eye on this. I'm using shinriyo/breeze but found enough differences from SCM Breeze that I would like to try an alternative. I like the philosophy of scmpuff and will happily try this out and provide feedback once merged. Thanks! |
Wow, that's bizarre. I don't have a M1 Mac yet so this was good to learn! (I think it's fine to bundle in this PR). |
Thanks @euoia. I think this is ready to be merged soon, I hopefully will try to find some time this coming weekend. Past that point, I think it would be good to wrap up #57 and then cut a new major version release. (@euoia if you let me know your OS and architecture, I can also build a pre-release snapshot binary for you if you'd like to test in advance.) |
MacOS Monterey, Intel. Thanks! |
@euoia snapshot binary attached: scmpuff_v0.4.0-next_macOS_x64.tar.gz |
@mroth thanks! Testing as of this morning, everything seems great so far. I noticed you didn't alias |
This adds fish support via
scmpuff init -s --shell=fish
. The fish scripts are based on work done by https://github.com/arbelt/fish-plugin-scmpuff, though I've tweaked them to better match the regular scmpuff behaviour.One downside is that it means you'll get failing feature-tests unless you have fish installed. I couldn't spot a clean way of skipping the fish examples, but let me know if you think that's important.