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

Update docs for bon 3.0 release (part 1) #166

Merged
merged 13 commits into from
Oct 31, 2024
Merged

Conversation

Veetaha
Copy link
Collaborator

@Veetaha Veetaha commented Oct 29, 2024

Summary by CodeRabbit

  • New Features

    • Introduced new documentation for the #[derive(Builder)] and #[builder] attributes, enhancing the builder pattern in Rust.
    • Added the overwritable attribute, allowing multiple setter calls for the same member.
    • Implemented new sections on "Builder Extensions" and "Customizing Setters" in the documentation.
    • Added experimental completions feature with Rust Analyzer for better development experience.
  • Bug Fixes

    • Clarified various documentation sections to improve understanding of attributes and their functionalities.
  • Documentation

    • Updated and reorganized several documentation files for clarity and better guidance on new features and attributes.
    • Added examples for new and existing attributes to illustrate their usage effectively.
  • Chores

    • Updated import paths and dependency versions in various files to improve structure and maintainability.

Copy link
Contributor

coderabbitai bot commented Oct 29, 2024

Caution

Review failed

The pull request is closed.

Walkthrough

This pull request includes significant modifications to the VitePress configuration, documentation files, and CI workflow for the bon Rust crate. Key changes involve updating import paths, restructuring sidebar entries, and enhancing documentation clarity regarding various builder attributes. New sections and attributes are introduced, such as overwritable, and existing attributes like finish_fn and start_fn have been updated for better usability. Additionally, the CI configuration has been adjusted to reflect new toolchain versions and flags.

Changes

File Path Change Summary
website/.vitepress/config.mts Updated import paths, added srcDir property, rewrites configuration, and reorganized sidebar.
website/reference/builder.md New file documenting #[derive(Builder)] and #[builder] attributes.
website/reference/builder/top-level/finish-fn.md Updated documentation for finish_fn attribute to include visibility and documentation configurations.
website/reference/builder/top-level/on.md New file introducing on attribute for applying member attributes based on type patterns.
website/reference/builder/member/overwritable.md New file documenting overwritable attribute for allowing multiple setter calls.
website/reference/builder/member/setters.md New file detailing customization of setter attributes in builders.
website/reference/builder/member/finish-fn.md Updated documentation for finish_fn attribute.
website/reference/builder/member/into.md Updated documentation for into attribute to clarify setter signatures.
website/reference/builder/member/transparent.md New section added for transparent attribute.
website/reference/builder/member/with.md New section added for with attribute.
website/reference/builder/top-level/state-mod.md New section added for state_mod attribute.
website/src/guide/builder-extensions.md New section added for "Builder Extensions."
website/src/guide/customizing-setters.md New section added for "Customizing Setters."
website/src/guide/optional-members.md Updated examples and explanations regarding optional members.
website/src/guide/overview.md Updated import path for version.data.
.github/workflows/ci.yml Updated Rust toolchain version and added new flags in CI jobs.
README.md Minor textual modifications for clarity.
website/src/blog.md Updated import paths for blog-related modules.
website/src/blog/bon-builder-generator-v2-release.md Documented release of version 2.0 of the bon Rust crate.
website/src/blog/bon-builder-v2-2-release.md Documented release of version 2.2 of the bon Rust crate.
website/src/changelog.md Updated changelog to reflect significant changes in the bon project.

Possibly related issues

  • Stabilize #[builder(overwritable)] #149: The introduction of the #[builder(overwritable)] attribute is directly addressed in this PR, which includes related documentation and functionality enhancements.

Possibly related PRs

Suggested reviewers

  • anelson: Suggested for review due to relevance to the changes made in the documentation and attributes related to the bon crate.

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

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)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@Veetaha Veetaha marked this pull request as draft October 29, 2024 00:21
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 1

🧹 Outside diff range and nitpick comments (16)
website/reference/builder/top-level/finish-fn.md (2)

38-42: Add a comma after "in turn" for better readability.

The visibility section is technically accurate, but a small grammatical improvement would help.

-The default visibility is the same as the visibility of the [`builder_type`](./builder-type#vis), which in turn defaults to the visibility of the underlying `struct` or `fn`.
+The default visibility is the same as the visibility of the [`builder_type`](./builder-type#vis), which in turn, defaults to the visibility of the underlying `struct` or `fn`.
🧰 Tools
🪛 LanguageTool

[uncategorized] ~42-~42: Possible missing comma found.
Context: ...e builder_type, which in turn, defaults to the visibility of ...

(AI_HYDRA_LEO_MISSING_COMMA)


44-47: Consider adding a documentation example.

While the explanation is accurate, it would be helpful to include a small example showing the expected doc comment syntax.

 Simple documentation is generated by default. The syntax of this attribute expects a block with doc comments.
+
+For example:
+```rust
+#[builder(
+    finish_fn(
+        doc {
+            /// Builds the final object with all configured parameters.
+            /// 
+            /// # Returns
+            /// 
+            /// Returns the constructed object.
+        }
+    )
+)]
+```
website/reference/builder.md (1)

Line range hint 1-89: Consider enhancing the documentation structure.

While the current documentation is well-organized, consider these improvements to enhance user experience:

  1. Add a "Quick Start" or "Common Usage" section at the beginning
  2. Include version compatibility information (especially relevant for 3.0 release)
  3. Add cross-references to related attributes where applicable
🧰 Tools
🪛 Markdownlint

61-61: Expected: leading_only; Actual: leading_and_trailing; Unexpected trailing pipe
Table pipe style

(MD055, table-pipe-style)

website/reference/builder/top-level/builder-type.md (3)

17-29: Consider clarifying field optionality in the long syntax.

While line 17 mentions that "all keys are optional", it would be helpful to provide examples of partial configurations to demonstrate this flexibility.

Consider adding examples like:

#[builder(
    builder_type(
        name = CustomName,
        vis = "pub(crate)"
        // doc is omitted
    )
)]

44-46: Consider adding an example of visibility inheritance.

While the text explains that visibility defaults to the underlying item's visibility, an example would make this clearer.

Consider adding:

pub struct Foo {} // The builder will also be `pub` by default

Line range hint 95-120: Consider improving error example comments.

The error example's comments could be more precise about the nature of the conflict.

Consider updating the comment to:

-// `BrushBuilder` builder type name was generated for both
-// the struct and the function. This is a compile error
+// Error: Multiple definitions of `BrushBuilder` in the same scope
+// Both the struct and function builders attempt to use the same name
website/reference/builder/top-level/start-fn.md (2)

40-46: Consider enhancing sections with examples.

The visibility and documentation sections could be more helpful with concrete examples:

  • Show different visibility patterns (e.g., pub, pub(crate), "")
  • Demonstrate custom documentation block syntax

Example enhancement for the doc section:

#[builder(
    start_fn(
        doc {
            /// Creates a new builder for constructing a User.
            /// 
            /// # Example
            /// ```
            /// let user = User::builder()
            ///     .name("John")
            ///     .build();
            /// ```
        }
    )
)]

Line range hint 151-153: Consider clarifying the new method behavior.

The paragraph about the new method quirk could be clearer. Consider restructuring it as:

-One interesting quirk is that by default the associated method named `new` already generates a starting function under the name `builder`. However, by default, the original method `new` also becomes hidden. By specifying the `#[builder(start_fn = builder)]` explicitly the original method `new` remains exposed.
+The associated method `new` has special handling:
+- By default, it generates a starting function named `builder`
+- The original `new` method is hidden by default
+- Adding `#[builder(start_fn = builder)]` explicitly preserves both the original `new` method and the builder syntax
🧰 Tools
🪛 LanguageTool

[duplication] ~38-~38: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)

website/reference/builder/top-level/derive.md (1)

130-171: Consider enhancing the code examples.

The examples could be more educational with these improvements:

  1. In the "Overly restrictive" example, consider adding a comment explaining the actual compiler error message.
  2. In the "Fixed" example, explain why U: Clone is still needed (because y: U needs to be cloned).

