Skip to content

Conversation

@LalitNarayanYadav
Copy link
Contributor

@LalitNarayanYadav LalitNarayanYadav commented Jun 7, 2025

Changes:

  • Removed outdated Grunt-based module bundling instructions from the main "Usage" section.
  • Added updated instructions using npm run build for dev-2.0 and guidance on custom builds via Rollup.
  • Moved legacy Grunt commands into a clearly labeled section with a deprecation warning.

Fixes #7871

PR Checklist

@ksen0
Copy link
Member

ksen0 commented Jun 7, 2025

Hi @LalitNarayanYadav thanks for working on this! To link the PR to an issue, please write: "Fixes #7871" (if the issue should be closed when this PR is merged; otherwise, write "Addresses [issue]"). Thank you!

@ksen0 ksen0 requested a review from perminder-17 June 7, 2025 11:41
@LalitNarayanYadav
Copy link
Contributor Author

Thanks you @ksen0 ! I'll keep it in mind.

Copy link
Collaborator

@perminder-17 perminder-17 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These looks good so far, Really thanks for your awesome work. I'll give another round of review. I just need to ask weather you are confirm with these Spanish docs? I'll review them with translating with google translator and AI since I don't know spanish?

Comment on lines +206 to +207
npx eslint src/
npx eslint test/
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, these commands look promising, and the npm run lint command appears to work correctly. Could you confirm whether changing the code’s indentation causes the linter to fail, or does it still pass? In my case, it always passes regardless of indentation.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The linter isn't implemented in v2+ yet. See #7853

In v1+ it wasn't configured for .md files. So my best bet is to not indent the code snippets.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aah...okay. Thanks for letting me know @error-four-o-four :)

Copy link
Collaborator

@perminder-17 perminder-17 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi, I think we should also update the overview section. Currently it's something like:

An excellent new [feature](https://github.com/processing/p5.js/pull/2051) of p5.js allows user to build p5.js as a custom combination of its modules. This greatly helps in reducing the production version size of the library, as well as improves overall performance..

I think, the PR we link here adds a grunt task which takes in the arguments of modules it want to bundle together. Maybe we could remove/update it.

Comment on lines 17 to 21
cd p5.js
npm ci
npm run grunt
npm run grunt combineModules:module_x:module_y
npm run build # builds the full p5.js bundle
npm test # runs linter and tests using Vitest
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This section is meant to show how to create a custom build of p5.js with selected components. Right now, the commands only build the full library and run the test suite. We should remove the final npm test line and replace it with the command that actually generates a custom bundle. I’m not sure whether the dev-2.0 branch already supports modular builds, @limzykenneth , could you confirm if dev-2.0 lets users assemble p5.js from a chosen set of modules, and if so, what the exact command is?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the suggestion, @perminder-17!

You're right , the current commands don't yet support creating a custom p5.js build with selected modules in dev-2.0. As of now, there's no direct equivalent to grunt combineModules in the dev-2.0 tooling.

I've updated the docs to reflect the available npm run build workflow, and removed the npm test line (since it's not relevant to bundling). Once modular builds are supported in dev-2.0, I’d be happy to help update this section with the correct commands.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In 2.x this feature is still WIP. Theoretically to get it working, a custom app.js needs to be assembled with the required modules the bundled with Rollup as usual. However the module system with ESM and identifying/refactoring module interdependency so we can get a minimal cross platform core is not fully implemented/verified yet.

We can remove this for now without a specific replacement until we have a working implementation, I have a few working ideas behind it that's on my backlog. I don't think anyone is using this feature in 1.x anyway.

Comment on lines 17 to 21
cd p5.js
npm ci
npm run grunt
npm run grunt combineModules:module_x:module_y
npm run build # builds the full p5.js bundle
npm test # runs linter and tests using Vitest
Copy link
Collaborator

@perminder-17 perminder-17 Jun 9, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"runs linter and tests using Vitest" also, this line is misleading. Vitest never “runs the linter”, if you look at the script section, we have two different commands,

"scripts" : {
    "test": "vitest",
    "lint": "eslint .",
},

so, for lint we should write npm run lint, however we can probably remove the commands which is used for running tests in p5js from custom_p5_build.md?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @perminder-17 for the helpful feedback! I've updated the custom_p5_build.md file to:

  • Remove the misleading npm test line
  • Clarify that npm run lint is the correct command for linting

Let me know if there's anything else you'd like me to revise.

@LalitNarayanYadav
Copy link
Contributor Author

Thanks for the review, @perminder-17!

Yes, I did update some Spanish .md files. I verified the changes using both Google Translate and AI-based translation tools to ensure they align with the English versions. However, since I'm not fluent in Spanish, I'd appreciate it if someone with Spanish proficiency could review those sections for accuracy.

Let me know if you’d prefer I flag these specific files for further review.

@ksen0
Copy link
Member

ksen0 commented Sep 16, 2025

Hi @marioguzzzman, could you take a look at the Spanish files here, and sense-check if they are understandable please? If the PR is merged before you have time to get to it, please feel free to make a new PR with your suggestions! Thank you very much.

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

Successfully merging this pull request may close these issues.

Docs: Remove legacy Grunt commands and transition fully to Vitest / npm scripts in dev-2.0

5 participants