-
-
Notifications
You must be signed in to change notification settings - Fork 595
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
[Feature]: Support circular-dependency-plugin #6048
Comments
We're not intended to expose complex data structures like |
this proved to be a very important plugin in webpack recently i faced a issue because of circular dependency which took lot of time will be good to have feature in rspack also |
this plugin can actually be implemented using stats.json,someone want to give it a try? |
I implemented a very basic version using the stats at https://github.com/kialo/rspack-circular-dependency-plugin. For our use case it works, but note that the tests that came with the original plugin do not pass, as I haven't found the time to fix them yet. Therefore it also doesn't have an official release. I'm happy to take contributions. |
thanks @ska-kialo worked for me but was returning ids instead of readable names/path extracted modulesById[currentModule].name and resonModule.name working as expected now |
@saifislamrepos ah yes, I assume you're running in production mode? I hadn't considered that when implementing it. |
@ska-kialo yes as in production it takes moduleids as deterministic i guess |
this will cause performance issue for rspack and we suggest do this check in lint tools like eslint | biome |
I disagree with this choice. The bundler is what actually generates runtime code, and therefore, is the safest and most accurate place to check for cycles—which can cause crashes. Additionally, how will it harm performance? Checking for cycles is O(V+E), so will scale ~roughly linearly in practice with the number of modules. If one throws a quick check after module resolution and before prod bundling, will that really take that much time? I would ask that y'all reconsider this :) I think it would be valuable and can be done performantly. |
if it's implemented in rust side it could be done performantly, but if it need to be done in js side it will cause huge module graph communication which will hurt performance |
Ah, I see. I think the general question of "should we support cyclic dependency checking" is worth considering. Would the rspack team be open to that being a feature of rspack, even though it is not one of webpack? Or would the recommendation be to build this as a rust-based plugin ourselves? (For more clarity: we at Discord really want cycle checking). |
we will reconsider what is the best way to do it |
This issue has been automatically marked as stale because it has not had recent activity. If this issue is still affecting you, please leave any comment (for example, "bump"). We are sorry that we haven't been able to prioritize it yet. If you have any new additional information, please include it with your comment! |
Yes. |
+1 |
What problem does this feature solve?
While the
optimizeModules
hook was added in #2758 to support circular-dependency-plugin. TheModule
interface does not include thedependencies
property the plugin uses to iterate through the dependencies of the module. Additionally theCompilation
interface does not include themoduleGraph
property the plugin uses.What does the proposed API of configuration look like?
The plugin uses the following properties:
Module.dependencies
: in Webpack this is an array ofHarmonyImportSideEffectDependency
Module.debugId
: a numberCompilation.moduleGraph.getModule(dependency: HarmonyImportSideEffectDependency): Module
: a method on the module graph that resolves a dependency to itsModule
The text was updated successfully, but these errors were encountered: