webpro-nl/knip

๐Ÿ’ก Support https://webpack.js.org/plugins/provide-plugin/

tryggvigy opened this issue ยท 4 comments

Suggest an idea for this project

I wonder if we could support ProvidePlugin somehow. I see

references it but it's not listed as an issue. I found that in our project when buffer is in package.json and

    new ProvidePlugin({
      process: 'process/browser',
      Buffer: ['buffer', 'Buffer'],
    }),

is defined in a webpack config, buffer gets listed as a unused dependency

In the webpack plugin, is there any way to find this in localConfig or resolvedConfig? That's the resolved exported value of the webpack config file (e.g. your webpack.config.js).

Right, good call. No, I don't think there is a way through the config value.

When I log resolvedConfig.plugins out in src/plugins/webpack/index.ts and run the webpack test I get

[ MiniCssExtractPlugin {}, ProvidePlugin {}, CopyWebpackPlugin {} ]

not sure what I'm looking at. At first I thought it was instances of these plugins, so basically an instance of https://github.com/webpack/webpack/blob/96c543c0a976e7d0a2dadd8ff0d6525f99bc3417/lib/ProvidePlugin.js#L25
but it doesn't seem to be since I can't access this.definitions and I thought to myself: "that makes sense, Knip is not actually executing the webpack config, that might have all kinds of side-effects".

So I guess the plugins are just opaque named empty objects/classes or something?

Hoping my hunch is right.

This seems hard to solve with the current plugin API interface where you get a resolved config (which is a really nice api). The plugin would need access to the AST or raw string contents of the file to parse out this ProvidePlugin dependency

Knip is not actually executing the webpack config

So I guess the plugins are just opaque named empty objects/classes or something?

Knip loads and executes files like webpack.config.ts, but nothing else (i.e. it does not call functions or instantiate classes). Whatever that config file exports is handed over as the first argument in resolveConfig(localConfig).

The plugin would need access to the AST

Exactly, this has been on my mind for a while (I should add this to the list: https://knip.dev/reference/faq#why-doesnt-knip-have). But so far, the need has surfaced only rarely and it would mean opening up a new API surface area I'm currently not too fond of.

Yeah I completely agree. That type of API is bloated. Maybe there could be some sane way to solve this (or maybe not), but rushing an API for it is not a good idea.