Consider updating the examples like this:

 // `Rc` can be cloned even if `T` is not `Clone`, but this code
 // doesn't compile, because the `Clone` impl for `ExampleBuilder`
-// conservatively requires `T: Clone`
+// conservatively requires `T: Clone`, producing error:
+// error[E0277]: the trait bound `T: Clone` is not satisfied
 builder.clone();
 #[derive(Builder)]
-// Only a bound `U: Clone` is needed in this case
+// Only `U: Clone` is needed because:
+// - `Rc<T>` implements Clone regardless of T
+// - field `y: U` needs to be cloned
 #[builder(derive(Clone(bounds(U: Clone))))]
website/reference/builder/top-level/on.md (2)

86-95: Add missing comma for better readability.

Add a comma after the code block for better flow:

-You can use `_` to mark parts of the type to ignore when matching. For example, `Vec<_>` matches `Vec<u32>` or `Vec<String>`. Lifetimes are ignored during matching.
+You can use `_` to mark parts of the type to ignore when matching. For example, `Vec<_>` matches `Vec<u32>` or `Vec<String>`. Lifetimes are ignored during matching.

-If you want to apply the attributes to all members, you can use the `_` type pattern that matches any type. For example, `#[builder(on(_, into))]`.
+If you want to apply the attributes to all members, you can use the `_` type pattern that matches any type. For example, `#[builder(on(_, into))]`.

-For optional members the underlying type is matched ignoring the `Option` wrapper.
+For optional members, the underlying type is matched ignoring the `Option` wrapper.
🧰 Tools
🪛 LanguageTool

[uncategorized] ~94-~94: Possible missing comma found.
Context: ...#[builder(on(_, into))]`. For optional members the underlying type is matched ignoring...

(AI_HYDRA_LEO_MISSING_COMMA)


199-201: Add missing article for better grammar.

Add the article "a" before "comment":

-We'll be glad if you take a look at the design proposed in that issue and put a 👍 if you like/want this feature or leave comment if you have some more feedback.
+We'll be glad if you take a look at the design proposed in that issue and put a 👍 if you like/want this feature or leave a comment if you have some more feedback.
🧰 Tools
🪛 LanguageTool

[uncategorized] ~201-~201: You might be missing the article “a” here.
Context: ... if you like/want this feature or leave comment if you have some more feedback.

(AI_EN_LECTOR_MISSING_DETERMINER_A)

website/changelog.md (5)

16-16: Add missing comma in the example list.

Add a comma before "e.g." for better readability.

-Only parentheses are accepted e.g. `#[builder(finish_fn(...))]`
+Only parentheses are accepted, e.g. `#[builder(finish_fn(...))]`
🧰 Tools
🪛 LanguageTool

[uncategorized] ~16-~16: Possible missing comma found.
Context: ...attributes syntax. Only parentheses are accepted e.g. #[builder(finish_fn(...))] or `#...

(AI_HYDRA_LEO_MISSING_COMMA)


41-41: Improve clarity with proper punctuation.

Add a comma to separate the clauses for better readability.

-Add `#[builder(transparent)]` for `Option` fields to opt out from their special handling which makes `bon` treat them as regular required fields.
+Add `#[builder(transparent)]` for `Option` fields to opt out from their special handling, which makes `bon` treat them as regular required fields.
🧰 Tools
🪛 LanguageTool

[uncategorized] ~41-~41: Possible missing comma found.
Context: ...nfields to opt out from their special handling which makesbon` treat them as regular...

(AI_HYDRA_LEO_MISSING_COMMA)


45-45: Add "please" for more polite phrasing.

Make the request more polite by adding "please".

-let us know if you need this attribute!
+please let us know if you need this attribute!
🧰 Tools
🪛 LanguageTool

[style] ~45-~45: This expression usually appears with a “please” in front of it.
Context: ...s://github.com//issues/149), let us know if you need this attribute!). ([#145](h...

(INSERT_PLEASE)


57-57: Add missing comma in documentation description.

Add a comma for better sentence structure.

-For optional members provide a link
+For optional members, provide a link
🧰 Tools
🪛 LanguageTool

[uncategorized] ~57-~57: Possible missing comma found.
Context: ...lt value in the docs. - For optional members provide a link to a companion setter. T...

(AI_HYDRA_LEO_MISSING_COMMA)


61-61: Add comma before contrasting conjunction.

Add a comma before "but" to properly separate independent clauses.

-reported via a Github issue but this provides
+reported via a Github issue, but this provides
🧰 Tools
🪛 LanguageTool

[uncategorized] ~61-~61: Use a comma before ‘but’ if it connects two independent clauses (unless they are closely connected and short).
Context: ...nd should be reported via a Github issue but this provides an easy temporary workaro...

(COMMA_COMPOUND_SENTENCE_2)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 636a8c5 and c0dccec.

⛔ Files ignored due to path filters (2)
  • bon-macros/src/builder/builder_gen/input_fn.rs is excluded by !**/*.rs
  • bon/tests/integration/builder/attr_bon.rs is excluded by !**/*.rs
📒 Files selected for processing (11)
  • website/.vitepress/config.mts (3 hunks)
  • website/changelog.md (1 hunks)
  • website/reference/builder.md (1 hunks)
  • website/reference/builder/member/overwritable.md (1 hunks)
  • website/reference/builder/member/transparent.md (1 hunks)
  • website/reference/builder/top-level/builder-type.md (2 hunks)
  • website/reference/builder/top-level/derive.md (2 hunks)
  • website/reference/builder/top-level/finish-fn.md (1 hunks)
  • website/reference/builder/top-level/on.md (4 hunks)
  • website/reference/builder/top-level/start-fn.md (2 hunks)
  • website/reference/builder/top-level/state-mod.md (1 hunks)
✅ Files skipped from review due to trivial changes (3)
  • website/reference/builder/member/overwritable.md
  • website/reference/builder/member/transparent.md
  • website/reference/builder/top-level/state-mod.md
🧰 Additional context used
🪛 LanguageTool
website/changelog.md

[uncategorized] ~16-~16: Possible missing comma found.
Context: ...attributes syntax. Only parentheses are accepted e.g. #[builder(finish_fn(...))] or `#...

(AI_HYDRA_LEO_MISSING_COMMA)


[formatting] ~18-~18: If the ‘because’ clause is essential to the meaning, do not use a comma before the clause.
Context: ..., finish_fn = build, on(Vec<_>, into))], because there is a finish_fn = ...betweeno...

(COMMA_BEFORE_BECAUSE)


[uncategorized] ~41-~41: Possible missing comma found.
Context: ...nfields to opt out from their special handling which makesbon` treat them as regular...

(AI_HYDRA_LEO_MISSING_COMMA)


[style] ~45-~45: This expression usually appears with a “please” in front of it.
Context: ...s://github.com//issues/149), let us know if you need this attribute!). ([#145](h...

(INSERT_PLEASE)


[uncategorized] ~57-~57: Possible missing comma found.
Context: ...lt value in the docs. - For optional members provide a link to a companion setter. T...

(AI_HYDRA_LEO_MISSING_COMMA)


[uncategorized] ~61-~61: Use a comma before ‘but’ if it connects two independent clauses (unless they are closely connected and short).
Context: ...nd should be reported via a Github issue but this provides an easy temporary workaro...

(COMMA_COMPOUND_SENTENCE_2)

website/reference/builder/top-level/finish-fn.md

[duplication] ~36-~36: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)


[uncategorized] ~42-~42: Possible missing comma found.
Context: ...e builder_type, which in turn, defaults to the visibility of ...

(AI_HYDRA_LEO_MISSING_COMMA)

website/reference/builder/top-level/on.md

[uncategorized] ~94-~94: Possible missing comma found.
Context: ...#[builder(on(_, into))]`. For optional members the underlying type is matched ignoring...

(AI_HYDRA_LEO_MISSING_COMMA)


