Skip to content
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

feat: add FormatConfig for GenericFormat with leap second validation #7584

Merged
merged 2 commits into from
Mar 27, 2025

Conversation

algebraic-dev
Copy link
Contributor

This PR introduces a structure called FormatConfig, which provides additional configuration options for GenericFormat, such as whether leap seconds should be allowed during parsing. By default, this option is set to false.

This PR also fixes certain flaws to make the implementation less permissive by:

  • Disallowing the final leap second, such as 2016-12-31T23:59:60Z, when allowLeapSeconds = false.
  • Disallowing invalid leap seconds, such as 2017-06-30T23:59:60Z, when allowLeapSeconds = false.
  • Disallowing leap-minute time zones, such as 2016-12-31T00:00:00+2360, and out-of-range time zones, such as 2016-12-31T00:00:00+2490.

These changes ensure that Lean aligns with TypeScript's behavior, as outlined in this table: cedar-policy/cedar-spec#519 (comment).

@algebraic-dev algebraic-dev requested a review from TwoFX as a code owner March 20, 2025 02:09
@algebraic-dev algebraic-dev changed the title Fix date ts feat: add FormatConfig for GenericFormat with leap second validation Mar 20, 2025
@github-actions github-actions bot added the toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN label Mar 20, 2025
@leanprover-community-bot
Copy link
Collaborator

leanprover-community-bot commented Mar 20, 2025

Mathlib CI status (docs):

  • ❗ Batteries/Mathlib CI will not be attempted unless your PR branches off the nightly-with-mathlib branch. Try git rebase 720f6fca94e24f21ba84805917edacef1bac9349 --onto a97813e11f962bc422a03c30b7e29dd2eefb92c8. You can force Mathlib CI using the force-mathlib-ci label. (2025-03-20 02:37:28)
  • ❗ Batteries/Mathlib CI will not be attempted unless your PR branches off the nightly-with-mathlib branch. Try git rebase 9466c5db25fe9e44199d2a9e837ab461716c89ec --onto 1465c23e12f6f8b608ef944be4559b1b5e38f40a. You can force Mathlib CI using the force-mathlib-ci label. (2025-03-26 21:40:43)

Copy link
Member

@TwoFX TwoFX left a comment

Choose a reason for hiding this comment

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

Please add tests for the things you fixed and in particular for the new syntax.

@algebraic-dev algebraic-dev requested a review from TwoFX March 27, 2025 10:39
@algebraic-dev algebraic-dev added the awaiting-review Waiting for someone to review the PR label Mar 27, 2025
@algebraic-dev algebraic-dev added this pull request to the merge queue Mar 27, 2025
Merged via the queue into leanprover:master with commit d95a2ee Mar 27, 2025
20 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
awaiting-review Waiting for someone to review the PR changelog-library Library toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants