-
-
Notifications
You must be signed in to change notification settings - Fork 1.7k
docs: in v4, strict() is not deprecated
#4298
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
docs: in v4, strict() is not deprecated
#4298
Conversation
|
Important Review skippedAuto reviews are disabled on base/target branches other than the default branch. Please check the settings in the CodeRabbit UI or the You can disable this status message by setting the WalkthroughThis update introduces significant changes to the project's configuration, tooling, and documentation, while removing a large number of files related to testing, benchmarking, and error handling—especially within the Deno environment. The project migrates from Yarn to pnpm as its primary package manager, updates various GitHub Actions workflows, and enhances documentation with new features and improved type annotations. Many configuration and test files are deleted, reflecting a major cleanup and possible shift in testing or build strategy. The Changes
Sequence Diagram(s)sequenceDiagram
participant Dev as Developer
participant VSCode as VSCode/Editor
participant CI as GitHub Actions
participant PNPM as pnpm
participant Changesets as Changesets Tool
Dev->>VSCode: Opens project, uses new settings/launch configs
Dev->>PNPM: Installs dependencies, runs scripts (test, build)
Dev->>Changesets: Manages versioning/publishing with new config
Dev->>CI: Pushes code, triggers updated workflows
CI->>PNPM: Installs dependencies via pnpm
CI->>CI: Runs tests, builds (some steps now disabled/commented)
CI->>Changesets: (On release) uses changeset config for versioning
Poem
🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
SupportNeed help? Create a ticket on our support page for assistance with any issues or questions. Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
✅ Deploy Preview for guileless-rolypoly-866f8a ready!Built without sensitive environment variables
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Caution
Inline review comments failed to post. This is likely due to GitHub's limits when posting large numbers of comments. If you are seeing this consistently it is likely a permissions issue. Please check "Moderation" -> "Code review limits" under your organization settings.
Actionable comments posted: 24
🔭 Outside diff range comments (2)
.github/workflows/release-canary.yml (1)
23-50: 🧹 Nitpick (assertive)Commented-out release steps: You’ve disabled the build/publish steps by commenting them out. If this is temporary, please add a note explaining why; if permanent, consider removing dead code to keep the workflow clean.
README_ZH.md (1)
1250-1256: 🧹 Nitpick (assertive)Ensure consistency in type casting comment
The English comment// cast to z.ZodType<Category>accurately reflects the type hint. Since this is Chinese documentation, consider translating this comment to Chinese or adding a brief note explaining its presence in English.
🛑 Comments failed to post (24)
ERROR_HANDLING.md (3)
188-197: 🛠️ Refactor suggestion
Fix typo in "deafult"
There’s a small typo—“deafult” should be “default”. For example:- To set the deafult error map based on your locale, you can import the error map from the `zod/locales` directory. + To set the default error map based on your locale, you can import the error map from the `zod/locales` directory.📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.## Locales There are locale-specific error maps built into Zod for various languages. To set the default error map based on your locale, you can import the error map from the `zod/locales` directory.🤖 Prompt for AI Agents (early access)
In ERROR_HANDLING.md around lines 188 to 197, fix the typo by changing the word "deafult" to "default" in the sentence describing setting the default error map based on locale.
57-57: 🧹 Nitpick (assertive)
Update link target casing & simplify wording
The link[ZodErrorMap](#Customizing-errors-with-ZodErrorMap)may not resolve; use a lowercase fragment and simplify wording. Also change “You are able to pass in” to “You can pass”. For example:-| `params: { [k: string]: any }` <br> This is the error code thrown by refinements… You are able to pass in a `params` object here that is available in your custom error maps (see [ZodErrorMap](#Customizing-errors-with-ZodErrorMap) below for details on error maps) +| `params: { [k: string]: any }` + This is the error code thrown by refinements… You can pass a `params` object here (see [ZodErrorMap](#customizing-errors-with-zoderrormap) below for details)Committable suggestion skipped: line range outside the PR's diff.
🧰 Tools
🪛 LanguageTool
[style] ~57-~57: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...hrow issues of anyZodIssueCode). You are able to pass in aparamsobject here that is ...(BE_ABLE_TO)
🪛 markdownlint-cli2 (0.17.2)
57-57: Inline HTML
Element: br(MD033, no-inline-html)
57-57: Link fragments should be valid
Expected: #customizing-errors-with-zoderrormap; Actual: #Customizing-errors-with-ZodErrorMap(MD051, link-fragments)
🤖 Prompt for AI Agents (early access)
In ERROR_HANDLING.md at line 57, update the link target to use lowercase fragment identifiers to ensure proper resolution, changing `[ZodErrorMap](#Customizing-errors-with-ZodErrorMap)` to `[ZodErrorMap](#customizing-errors-with-zoderrormap)`. Also, simplify the wording by replacing "You are able to pass in" with "You can pass".
45-56: 🧹 Nitpick (assertive)
Replace HTML
<br>tags with Markdown line breaks
Inline HTML in tables is flagged by markdownlint. Consider using two spaces at the end of a line to create a line break instead of<br>. For example:- `expected: ZodParsedType` <br> `received: ZodParsedType` <br><br> + `expected: ZodParsedType` + `received: ZodParsedType` +Apply the same pattern to other rows to eliminate all
<br>elements.Committable suggestion skipped: line range outside the PR's diff.
🧰 Tools
🪛 markdownlint-cli2 (0.17.2)
45-45: Inline HTML
Element: br(MD033, no-inline-html)
45-45: Inline HTML
Element: br(MD033, no-inline-html)
45-45: Inline HTML
Element: br(MD033, no-inline-html)
46-46: Inline HTML
Element: br(MD033, no-inline-html)
46-46: Inline HTML
Element: br(MD033, no-inline-html)
47-47: Inline HTML
Element: br(MD033, no-inline-html)
48-48: Inline HTML
Element: br(MD033, no-inline-html)
49-49: Inline HTML
Element: br(MD033, no-inline-html)
50-50: Inline HTML
Element: br(MD033, no-inline-html)
52-52: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
53-53: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
54-54: Inline HTML
Element: br(MD033, no-inline-html)
55-55: Inline HTML
Element: br(MD033, no-inline-html)
55-55: Inline HTML
Element: br(MD033, no-inline-html)
56-56: Inline HTML
Element: br(MD033, no-inline-html)
56-56: Inline HTML
Element: br(MD033, no-inline-html)
🤖 Prompt for AI Agents (early access)
In ERROR_HANDLING.md between lines 45 and 56, the table uses HTML <br> tags for line breaks, which markdownlint flags as inline HTML. Replace all <br> tags with Markdown line breaks by adding two spaces at the end of the line where a break is needed. Apply this change consistently across all rows in the table to remove all <br> elements..gitignore (1)
9-22: 🧹 Nitpick (assertive)
Update ignore patterns for new outputs: Adding these new build and temp files makes sense. Optionally, you can append a slash to directory patterns for clarity:
-scratch +scratch/ -logos +logos/📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.scratch/ workspace.code-workspace .netlify bun.lockb out.png logos/ .zed dist .tshy .tshy-build packages/tsc-perf tsconfig.vitest-temp.json *.tgz🤖 Prompt for AI Agents (early access)
In the .gitignore file from lines 9 to 22, the new ignore patterns for directories like netlify, logos, dist, .tshy, and .tshy-build should have a trailing slash appended to clearly indicate they are directories. Update these patterns by adding a slash at the end of each directory name to improve clarity and maintain consistency..github/pull_request_template.md (1)
3-3:
⚠️ Potential issueFix typo in PR template: There's a small misspelling (
contribting→contributing) that should be fixed so the template reads smoothly for contributors.-Thanks for contribting to OSS! +Thanks for contributing to OSS!📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.Development of the next major version of Zod (`v4`) is currently underway. During this phase, only bugfixes and documentation improvements are being accepted into the `main` branch. All other PRs should target the `v4` branch. Thanks for contributing to OSS!🤖 Prompt for AI Agents (early access)
In .github/pull_request_template.md at line 3, fix the typo by changing "contribting" to "contributing" to ensure the template reads correctly for contributors..github/workflows/test.yml (1)
25-29: 🧹 Nitpick (assertive)
Consider caching and DevDeps: The pnpm steps look solid. To speed up CI, you might:
- Cache the pnpm store.
- Declare TypeScript in devDependencies instead of running
pnpm addin each job.+ - name: Cache pnpm store + uses: actions/cache@v3 + with: + path: ~/.pnpm-store + key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}Also applies to: 42-45
🤖 Prompt for AI Agents (early access)
In .github/workflows/test.yml around lines 25 to 29 and 42 to 45, the workflow installs TypeScript by running `pnpm add` in each job, which slows down CI. To fix this, declare TypeScript as a devDependency in your package.json instead of adding it during the workflow. Additionally, add caching steps for the pnpm store to speed up dependency installation by reusing cached packages across runs..github/workflows/release.yml (1)
22-22: 🧹 Nitpick (assertive)
Remove trailing whitespace ✂️
YAMLlint flagged trailing spaces on blank lines. Trimming these will keep the file clean.Also applies to: 51-51
🧰 Tools
🪛 YAMLlint (1.35.1)
[error] 22-22: trailing spaces
(trailing-spaces)
🤖 Prompt for AI Agents (early access)
In .github/workflows/release.yml at lines 22 and 51, there are trailing whitespace characters on blank lines flagged by YAMLlint. Remove all trailing spaces from these blank lines to ensure the file is clean and adheres to YAML formatting standards.CONTRIBUTING.md (1)
55-57: 🧹 Nitpick (assertive)
Clarify description for
pnpm test:watch📝
The bullet underpnpm test:watchends with “and” and looks incomplete. Consider updating it to something like:- runs all Vitest tests in watch mode🤖 Prompt for AI Agents (early access)
In CONTRIBUTING.md around lines 55 to 57, the description for `pnpm test:watch` ends abruptly with "and" making it incomplete. Update the bullet point to a complete sentence such as "runs all Vitest tests in watch mode" to clearly describe the command's behavior..configs/rollup.config.js (2)
12-12: 🧹 Nitpick (assertive)
Enable sourcemaps for debugging 🛠️
Uncomment thesourcemap: trueoption so you can trace runtime errors back to your original TS sources.🤖 Prompt for AI Agents (early access)
In .configs/rollup.config.js at line 12, uncomment the line setting sourcemap: true to enable sourcemaps. This will allow tracing runtime errors back to the original TypeScript source files for easier debugging.
15-15: 🧹 Nitpick (assertive)
Specify file extensions in
@rollup/plugin-node-resolve📦
To ensure TypeScript (and other) files are resolved properly, consider:resolve({ extensions: ['.mjs', '.js', '.jsx', '.ts', '.tsx'] })🤖 Prompt for AI Agents (early access)
In .configs/rollup.config.js at line 15, the resolve() plugin is used without specifying file extensions, which may cause issues resolving TypeScript and other files. Update the resolve() call to include an extensions array with ['.mjs', '.js', '.jsx', '.ts', '.tsx'] to ensure proper resolution of these file types..github/workflows/release-beta.yaml (3)
21-21: 🧹 Nitpick (assertive)
Trim trailing whitespace ✂️
YAMLlint points out extra spaces on blank lines—removing them keeps CI configs tidy.Also applies to: 26-26, 32-32
🧰 Tools
🪛 YAMLlint (1.35.1)
[error] 21-21: trailing spaces
(trailing-spaces)
🤖 Prompt for AI Agents (early access)
In .github/workflows/release-beta.yaml at lines 21, 26, and 32, remove any trailing whitespace on blank lines to comply with YAMLlint standards and keep the CI configuration clean. Ensure these lines contain no spaces or tabs after the line break.
1-1: 🧹 Nitpick (assertive)
Update header comment 🖊️
The top comment reads# .github/release.ymlbut this file isrelease-beta.yaml. Updating it will avoid confusion.🤖 Prompt for AI Agents (early access)
In .github/workflows/release-beta.yaml at line 1, the header comment incorrectly states '# .github/release.yml'. Update this comment to accurately reflect the current file name by changing it to '# .github/release-beta.yaml' to prevent confusion.
25-25: 🧹 Nitpick (assertive)
Pin Node.js version for reproducibility 🔒
Usinglatestcan lead to unexpected changes; consider a specific LTS tag (e.g.,20.xorlts/*) instead.🤖 Prompt for AI Agents (early access)
In .github/workflows/release-beta.yaml at line 25, the Node.js version is set to 'latest', which can cause unpredictable builds. Replace 'latest' with a specific LTS version tag like '20.x' or 'lts/*' to ensure consistent and reproducible workflows..vscode/settings.json (1)
12-17: 🧹 Nitpick (assertive)
Consider adding
files.watcherExclude
Mirroring yourfiles.excludepatterns infiles.watcherExcludecan dramatically reduce file-watcher load in big projects—think about adding**/dist,**/.tshy-build, etc.🤖 Prompt for AI Agents (early access)
In .vscode/settings.json around lines 12 to 17, add a "files.watcherExclude" section that mirrors the patterns in "files.exclude" such as "**/dist" and "**/.tshy-build". This will reduce file-watcher load by excluding these directories from being watched, improving performance in large projects. Ensure the patterns match those in "files.exclude" for consistency.biome.jsonc (2)
61-74: 🧹 Nitpick (assertive)
Consider expanding ignore patterns
Yourfiles.ignoreis solid, but you might also ignore lockfiles (pnpm-lock.yaml),.husky/, or.vscode/if they’re irrelevant to linting.🤖 Prompt for AI Agents (early access)
In biome.jsonc around lines 61 to 74, the files.ignore array should be expanded to include additional patterns such as lockfiles like pnpm-lock.yaml, the .husky/ directory, and the .vscode/ directory. Add these entries to the ignore list to prevent linting on these files and directories that are typically not relevant.
22-36: 🧹 Nitpick (assertive)
Review disabled suspicious/style rules
You’ve turned off a bunch of suspicious (noExplicitAny, etc.) and style (noParameterAssign, etc.) rules—totally fine if you have a good reason, but I’d suggest a short comment explaining why these are off, or consider re-enabling any that guard against real bugs.🤖 Prompt for AI Agents (early access)
In biome.jsonc around lines 22 to 36, you have disabled several suspicious and style rules without explanations. Add brief comments next to each disabled rule explaining the rationale for turning them off, or reconsider enabling any rules that help prevent real bugs to improve code clarity and maintainability..configs/tsconfig.base.json (2)
32-34: 🧹 Nitpick (assertive)
Custom conditions are on point
Adding"@zod/source"will help tree-shaking your different entry points. You might also consider"incremental": trueto speed up ts-compiles if you haven’t already.🤖 Prompt for AI Agents (early access)
In .configs/tsconfig.base.json around lines 32 to 34, the customConditions array correctly includes "@zod/source" for better tree-shaking. To improve TypeScript compile speed, add the "incremental": true option at the same level as "pretty" and "customConditions" in the compilerOptions section.
12-17: 💡 Verification agent
❓ Verification inconclusive
Review
skipLibCheck& unused locals
skipLibCheck: truespeeds up builds but can hide errors in dependency types. Also,noUnusedLocalsis off whilenoUnusedParametersis on—consider flipping both for consistency.
Review skipLibCheck & noUnusedLocals settings
skipLibCheck: truecan mask type errors in your dependencies. Also,noUnusedLocalsis disabled whilenoUnusedParametersis enabled—these should be aligned.• File:
.configs/tsconfig.base.json(lines 12–17)Suggested changes:
.configs/tsconfig.base.json -"skipLibCheck": true, +"skipLibCheck": false, // catch errors in library declarations -"noUnusedLocals": false, // currently off +"noUnusedLocals": true, // match noUnusedParameters📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements."exactOptionalPropertyTypes": true, "skipLibCheck": false, // catch errors in library declarations "forceConsistentCasingInFileNames": true, "noUnusedLocals": true, // match noUnusedParameters "noUnusedParameters": true, "noImplicitAny": true,🤖 Prompt for AI Agents (early access)
In .configs/tsconfig.base.json around lines 12 to 17, the settings for skipLibCheck and noUnusedLocals are inconsistent and may hide errors. Change skipLibCheck to false to ensure type errors in dependencies are caught, and set noUnusedLocals to true to align with noUnusedParameters, enforcing consistent unused code checks.README.md (6)
1505-1515: 🧹 Nitpick (assertive)
Add
.unique()array method
The documentation of the uniqueness feature and itsidentifieroption is clear. It may help to specify the default error message when duplicates are found.🤖 Prompt for AI Agents (early access)
In README.md around lines 1505 to 1515, add the default error message shown when the `.unique()` array method detects duplicates. Update the documentation to include this message so users know what error to expect if uniqueness validation fails, enhancing clarity on the feature's behavior.
656-657: 🧹 Nitpick (assertive)
Add E.164 telephone number validation (
.e164())
The E.164 validator is clearly documented. Consider linking to the E.164 specification or providing a brief note about country code support.🤖 Prompt for AI Agents (early access)
In README.md around lines 656 to 657, the E.164 telephone number validation is mentioned but lacks additional context. Enhance the documentation by adding a link to the official E.164 specification or include a brief note explaining that the format supports international country codes, to provide clearer guidance to users.
794-805: 🧹 Nitpick (assertive)
Provide JSON parsing examples
The code snippets demonstrate proper use of.json(). For completeness, you could add a quick example showingsafeParseon invalid JSON to highlight error wrapping.🤖 Prompt for AI Agents (early access)
In README.md around lines 794 to 805, add an example demonstrating the use of safeParse with z.string().json() on invalid JSON input. Show how the parsing fails and how the error is wrapped, to provide a complete understanding of error handling when JSON parsing fails.
835-842: 🧹 Nitpick (assertive)
E.164 examples demonstrate edge cases
Good coverage of passing and failing numbers. To round out the docs, consider noting supported country code formats or linking to the E.164 standard.🤖 Prompt for AI Agents (early access)
In README.md around lines 835 to 842, the E.164 examples show passing and failing cases but lack explanation of supported country code formats. Add a brief note describing the expected E.164 format, emphasizing the country code prefix and number length constraints, or include a link to the official E.164 standard for reference. This will provide clearer context for users about the validation rules.
769-769:
⚠️ Potential issueTypo: "IP 6" should be "IPv6"
The sentence reads "validate IPv4 and IP 6" — it should be "validate IPv4 and IPv6".Apply this diff:
-The `z.string().ip()` method by default validate IPv4 and IP 6. +The `z.string().ip()` method by default validates both IPv4 and IPv6.📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.The `z.string().ip()` method by default validates both IPv4 and IPv6.🤖 Prompt for AI Agents (early access)
In README.md at line 769, correct the typo in the sentence describing the `z.string().ip()` method by changing "IP 6" to "IPv6" so it reads "validate IPv4 and IPv6".
117-117:
⚠️ Potential issueBroken link fragment: normalize to lowercase
The TOC link uses an uppercase fragment (#zodtype-with-ZodTransform), which may not match the generated anchor.Apply this diff:
- - [ZodType with ZodTransform](#zodtype-with-ZodTransform) + - [ZodType with ZodTransform](#zodtype-with-zodtransform)📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.- [ZodType with ZodTransform](#zodtype-with-zodtransform)🧰 Tools
🪛 markdownlint-cli2 (0.17.2)
117-117: Link fragments should be valid
Expected: #zodtype-with-zodtransform; Actual: #zodtype-with-ZodTransform(MD051, link-fragments)
🤖 Prompt for AI Agents (early access)
In README.md at line 117, the table of contents link fragment uses uppercase letters (#zodtype-with-ZodTransform) which may not match the actual anchor generated by markdown parsers that normalize anchors to lowercase. Change the link fragment to all lowercase (#zodtype-with-zodtransform) to ensure the link works correctly.
|
Very true. Though I'm not actually removing these methods (and never will in |
* docs: in v4, `strict()` is not deprecated * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]>
…4261) * Add composable-functions as a library powered by Zod supporting v4 * docs: in v4, `strict()` is not deprecated (#4298) * docs: in v4, `strict()` is not deprecated * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * chore: add `orval` to XtoZod ecosystems in v4 (#4256) Co-authored-by: Colin McDonnell <[email protected]> --------- Co-authored-by: Shodai Suzuki <[email protected]> Co-authored-by: Colin McDonnell <[email protected]>
* feat(lang): Added initial Azerbaijani locale (#4158) * feat(lang): Added initial Azerbaijani locale * Format --------- Co-authored-by: Colin McDonnell <[email protected]> * fix(docs): Typo fro (#4157) * Fix broken logo link (#3974) * Fix broken logo link * Use absolute URL * Absolute url --------- Co-authored-by: Colin McDonnell <[email protected]> * Add packages/docs * Remove packages/docs * Clean up zodmini exports with underscores * Add precommit format * Fix error generic * Fix optionality docs * tweak (#4173) Co-authored-by: Colin McDonnell <[email protected]> * fix: dev:play script to use play.ts instead of playground.ts (#4177) * Optimize `extendShape` (#4150) Co-authored-by: Anders Hejlsberg <[email protected]> * 3.24.3 * add back packages/docs * Update * Update benchmark * Refactor `Extend` to preserve declaration links (#4155) * Refactor `ExtendShape` to preserve declaration links * fix type issues * Simplify aliases * Fix lint * Fix * Update benchmarks --------- Co-authored-by: Colin McDonnell <[email protected]> * Fix en.ts * 0.5.2 * 0.6.0 * Fix enum type portability * Clean up passthrough schemas in toJSONSchema * 0.6.3 * v4: fix typos in basics guide (#4211) - Removed redundant whitespaces before `string()` method - Fixed typo in the note to `.parse()` method * v4: fix typo in defining schemas section (#4219) * fix migration guide typos (#4205) * partial record * Clean up toJSONSchema behavior. extract schemas with ids * Improve core.mdx * Fix missing methods * 0.7.0 * Fix unrepresentable literals and onattach issues * 0.8.0 * Improve error customization docs * Clarify error docs * Closes #4089 * Fix starts_with * docs: add zod-schema-faker to ecosystem (#4247) * fix(docs): Correct "with with" typo. (#4243) Correct "with with" typo. * fix(docs): Correct typo in Records (#4244) Correct typo in Records "that as" instead of "that is". * fix(docs): Typo in `z.object()` vs `z.interface()` (#4241) Update documentation to clarify that optional properties in `z.interface()` are defined with a `?` suffix, not a prefix. * Correcting the default numeric range to be inclusive. (#4224) * Reusing `Number.MAX_VALUE` for `float64` range (#4222) * Clarify defaults for `toJsonSchema` options (#4223) * docs: add GQLoom to ecosystem (#4225) * fix(docs): Swap Enum `.exclude() / .extract()` code samples. (#4242) The code samples in `.exclude()` belong to `.extract()` and vice versa. * fix(docs): Grammatical error in Refinements (#4252) Correct grammatical error in Refinements * Improve handling of `.meta()`/`.describe()` in JSON Schema converter (#4255) * WIP * Big improvements to meta and describe handling * WIP * Lazy disc * Add cybozu * 0.9.0 * Feature Stainless * Edit alt text * doc: fixed missing comment in migration guide (#4293) * fix migration guide typo (#4291) * Add "zod-config" to ecosystem.tsx (v4 support via pre-release) (#4282) * Update ecosystem.tsx to add "zod-config" with v4 support via RC * fix(docs): Correct formatting in ecosystem.tsx for "zod-config" entry --------- Co-authored-by: Alexandre Marques <[email protected]> * docs: add support for `kubb` as part of the v4 upgrade (#4260) * Add methods to string formats (#4296) * 0.10.0 * Tweak * Tweak * z._default * Correct conditions for error in docs (#4312) - Make schema a strict object - Add extra key to induce error described later * fix vscode debug issue with tsx runtime (#4306) * Tweak default docs * correction in documentation (#4303) (zod example using @zod/mini import) * WIP * Make ulid case insensitive * v0.10.1 * Improve jsdoc * ULID * docs: in v4, `strict()` is not deprecated (#4298) * docs: in v4, `strict()` is not deprecated * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * chore: add `orval` to XtoZod ecosystems in v4 (#4256) Co-authored-by: Colin McDonnell <[email protected]> * Add composable-functions as a library powered by Zod supporting v4 (#4261) * Add composable-functions as a library powered by Zod supporting v4 * docs: in v4, `strict()` is not deprecated (#4298) * docs: in v4, `strict()` is not deprecated * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * chore: add `orval` to XtoZod ecosystems in v4 (#4256) Co-authored-by: Colin McDonnell <[email protected]> --------- Co-authored-by: Shodai Suzuki <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> * Support recursive types in `z.object()`, drop `z..interface()` (#4271) * WIP * WIP * Add qin * WIP * Refactor object-like internals. use optionality in zodinterface shape. remove ?-prefixing for defaulted. handle optionals/defaults in json schema * WIP * WIP * Generics are working * WIP * WIP * Fix * Fix tests * Fix tests * WIP * WIP * Drop `z.interface()` from docs (#4316) * Drop interface * Format * Feature * Allow HH:MM format in `z.string().datetime()` and `z.string().time()` (#4315) * feat: allow omitting seconds in time string * docs: include examples of omitted seconds * docs: remove whitespace * 3.23.4 * V4(fix): generate json-schema with min/max(0) (#4267) * fix: generate number json schema * fix: generate json schema with min/max(0) * Apply suggestions from code review fix: format Co-authored-by: Anna Bocharova <[email protected]> --------- Co-authored-by: Panda <[email protected]> Co-authored-by: Anna Bocharova <[email protected]> * 0.11.1 * docs: added @regle/schemas to form ecosystem (#4169) * docs: added @regle/schemas to form ecosystem In my previous MR you said to edit `components/ecosystem.mdx` but couldn't find it, if it was a typo i guessed it was this file! 👍 * Add to ecosystem.tsx --------- Co-authored-by: Colin McDonnell <[email protected]> * Fix union inferred type issue * v0.11.2 * optionalObjectKeys -> optionalKeys * 0.11.3 * Add test for union types * Fix assignability * 0.11.4 * Add assignability tests * Stack trace in parse and parseAsync * Biome * Clean up code, fix lock * Document default changes * Clarify deprecations * Update changelog * v0.11.6. support recursive types in zodmini * Add recursive type tests for zod mini * Add recursive tests for zod mini * fix(core): use `Object.create(null)` to cache ids (#4359) * Jazz sponsorship * Update Speakeasy sponsor URL (#4337) * fix: use input, not output, for input of ZodUnionInternals (#4330) * Languages: Add Japanese language (#4170) * Add Japanese locale * format * fix(ja): Fixed comparison operator in error messages * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * New parse signature * Fix parse functions * Add Jazz * Languages: Add Portuguese language (#4171) * Adding portuguese translations * Adding portuguese * Adding language to docs * Adding spanish language in docs * Tweak * Updating references from string to texto * Updating faixa to faixa de * Updating from elementos to itens * Mirroring validation from original file * Updating regex to padrao * Updating entrada by tipo * Replacing entrada by campo --------- Co-authored-by: Helmer <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> * Languages: Add french language (#4172) * Adding french and exporting it * Adding french in docs * Update fr.ts Co-authored-by: Florian Lefebvre <[email protected]> * Translating datetime * Tweak * Update elements * Update packages/core/src/locales/fr.ts Co-authored-by: Fabrice Cipolla <[email protected]> --------- Co-authored-by: Helmer <[email protected]> Co-authored-by: Florian Lefebvre <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> Co-authored-by: Fabrice Cipolla <[email protected]> * Languages: Add Arabic language (#4176) * feat(lang): Add Arabic locale support * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * remove period * fix: add space after comparison operator * feat(lang): Add Arabic locale support * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * Update packages/core/src/locales/ar.ts Co-authored-by: Abdullah Mohammed <[email protected]> * remove period * fix: add space after comparison operator * Tweak * Updated ar.ts with new edits discussed in #4176 * Update packages/core/src/locales/ar.ts * Update packages/core/src/locales/ar.ts * Update packages/core/src/locales/ar.ts * chore: format * fix: update translation for template_literal * fix: correct translation for invalid input error message * fix: spacing in error messages * fix: show correct prefix * fix: remove unused template literal * Update error-customization.mdx --------- Co-authored-by: Abdullah Mohammed <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> Co-authored-by: Hosam Hamdy <[email protected]> * Languages: Add Hebrew language (#4183) * Create he.ts * Update locales.ts * Update error-customization.mdx * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: add Polish 🇵🇱 language (#4184) * Languages: add polish language * Fix: apply formatting * Tweak * Fix: add missing fallbacks * Update packages/core/src/locales/pl.ts Co-authored-by: Marcel <[email protected]> * Update packages/core/src/locales/pl.ts Co-authored-by: Marcel <[email protected]> --------- Co-authored-by: Colin McDonnell <[email protected]> Co-authored-by: Marcel <[email protected]> * Languages: add Ukrainian language (#4185) * locale: add ukrainian language * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: add Finnish language (#4188) * feat: add initial finnish translations * chore: add export and docs * Tweak * feat: add more translations for different data types * fix: lint errors * fix: map translation * feat: only handle used cases in TypeNames * refactor: pr comments * refactor: map translation * refactor: heavily simplify finnish translations * chore: use unioni instead of yhdiste Might be more commonly used (gut feeling). * style: remove unused imports --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: add Hungarian language (#4186) * add hungarian * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * Add Simplified Chinese (#4189) * feat(lang): add Simplified Chinese * fix: locale * fix: space format * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(lang): add Vietnamese (vi) locale (#4191) * feat(lang): add Vietnamese (vi) locale * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: add Czech language 🇨🇿 (#4192) * feat: add czech error locales * fix(locales): improve Czech error messages for clarity * Fmt * fix(locales): use correct string error prefix in error message For Czech language. Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> * fix(locales): translate other data types as well For Czech language. Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> * fix(locales): handle nullable variables in error messages For Czech langauge. --------- Co-authored-by: Colin McDonnell <[email protected]> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> * Languages: add italian language (#4194) * feat: added italian language * Fmt * Tweak --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: add Indonesia language (#4195) * Languages: add Bahasa Indonesia language * tweak * Tweak * Update packages/core/src/locales/id.ts Co-authored-by: Griko Nibras <[email protected]> * Update packages/core/src/locales/id.ts Co-authored-by: Griko Nibras <[email protected]> * Update packages/core/src/locales/id.ts Co-authored-by: Griko Nibras <[email protected]> * Update packages/core/src/locales/id.ts Co-authored-by: Griko Nibras <[email protected]> * Update packages/core/src/locales/id.ts Co-authored-by: Griko Nibras <[email protected]> --------- Co-authored-by: Colin McDonnell <[email protected]> Co-authored-by: Griko Nibras <[email protected]> * feat(lang): Added initial Turkish locale (#4196) * feat(lang): Added initial Turkish locale * fix(lang): Improve formatting in Turkish error messages * fix(lang): Update Turkish translations for various terms * fix(lang): Update Turkish translations for base64 and template literal terms * fix(lang): Correct Turkish error message for 'starts_with' format * test(lang): Add unit tests for Turkish locale parsing and validation * test(lang): Remove console log from Turkish locale test for cleaner output Co-authored-by: Mert Şişmanoğlu <[email protected]> * fix(lang): Correct variable reference in Turkish 'starts_with' error message Co-authored-by: Mert Şişmanoğlu <[email protected]> --------- Co-authored-by: Mert Şişmanoğlu <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): add russian language (#4197) * feat(locale): add russian language * updates * feat(locale): add Russian pluralization rules * fix: tests * fixes * fix(locale): correct error message for string format validation in Russian locale --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): add belarusian language (#4199) * feat(locale): add belarusian language * feat: add belarusian plurals support * fix(locale): correct Belarusian error message formatting for string validation --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(lang): Add ota locale in Latin script (#4200) Co-authored-by: Colin McDonnell <[email protected]> * Languages: Add Korean language (#4206) * chore: run format * feat(locale): add Korean language --------- Co-authored-by: Colin McDonnell <[email protected]> * Languages: Add Farsi language (#4207) * feat(lang): add farsi language * fix: joinValues in invalid_value --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): Add Urdu language (#4208) * feat(locale): add urdu language * Fix formatting for ur.ts file * Fix formatting for ur.ts file --------- Co-authored-by: Colin McDonnell <[email protected]> * Add Macedonian locale support and update documentation (#4214) Co-authored-by: Antonio Ivanovski <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> * Add-fr-ca-locale (#4218) * chore: Add .pnpm-store to .gitignore * chore: Add Canadian French locale support --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): add Traditional Chinese (#4226) * feat(locale): add Traditional Chinese * fix --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): Add Norwegian (#4229) * feat: added Norwegian (Bokmål) * fix: renamed locale to no + improved translations * fix: forgot to add the file to git... * fix: more accurate verb for collections * chore: removed commented out code * chore: ran linter * fix: minor tweaks to error messages * Update packages/core/src/locales/no.ts I agree, that's better! Co-authored-by: Steffen Holanger <[email protected]> --------- Co-authored-by: Magne Skutle <[email protected]> Co-authored-by: Steffen Holanger <[email protected]> Co-authored-by: Colin McDonnell <[email protected]> * feat(lang): Added initial Thai locale (#4230) * feat(lang): Added initial Thai locale * fix(lang): improve thai translation for clarify meaning --------- Co-authored-by: Colin McDonnell <[email protected]> * feat(locale): Add SL locale (#4231) Co-authored-by: Colin McDonnell <[email protected]> * feat(lang): Added initial `Tamil` locale (#4237) Co-authored-by: Colin McDonnell <[email protected]> * Languages: add German language (#4253) * feat(locales): add Catalan locale support and update documentation (#4287) Co-authored-by: Colin McDonnell <[email protected]> * Languages: Add Malay language (#4204) * feat(lang): add Malay support * chore: run format --------- Co-authored-by: Colin McDonnell <[email protected]> * Fix issue issue * Subclass Error * Update Error inheritance * Clean up Error inheritance * Fix prom test * Refactor: add subpath imports `zod/v4` (#4364) * Refactor to subpaths * Tweak * Roll back to tshy 1 * Use supershy * Lint * drop dryrun * Add root re-export * Add file * Update docs * Update guide * Docs and locales barrel file * Update announcement and changelog * Update anno * Add accordion * Fix readonly issue on zodminienum. Rename _getter to innerType on zodlazy * Fix diagonal enum issue * Improve `z.url()`: support `hostname` and `protocol` regexes (#4367) * Improve z.url(). Add support for hostname and protocol regexes * Add docs * Add z.core.$ZodBranded * Add jitless config flag (#4368) * Remove util.Exactly from zod-mini masks * Roll back never toJSONSchema * Update snaps * v4: set additionalProperties to false when catchall is never (#4365) * Document dropping of ctx.path in changelog * Remove z.core from zod/v4-mini * Add back z.core * Document .refine overload drop * Fix input type for ZodMiniDate * Add zodpipe mini test * Clean up params * Fix test * docs: escape `.` in the example regex for `z.url` with `hostname` (#4375) * Document moduleResolution * typo * Implement `z.prefault` (#4376) * WIP * Implement prefault * Document prefault * Add link to function workaround * Defer initialization to avoid crashes with z.lazy. Closes #4324. (#4377) * noPrecompilation -> jitless * Update ZodError section in changelog. Deprecate isOptional and isNullable * Return data on best-effort basis despite errors * Fix prefixIssues issue * Add fallback File interface * Add back formatError and flattenError functions * Allow generic on coerce functions (#4379) * Allow generic on coerce functions * Clean up * Add union values test * Add another lazy schema init test * Clean up * Add docs for recursive type debugging. * Update recursive type docs * F * Improve discriminateduion errors (#4384) * Remove abort property from ZodTransformDef. Add discriminator key to no_discriminator_found issue. * Clean up * Clean up Error inheritance * Remove examples from JSON Schema when io=input * `z.toJSONSchema`: Defer execution of `override`, improve ref handling (#4385) * Defer override execution * Improve refs in json schema. Cleanup. * Clean up * Clean up * Clean up enum input type * Improve base64 perf. Disallow padding in base64url. (#4386) * Improve base64 perf. Disallow padding in base64url * Allow empty base64 string * Allow empty base64 string * Clean up * Document base64url change * Tweak * Fix treeify error invalid_union handling * fix ensure catchValue is applied correctly on validation error (#4382) * Simplify object generics, add test for empty objects (#4387) * Simplify object generics. Add tests for empty object types. * Fix tests * Fix tests, rename pickomit * Fix typo in json-schema.mdx (#4380) * fix: use JSON.stringify to escape toDotPath keys w/ quotes (#4374) This should also correctly handle even weirder stuff like newlines in proeprty keys. JSON.stringify should do all the right escaping - if it's a valid JSON string, it's a valid key. Note: one existing test was updated: ``` expect(z.core.toDotPath(["data[0]", "value"])).toMatchInlineSnapshot(`"data[0].value"`); // <- before expect(z.core.toDotPath(["data[0]", "value"])).toMatchInlineSnapshot(`"["data[0]"].value"`); // <- after ``` This looks correct to me? Previously it was implying a shape of `{data: [{value: '...'}]}` when actually it should be a shape of `{'data[0]': {value: '...'}}` (updated 12:30) Co-authored-by: Misha Kaletsky <[email protected]> * Improve min/max in JSON Schema (#4388) * Add types for bag. Fix setting of min/max in json schema * Fix minValue/maxValue * Improve number tests * Trim * Remove type on base class * Fix err * Mark internals * Remove partial record accordion * Update ecosystem * Add reference to instanceof Class * Add JSON Schema (#4390) * Update prefault changelog * Lazy initialization in union and discunion * Clean up util * Fix override execution order * Add test for override execution order * Preserve shape key ordering in result (#4396) * Clean up object parser * Fix discriminated union * Add disc union test * Fix inheritance on ZodDiscriminatedUnion * Document metadata inheritance * Metadata inherited across clones (#4401) * Add back discriminator to `z.discriminatedUnion()` API (#4402) * WIP * Add back discriminator, add benchmark * Update docs * Play * Add disc union test, improve docs * chore: add oRPC to the API Libraries ecosystem (#4349) oRPC 1.2.0 has full support for Zod 4, from validation to OpenAPI spec generation Co-authored-by: Colin McDonnell <[email protected]> * Update benchmark * [v3] Allow missing `type` in JWT (#4404) * WIP * Improve JWT tests * Implement pipe optionality. Drop `._zod.optionality` in favor of `._zod.optin` and `._zod.optout`. (#4405) * Implement pipe optionalty. Switch to optin and optout * Clean up * Redirect * WIP * Page events * Move up sponsors * Try scroller * Suspense * No animation * Add redirects * Remove logs * Add Juno (new silver sponsor) (#4408) * Add Juno (new silver sponsor) * chore: redo * chore: redo * Add redirects * WIP * Audit redirects * Tweak * v4: Doc updates for release (#4409) * v4 release updates * Tweak * REmove banners * Add tabs * Update intro * Zod 4 * Fix lint * Simplify readme * Simplify readme * Simplify readme * Simplify readme --------- Co-authored-by: Chingiz Mammadov <[email protected]> Co-authored-by: Henrikh Kantuni <[email protected]> Co-authored-by: Shivam Vijaywargi <[email protected]> Co-authored-by: Abdalrhman Almarakeby <[email protected]> Co-authored-by: Mateusz Burzyński <[email protected]> Co-authored-by: Anders Hejlsberg <[email protected]> Co-authored-by: Andrii Andreichenko <[email protected]> Co-authored-by: Mohammed Alaa Alhaj <[email protected]> Co-authored-by: Jonathan Waltz <[email protected]> Co-authored-by: Ernest <[email protected]> Co-authored-by: Juan Giordana <[email protected]> Co-authored-by: Anna Bocharova <[email protected]> Co-authored-by: xcfox <[email protected]> Co-authored-by: Shodai Suzuki <[email protected]> Co-authored-by: Dan Michael O. Heggø <[email protected]> Co-authored-by: Alexandre Marques <[email protected]> Co-authored-by: Alexandre Marques <[email protected]> Co-authored-by: Stijn Van Hulle <[email protected]> Co-authored-by: George Kormaris <[email protected]> Co-authored-by: Lakshan Perera <[email protected]> Co-authored-by: Kevin Damm <[email protected]> Co-authored-by: Guga Guichard <[email protected]> Co-authored-by: Timothy Ng <[email protected]> Co-authored-by: Panda <[email protected]> Co-authored-by: Panda <[email protected]> Co-authored-by: Victor Garcia <[email protected]> Co-authored-by: andrew jarrett <[email protected]> Co-authored-by: Nolan Di Mare Sullivan <[email protected]> Co-authored-by: Rik Brown <[email protected]> Co-authored-by: Kio Yoshimatsu <[email protected]> Co-authored-by: Helmer <[email protected]> Co-authored-by: Helmer <[email protected]> Co-authored-by: Florian Lefebvre <[email protected]> Co-authored-by: Fabrice Cipolla <[email protected]> Co-authored-by: Abdullah Mohammed <[email protected]> Co-authored-by: Hosam Hamdy <[email protected]> Co-authored-by: Shachar Zidon <[email protected]> Co-authored-by: Bartosz Szar <[email protected]> Co-authored-by: Marcel <[email protected]> Co-authored-by: Dmytro Dobrovolskyi <[email protected]> Co-authored-by: Henri Södergård <[email protected]> Co-authored-by: Lőrik Levente <[email protected]> Co-authored-by: GrahamQuan <[email protected]> Co-authored-by: Nguyễn Hoàng Trung <[email protected]> Co-authored-by: Filip Ditrich <[email protected]> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> Co-authored-by: Davide Lombardi <[email protected]> Co-authored-by: Krisna Wijaya <[email protected]> Co-authored-by: Griko Nibras <[email protected]> Co-authored-by: Özgür ÖZALP <[email protected]> Co-authored-by: Mert Şişmanoğlu <[email protected]> Co-authored-by: Vlad Sazonau <[email protected]> Co-authored-by: KadimElifba <[email protected]> Co-authored-by: Lee Keun Hwee <[email protected]> Co-authored-by: Mojtaba <[email protected]> Co-authored-by: Asharib Ali <[email protected]> Co-authored-by: Antonio <[email protected]> Co-authored-by: Antonio Ivanovski <[email protected]> Co-authored-by: Sofiane <[email protected]> Co-authored-by: Jie Peng <[email protected]> Co-authored-by: Magne Skutle <[email protected]> Co-authored-by: Magne Skutle <[email protected]> Co-authored-by: Steffen Holanger <[email protected]> Co-authored-by: Thada Wangthammang <[email protected]> Co-authored-by: Tadej Polajnar <[email protected]> Co-authored-by: Sasivarnan R <[email protected]> Co-authored-by: Simon Legner <[email protected]> Co-authored-by: Pere Montpeó <[email protected]> Co-authored-by: Khairul Haziq <[email protected]> Co-authored-by: Jacques <[email protected]> Co-authored-by: Loris Sigrist <[email protected]> Co-authored-by: chimame <[email protected]> Co-authored-by: Fabian Hiller <[email protected]> Co-authored-by: Misha Kaletsky <[email protected]> Co-authored-by: Misha Kaletsky <[email protected]> Co-authored-by: unnoq <[email protected]> Co-authored-by: David Dal Busco <[email protected]>
The following commit removed the deprecated mark from strict():
4d269a2
And this was an omission from the guide, so I fixed it.
#4289 (comment)