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

plugin 依赖安装的问题 #36

Open
JerrysShan opened this issue Apr 19, 2022 · 4 comments
Open

plugin 依赖安装的问题 #36

JerrysShan opened this issue Apr 19, 2022 · 4 comments

Comments

@JerrysShan
Copy link
Collaborator

假设 plugin A 依赖了plugin B,plugin B 插件依赖了plugin C。用户需要在项目里面同时安装 A,B,C,用户怎么感知我要安装这些插件?

对用户来说,可能需要去看 A 的文档,知道我需要安装 B ; 然后再看 B 的文档,才知道我还需要安装 C,这样的体验不是太友好

@DuanPengfei
Copy link
Collaborator

能想到两个思路,一个是为用户提供更便捷的获取方式,比如通过 cli 添加 plugin 的依赖而不是直接改文件,这样更可控也更方便我们帮助他处理。这个思路最终还是体现在了代码上,不会黑盒,用户也能看到代码的 diff。

第二个思路是用户只需配置直接依赖的,由构建期去处理,这样会比较黑盒,Egg 好像就是这样的方式 @hyj1991 可以给点建议。

@JerrysShan
Copy link
Collaborator Author

能想到两个思路,一个是为用户提供更便捷的获取方式,比如通过 cli 添加 plugin 的依赖而不是直接改文件,这样更可控也更方便我们帮助他处理。这个思路最终还是体现在了代码上,不会黑盒,用户也能看到代码的 diff。

通过 cli 处理依赖的方式,cli 里面需要预先识别用户所使用的包管理器以及要动态修改用户的plugin 配置文件

@DuanPengfei
Copy link
Collaborator

能想到两个思路,一个是为用户提供更便捷的获取方式,比如通过 cli 添加 plugin 的依赖而不是直接改文件,这样更可控也更方便我们帮助他处理。这个思路最终还是体现在了代码上,不会黑盒,用户也能看到代码的 diff。

通过 cli 处理依赖的方式,cli 里面需要预先识别用户所使用的包管理器以及要动态修改用户的plugin 配置文件

是的,这样 cli 就也要做扫描计算的工作,感觉如果朝这个方向发展,那个插件的扫描、依赖计算的功能应该独立出来,有几个地方都要用到了。

这个方式虽然用户感知到很多东西,我理解从清晰度角度看比黑盒好一些,可以再讨论看看,如果没有什么更好的方案时我们可以尝试一下通过 cli 做,然后自己吃一波狗粮看看体验怎么样。

@Beace
Copy link
Collaborator

Beace commented Apr 20, 2022

能想到两个思路,一个是为用户提供更便捷的获取方式,比如通过 cli 添加 plugin 的依赖而不是直接改文件,这样更可控也更方便我们帮助他处理。这个思路最终还是体现在了代码上,不会黑盒,用户也能看到代码的 diff。

通过 cli 处理依赖的方式,cli 里面需要预先识别用户所使用的包管理器以及要动态修改用户的plugin 配置文件

兼容主流的包管理器,其他框架冷启动阶段做好提示用户应该也可以接受

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants