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

Fix type inference example in "Creating an Empty Array" #341

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

bohdany-cricut
Copy link
Contributor

This pull request resolves an inconsistency in the "Creating an Empty Array" section of the Swift Language Guide under "Collection Types."

Changes:

  • Updated the example code by replacing var someInts: [Int] = [] with var someInts = [Int]() to accurately demonstrate type inference, aligning with the accompanying explanatory text.

Rationale:

The previous example did not demonstrate type inference, as the type [Int] was explicitly declared using : [Int]. However, the accompanying text states:

"Note that the type of the someInts variable is inferred to be [Int] from the type of the initializer."

This was misleading because type inference did not occur in the provided example. The updated example clarifies the explanation and ensures consistency across the guide, aligning with similar sections such as "Creating and Initializing an Empty Set."

Updated the array initialization example to demonstrate type inference
(var someInts = [Int]()) for consistency with other sections in the guide,
such as Sets and Dictionaries. This change aligns the code example with
the accompanying explanatory text.
@amartini51 amartini51 self-requested a review November 23, 2024 00:42
@amartini51
Copy link
Member

amartini51 commented Nov 23, 2024

Thanks for taking the time to write this up in a PR!

This change looks like it’s only in an HTML <!-- --> comment, which isn't part of the rendered book. The block that this PR changes is essentially a leftover from migration to DocC. The build system TSPL used before DocC tested the code listings. DocC doesn't support tested code listings, but we kept the tests during the export, so we would still have the hidden "expectation" lines if we ever try to resume code testing.

Looking at the rendered version of the content, the example uses this form:

var someInts: [Int] = []

However, as you noted, the text and the code don’t match: The text talks about type inference, but the code has an explicit type in it. This looks an oversight from 2021 in commit 639bcc6 when cleaning up initializer syntax throughout the book. We should keep the code as-is, since it follows the code style guidelines for empty collections.

In this case, I think we might want to just remove the mention of type inference, since it would be pretty rare to create an empty array in code that has enough type information to infer the array’s type. If we want to mention something about that, one example is passing an empty array to a function.

I'll be out of the office next week for Thanksgiving — if you'd like to try rewriting, take a look at your changes when I get back. Otherwise, I'll push another commit to your branch after the holiday, changing the prose.

- Highlight empty array literals (`[]`) as the preferred method.
- Add initializer syntax (`[Type]()`) as an alternative.
- Reorganize examples to reduce redundancy and improve clarity.
@bohdany-cricut
Copy link
Contributor Author

bohdany-cricut commented Nov 25, 2024

@amartini51 Thank you for taking the time to review my PR! I appreciate the context regarding the migration to DocC.

After carefully considering your feedback, I believe the best solution would be to update the example to use the actual initializer syntax as an alternative to the preferred array literal syntax. Here’s why I think this approach would address the concerns and improve the clarity of the guide:

1. Clarifying "Initializer Syntax"
The section currently states:

You can create an empty array of a certain type using initializer syntax.

However, the example provided (var someInts: [Int] = []) does not use an initializer. Instead, it assigns an empty array literal to a variable with an explicitly declared type. This is misleading because it does not demonstrate what "initializer syntax" means.

Updating the section to explicitly show both methods - the preferred array literal syntax ([]) and the initializer syntax ([Int]()) - provides clarity and ensures completeness. Additionally, it’s worth noting that the "Collection Types" page doesn’t currently include any examples showcasing the array initializer syntax.

2. Avoiding Redundancy

The "Alternatively" example, which follows the initializer syntax section, states:

Alternatively, if the context already provides type information, such as a function argument or an already typed variable or constant, you can create an empty array with an empty array literal, which is written as [] (an empty pair of square brackets):

This is illustrated with:

someInts = []

However, this example demonstrates the same concept as the first example: assigning an empty array literal ([]) to a variable. This creates redundancy without adding new information.

By explicitly stating that the array literal ([]) is the preferred method and introducing the initializer syntax ([Int]()) as an alternative, the section would comprehensively cover both ways of creating an empty array without duplication.

These aren't used for anything today -- they're just an (intentional)
leftover from RST migration, to ease a possible re-adoption of tested
code listings some day.
I think pointing out [Int]() from the code example is easier to follow
than [Element](), since the reader doesn't have to mentally map or
substitute a placeholder.

Reserve emphasis around new terms for when they're being introduced and
also explicitly defined.

No need to call out the book's style in the book itself.
@amartini51
Copy link
Member

Thanks for your revision and for your patience — I expected to come back to this PR sooner. I've pushed a few minor changes to this branch. This looks good to me now.

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