Skip to content
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

Get selected version in plugin event handlers #788

Open
Realiserad opened this issue Apr 6, 2024 · 7 comments
Open

Get selected version in plugin event handlers #788

Realiserad opened this issue Apr 6, 2024 · 7 comments
Labels
enhancement New feature or bug fix

Comments

@Realiserad
Copy link

When designing a plugin which can be installed with fisher, you can add event handlers in conf.d which get invoked by fisher when the user installs, updates and removes your plugin.

This is great, and I want to leverage these event handlers to install dependencies for my plugin. However, the version of these dependencies may vary depending on which version of the plugin is being installed, but I cannot see any mechanism in fisher for getting the version of the plugin being installed. For example, if the user runs fisher install some/plugin@v1 I would like to get v1 as an argument somewhere.

Is this possible?

@jorgebucaran
Copy link
Owner

There isn't an automatic way to grab that info right now, but we could make it happen. We can pass the plugin name and tag in the $plugin variable to the install/update event handler as an argument when we're emitting the event here:

if set --local name (string replace --regex -- '.+conf\.d/([^/]+)\.fish$' '$1' $file)
emit {$name}_$event
end

This way the event handler receives the full plugin name and version tag, as its first argument. For example, if you installed jorgebucaran/[email protected], you'd receive exactly that string. You could then string split -- @ to get the version number.

# Defined in flipper/conf.d/flipper.fish

function _flipper_install --on-event flipper_install --argument-names plugin
    switch (string split -- @ $plugin)[2]
        case v1
            ...
    end
end

We can set it up the same way for when you're uninstalling a plugin here:

for name in (string replace --filter --regex -- '.+/conf\.d/([^/]+)\.fish$' '$1' $$plugin_files_var)
emit {$name}_uninstall
end

What you could do is modify Fisher as I've outlined and see if that works for you. I'm open to adding this in. It's a minimal change, and I've been waiting for a good reason to use event parameters more effectively. 👍

@jorgebucaran
Copy link
Owner

You can try it via jorgebucaran/fisher@event-args now.

@Realiserad
Copy link
Author

Realiserad commented Apr 7, 2024

Thanks for the quick and detailed response! 💛

TL;DR It works, but now when I'm thinking about it, would it be possible to invoke fisher list instead?

I patched my local fisher using the diff from your commit and took it for a spin, and it works well! Being used to statically typed languages where method signatures cannot be easily changed, I was worried that it would break backwards compatibility somehow, but that does not seem to be the case (when dereferencing the the $plugin variable on an old fisher installation you just get an empty string).

Considering that plugin developers would have to wait for users to upgrade their version of fisher before they can start using this new feature, maybe a better way would be to simply run fisher list my-plugin in the event handler?

I believe this would achieve the same thing for installs, but for upgrades it looks like the fish_plugins file is updated after the event is emitted, which means that if I run fisher list in the upgrade event handler, I would get the old version of the plugin, not the new version being installed?

@jorgebucaran
Copy link
Owner

Developers would still need to wait, since there is no fisher list plugin either. We actually had something similar in the early days, but it provided limited information mainly because plugins don't carry metadata with them.

Your initial idea seems to align more naturally with automating things, which I think suits our needs better for this context. But, like you said, ensuring all users update to the latest Fisher version takes time.

In the meantime, you might consider traversing the internal $_fisher_plugins array to identify your plugin (maybe you can use contains) and extract the part after the "@" with string split. I'd need to verify that $_fisher_plugins indeed includes the plugin being installed, updated, or uninstalled, but I believe it should.

@Realiserad
Copy link
Author

Developers would still need to wait, since there is no fisher list plugin either.

I'm not sure what you mean by this, since I can run fisher list on my machine and I'm using the latest fisher. This command is also documented in the README.md. Here is an example of how I used fisher list to get the name and version of the plugin being installed.

Anyway, getting the plugin name as an argument would indeed be better, and potentially iron out some weird edge cases (e.g. my code would fail if someone would have two different versions of the plugin installed).

So /lgtm 🙈

@jorgebucaran
Copy link
Owner

I was referring to fisher list my-plugin, which isn't a valid Fisher command. If fisher list alone works for you, then that's fine. 😄

@jorgebucaran jorgebucaran modified the milestone: 5.0 May 24, 2024
@jorgebucaran jorgebucaran removed this from the 5.0 milestone Sep 10, 2024
@jorgebucaran
Copy link
Owner

Quick update. I've removed this issue from the 5.0 milestone because, on second thought, there doesn't seem to be a need for a new major release for this. A minor release should be enough. In hindsight, I was probably being too cautious. I know you might not need this anymore, but I've kind of grown fond of the idea and want to explore it further. This is non-critical, so I'll just keep it open, but I like it.

@jorgebucaran jorgebucaran added the enhancement New feature or bug fix label Sep 10, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or bug fix
Projects
None yet
Development

No branches or pull requests

2 participants