Home  >  Article  >  Web Front-end  >  rollup-plugin-analyzer usage in trpc scripts

rollup-plugin-analyzer usage in trpc scripts

Barbara Streisand
Barbara StreisandOriginal
2024-10-26 15:34:30246browse

In the previous article, we provided a mental picture of functions in analyzeSizeChange.ts file, In this article, let’s find out how the actual size change is analyzed.

import analyze from 'rollup-plugin-analyzer';
export default function analyzeSizeChange(packageDir: string) {
 let analyzePluginIterations = 0;
 return analyze({
   summaryOnly: process.env.CI ? undefined : true,
   skipFormatted: process.env.CI ? true : undefined,
   onAnalysis: (analysis) => {
   },
 });
}

analyze is imported from rollup-plugin-analyzer. It’s got an object as param with options:

  1. summaryOnly — Only output bundle summary and module usage bar graphs

  2. skipFormatted — Don’t output formatted string

  3. onAnalysis — Callback to be invoked with analysis object (I copied the below description for onAnalysis from npm:)

function will be invoked with:

- analysisObject (Object)

- bundleSize (Number) — rendered bundle size in bytes

- bundleOrigSize (Number) — original bundle size in bytes

- bundleReduction (Number) — percentage of rendered bundle size reduction

- moduleCount (Number) — Count of all included modules

- modules (Array) — array of module analysis objects

- module (Object)

- id (String) — path of module / rollup module id

- size (Number) — size of rendered module code in bytes

- origSize (Number) — size of module’s original code in bytes

- dependents (Array) — list of dependent module ids / paths

- percent (Number) — percentage of module size relative to entire bundle

- reduction (Number) — percentage of rendered size reduction

- renderedExports (Array) — list of used named exports

- removedExports (Array) — list of unused named exports

Let’s see how many of these options are actually used in analyzeSizeChange file.

- bundleSize

- modules

Just these are found to be used in analyzeSizeChange.ts

But in what circumstances is this script executed? is it after you check in some code? does it report on a pull request? To find that out, we need to go where the code takes us.

You would have to first search for analyzeSizeChange to see where it is used. It is found to be used in script/getRollupConfig.ts

rollup-plugin-analyzer usage in trpc scripts

Next, you would have to find out where getRollupConfig is used. It is used in a lot of packages.

rollup-plugin-analyzer usage in trpc scripts

but I picked packages/client/rollup.config.ts, this rollup config is used in the build script.

"scripts": {
 "build": "rollup - config rollup.config.ts - configPlugin rollup-plugin-swc3",

So the answer, you will have the bundle size changes when you build a package in tRPC source code.

About us:

At Thinkthroo, we study large open source projects and provide architectural guides. We have developed resubale Components, built with tailwind, that you can use in your project. We offer Next.js, React and Node development services.

Book a meeting with us to disucss your project.

rollup-plugin-analyzer usage in trpc scripts

rollup-plugin-analyzer usage in trpc scripts

References:

  1. https://github.com/trpc/trpc/blob/next/scripts/analyzeSizeChange.ts

  2. https://github.com/search?q=repo:trpc/trpc getRollupConfig&type=code

  3. https://github.com/trpc/trpc/blob/3388c9691d122b9d4047b2de0caedcdf611354ab/packages/client/rollup.config.ts#L3

  4. https://github.com/trpc/trpc/blob/3388c9691d122b9d4047b2de0caedcdf611354ab/scripts/getRollupConfig.ts#L9

  5. https://www.npmjs.com/package/rollup-plugin-analyzer#options



The above is the detailed content of rollup-plugin-analyzer usage in trpc scripts. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn