haskell-language-server icon indicating copy to clipboard operation
haskell-language-server copied to clipboard

Explicit Records Plugin's (in some scenarios) codeAction doesn't work

Open joyfulmantis opened this issue 2 years ago • 4 comments

Your environment

Which OS do you use? Fedora 38

Which version of GHC do you use, and how did you install it? 9.4.4 from GHCup

Which LSP client (editor/plugin) do you use? VS Code 1.77.3+vscode-haskell

Which version of HLS do you use and how did you install it? hls-1.10.0.0 from GHCup

Have you configured HLS in any way (especially: a hie.yaml file)? no

Steps to reproduce

I can reproduce this bug in VS Code with the following code by clicking on the record wildcards and then following the code action to expand them.

{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedRecordDot #-}

data Happy = Happy {name :: String, age :: Int, happy :: Bool}

main :: IO ()
main = do 
    putStrLn test4

test1 Happy {..}= name

test4 = name man

man :: Happy
man = Happy {name = "Happy", age = 1, happy = True}

Expected behaviour

I expect the codeAction to modify the code.

Actual behaviour

However, nothing happens.

Debug information

I have traced the messages between the hls server and vscode, and the codeAction seems to be fine, but for some reason it won't execute.

Result: [
    {
        "edit": {
            "changes": {
                "file:///[retracted]/Test.hs": [
                    {
                        "newText": "Happy {name}",
                        "range": {
                            "end": {
                                "character": 16,
                                "line": 10
                            },
                            "start": {
                                "character": 6,
                                "line": 10
                            }
                        }
                    }
                ]
            }
        },
        "kind": "refactor.rewrite",
        "title": "Expand record wildcard"
    }
]

This is especially puzzling because small changes in the program cause it to work, just this specific code doesn't. For example, slightly modifying it so that test1 and test4 switch places causes it to work.

{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedRecordDot #-}

data Happy = Happy {name :: String, age :: Int, happy :: Bool}

main :: IO ()
main = do 
    putStrLn test4

test4 = name man

test1 Happy {..} = name

man :: Happy
man = Happy {name = "Happy", age = 1, happy = True}

Looking at the codeAction that works, it is almost identical.

Result: [
    {
        "edit": {
            "changes": {
                "file://[retracted]/Test.hs": [
                    {
                        "newText": "Happy {name}",
                        "range": {
                            "end": {
                                "character": 16,
                                "line": 12
                            },
                            "start": {
                                "character": 6,
                                "line": 12
                            }
                        }
                    }
                ]
            }
        },
        "kind": "refactor.rewrite",
        "title": "Expand record wildcard"
    }
]

joyfulmantis avatar Apr 14 '23 12:04 joyfulmantis

Ping @ozkutuk as the code owner

July541 avatar Apr 16 '23 07:04 July541

This seems pretty interesting; it works as expected on Neovim (via native LSP), whereas I can indeed replicate the issue on VSCode, using the same HLS build on both. Which makes me think, could this possibly be an issue with vscode-haskell?

ozkutuk avatar Apr 25 '23 23:04 ozkutuk

I've also been hit by this bug. Environment:

  • OS: Ubuntu 20.04.6 LTS (connected via VSCode Remote with the client running on macOS Sonoma)
  • GHC: 9.2.8, installed via GHCup
  • LSP Client: VSCode 1.85.2 with vscode-haskell v2.5.2
  • HLS: 2.6.0.0, installed via GHCup vanilla 0.0.8

konn avatar Jan 24 '24 02:01 konn

This seems pretty interesting; it works as expected on Neovim (via native LSP), whereas I can indeed replicate the issue on VSCode, using the same HLS build on both. Which makes me think, could this possibly be an issue with vscode-haskell?

Interesting bug, I wonder if vscode-Haskell doing more than just wrapping up edits on this?

soulomoon avatar Jan 27 '24 20:01 soulomoon