[uncategorized] ~98-~98: A comma might be missing here.
Context: ...contain several of these separated by a comma e.g. on(_, into, transparent). - [`i...

(AI_EN_LECTOR_MISSING_PUNCTUATION_COMMA)


[uncategorized] ~100-~100: Loose punctuation mark.
Context: ...ansparent). - [into](../member/into); - [transparent`](../member/transparent...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~201-~201: You might be missing the article “a” here.
Context: ... if you like/want this feature or leave comment if you have some more feedback.

(AI_EN_LECTOR_MISSING_DETERMINER_A)

website/reference/builder/top-level/start-fn.md

[duplication] ~38-~38: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)

🔇 Additional comments (18)
website/reference/builder/top-level/finish-fn.md (2)

5-25: LGTM! Clear and comprehensive explanation of the attribute.

The introduction and syntax sections effectively explain the attribute's purpose and provide well-structured examples for both short and long syntax variants.


27-37: LGTM! Clear presentation of naming rules.

The table format effectively presents the default naming rules. Note: The repetition in fn fn_name() is correct as it represents valid Rust syntax where fn is the function keyword followed by the function name.

🧰 Tools
🪛 LanguageTool

[duplication] ~36-~36: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)

website/reference/builder.md (1)

62-62: LGTM! Clear improvement in attribute description.

The updated description for builder_type is more precise and comprehensive, explicitly stating all aspects that can be overridden (name, visibility, and docs).

website/reference/builder/top-level/builder-type.md (2)

1-9: LGTM! Clear and concise introduction.

The frontmatter and introduction effectively communicate the purpose and applicability of the builder_type attribute.


Line range hint 1-120: Verify documentation consistency across the codebase.

Let's ensure the builder_type attribute documentation is consistent across all documentation files.

✅ Verification successful

Let me analyze the search results to verify documentation consistency. I'll need to check the content of the v1 and v2 documentation to ensure they align with the current version.


After analyzing the documentation across different versions, I can generate the final response regarding the documentation consistency.

Documentation for builder_type is consistent with recent changes

The documentation in website/reference/builder/top-level/builder-type.md correctly reflects:

  • The new long syntax with vis and doc options
  • Default naming rules for different contexts
  • Examples for all supported cases (structs, free functions, associated methods)
  • Proper visibility documentation

The changes are also properly reflected in:

  • The changelog entry mentioning the addition of vis and docs options
  • The main builder reference linking to the detailed documentation
  • Cross-references from other documentation files (start-fn.md and finish-fn.md)
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for other mentions of builder_type to verify consistency
rg -t md "builder_type" website/

Length of output: 2709


Script:

#!/bin/bash
# Check content of v1 and v2 builder_type documentation
cat website/v1/reference/builder.md website/v2/reference/builder.md

Length of output: 61860

website/reference/builder/top-level/start-fn.md (3)

33-38: LGTM! Clear and well-structured table.

The table effectively communicates the default naming rules for different syntax patterns.

🧰 Tools
🪛 LanguageTool

[duplication] ~38-~38: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)


Line range hint 50-86: LGTM! Well-structured examples with clear highlighting.

The examples effectively demonstrate both short and long syntax variants with appropriate code highlighting.

🧰 Tools
🪛 LanguageTool

[duplication] ~38-~38: Possible typo: you repeated a word
Context: ...fn T::fn_name()|{fn_name}| Freefn fn_name() |{fn_name} ##v...

(ENGLISH_WORD_REPEAT_RULE)


Line range hint 89-150: LGTM! Excellent documentation of function exposure behavior.

The section thoroughly explains the interaction between original functions and builder syntax, with clear examples for both free functions and associated methods. The cargo features example is particularly valuable for library maintainers.

website/reference/builder/top-level/derive.md (3)

5-5: LGTM! Clear and attention-grabbing warning.

The warning effectively prevents confusion between similar but different attributes.


7-7: LGTM! Clear attribute description.

The explanation is precise and includes all necessary details about syntax and supported derives.


122-129: LGTM! Comprehensive explanation of generic type handling.

The section effectively explains the problem, solution, and includes a helpful reference for deeper understanding.

Also applies to: 174-178

website/reference/builder/top-level/on.md (3)

Line range hint 1-85: LGTM! Clear introduction with well-structured examples.

The introduction effectively explains the on attribute's purpose and demonstrates its usage across different contexts (structs, free functions, and associated methods).


Line range hint 105-173: LGTM! Comprehensive examples with clear explanations.

The examples effectively demonstrate each attribute's usage with appropriate comments explaining the behavior.


Line range hint 174-198: LGTM! Clear explanation of multiple clause usage.

The section effectively explains the consecutive clause requirement and demonstrates it with a practical example using different types.

website/.vitepress/config.mts (3)

221-224: LGTM! The new top-level attribute entry is well-structured.

The "state_mod" entry follows the established pattern and maintains consistent formatting with other top-level attributes.


247-250: LGTM! The new member attribute entries are properly structured.

Both "overwritable" and "transparent" entries maintain consistent formatting and are correctly placed alphabetically within the member attributes section.

Also applies to: 259-262


221-224: Verify that the new documentation pages exist.

Let's ensure that the documentation files for the new attributes exist at the referenced paths.

Also applies to: 247-250, 259-262

✅ Verification successful

Documentation files exist at the referenced paths

All the documentation files mentioned in the navigation links are present in the repository:

  • website/reference/builder/top-level/state-mod.md
  • website/reference/builder/member/overwritable.md
  • website/reference/builder/member/transparent.md
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if the new documentation files exist

echo "Checking for new documentation files..."
for path in \
    "reference/builder/top-level/state-mod.md" \
    "reference/builder/member/overwritable.md" \
    "reference/builder/member/transparent.md"
do
    if [ -f "website/$path" ]; then
        echo "✓ Found: $path"
    else
        echo "✗ Missing: $path"
    fi
done

Length of output: 1024

website/changelog.md (1)

13-61: LGTM! Well-structured changelog with clear sections.

The changelog follows best practices with:

  • Clear marking of breaking changes with ⚠️
  • Consistent reference to PR numbers
  • Good separation between sections
  • Proper versioning format
🧰 Tools
🪛 LanguageTool

[uncategorized] ~16-~16: Possible missing comma found.
Context: ...attributes syntax. Only parentheses are accepted e.g. #[builder(finish_fn(...))] or `#...

(AI_HYDRA_LEO_MISSING_COMMA)


[formatting] ~18-~18: If the ‘because’ clause is essential to the meaning, do not use a comma before the clause.
Context: ..., finish_fn = build, on(Vec<_>, into))], because there is a finish_fn = ...betweeno...

(COMMA_BEFORE_BECAUSE)


[uncategorized] ~41-~41: Possible missing comma found.
Context: ...nfields to opt out from their special handling which makesbon` treat them as regular...

(AI_HYDRA_LEO_MISSING_COMMA)


[style] ~45-~45: This expression usually appears with a “please” in front of it.
Context: ...s://github.com//issues/149), let us know if you need this attribute!). ([#145](h...

(INSERT_PLEASE)


[uncategorized] ~57-~57: Possible missing comma found.
Context: ...lt value in the docs. - For optional members provide a link to a companion setter. T...

(AI_HYDRA_LEO_MISSING_COMMA)


[uncategorized] ~61-~61: Use a comma before ‘but’ if it connects two independent clauses (unless they are closely connected and short).
Context: ...nd should be reported via a Github issue but this provides an easy temporary workaro...

(COMMA_COMPOUND_SENTENCE_2)

website/reference/builder/top-level/on.md Outdated Show resolved Hide resolved
@Veetaha Veetaha changed the title Update docs for bon 3.0 release Update docs for bon 3.0 release (part 1) Oct 31, 2024
@Veetaha Veetaha marked this pull request as ready for review October 31, 2024 01:28
@Veetaha Veetaha merged commit 8dc644c into master Oct 31, 2024
25 of 26 checks passed
@Veetaha Veetaha deleted the feat/more-docs-for-v3 branch October 31, 2024 01:30
@Veetaha Veetaha mentioned this pull request Oct 31, 2024
18 tasks
@github-actions github-actions bot mentioned this pull request Nov 9, 2024
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.

2 participants