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

PrettyPrinter reports wrong line numbers #882

Open
bkolb opened this issue Nov 23, 2024 · 2 comments
Open

PrettyPrinter reports wrong line numbers #882

bkolb opened this issue Nov 23, 2024 · 2 comments

Comments

@bkolb
Copy link
Contributor

bkolb commented Nov 23, 2024

I have a file with a copyright header. This leads to the reporting of wrong line numbers in rules like EndOfLineComment

Here is an example where the reporting works as expected:

final class A {
    @Test func b() throws {
        doSomethingInAFunctionWithAVeryLongName()  1️⃣// Here we have a very long comment that should not be here because it is far too long
    }
}

Changing the input to the following will fail:

// Copyright (C) 2024 My Coorp. All rights reserved.
//
// This document is the property of My Coorp.
// It is considered confidential and proprietary.
//
// This document may not be reproduced or transmitted in any form,
// in whole or in part, without the express written permission of
// My Coorp.

final class A {
    @Test func b() throws {
        doSomethingInAFunctionWithAVeryLongName()  1️⃣// Here we have a very long comment that should not be here because it is far too long
    }
}

The error is here is reported in location (line:col 5:52) and should be in (line:col 12:52)

bkolb added a commit to bkolb/swift-format that referenced this issue Nov 23, 2024
This is to reproduce issue swiftlang#882.
No fix is provided yet.

Issue: swiftlang#882
bkolb added a commit to bkolb/swift-format that referenced this issue Nov 23, 2024
This is to reproduce issue swiftlang#882.
No fix is provided yet.

Issue: swiftlang#882
@bkolb
Copy link
Contributor Author

bkolb commented Nov 23, 2024

My suspicion is, that the pretty printer is thrown off by multiline comments. In that case, it seems to add only one line for an entire comment block.

bkolb added a commit to bkolb/swift-format that referenced this issue Nov 23, 2024
The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
@ahoppen
Copy link
Member

ahoppen commented Nov 24, 2024

Synced to Apple’s issue tracker as rdar://140495994

bkolb added a commit to bkolb/swift-format that referenced this issue Dec 2, 2024
The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
bkolb added a commit to bkolb/swift-format that referenced this issue Dec 3, 2024
The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
bkolb added a commit to bkolb/swift-format that referenced this issue Dec 4, 2024
The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
bkolb added a commit to bkolb/swift-format that referenced this issue Dec 4, 2024
The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
macshome pushed a commit to macshome/swift-format that referenced this issue Dec 5, 2024
Squashed commits:
[23709e8] Fix issue in publish_release pipeline testing swift-format in debug configuration
[ce212ca] Use matrix to run debug and release
[39ee6a2] Run Windows tests before tagging a release

The GitHub workflows enabled Windows in the testing matrix. We needed to port the pre-build commands that apply the release commits to Windows to make the Windows checks pass.
[8fec655] Use dockerless Windows jobs

Dockerless Windows is 5-10 minutes faster than Docker on Windows
[2cd032c] PrettyPrinter reports wrong line LineNumbersTests

The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882
[8c68ec3] Add indentBlankLines configuration
[fee42c9] Add `--enable-experimental-feature` to enable those features in the parser.

Also add a couple small tests for value generics to exercise the capability in
tests.

Fixes swiftlang#875.
[5e4caa8] feat: add pre-commit hooks
[e6aa9ec] Update UseShorthandTypeNames.swift
[9cbc942] Update UseShorthandTypeNames.swift
[dfb366a] Fix formatting
[c3b0c9f] Prepare for integer generics with new generic argument node
[211884f] Fix tests when building swift-format using Swift 6.0.2

When traversing the file URL with Foundation from Swift 6.0.2, you get the following components
- `["/", "C:", "test.swift"]`
- `["/", "C:"]`
- `[]`

The component count never reaches 1.

Foundation from Swift 6.1 goes
- `["/", "C:", "test.swift"]`
- `["/", "C:"]`
- `["/"]`

Cover both cases by checking for `<= 1` instead of `== 1`

Prepare for integer generics with new generic argument node

Fix formatting

Update UseShorthandTypeNames.swift

Update UseShorthandTypeNames.swift

feat: add pre-commit hooks

Add `--enable-experimental-feature` to enable those features in the parser.

Also add a couple small tests for value generics to exercise the capability in
tests.

Fixes swiftlang#875.

Add indentBlankLines configuration

PrettyPrinter reports wrong line LineNumbersTests

The reason for the wrong line number were multiline
comments.
In to accomodate for this, we now check the string
while writing for new lines and increment the line
count accordingly.

Issue: swiftlang#882

Use dockerless Windows jobs

Dockerless Windows is 5-10 minutes faster than Docker on Windows

Run Windows tests before tagging a release

The GitHub workflows enabled Windows in the testing matrix. We needed to port the pre-build commands that apply the release commits to Windows to make the Windows checks pass.

Use matrix to run debug and release

Fix issue in publish_release pipeline testing swift-format in debug configuration

Run Windows tests dockerless
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

No branches or pull requests

2 participants