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

18 vscode hoverprovider ls #212

Merged
merged 8 commits into from
Aug 14, 2023
Merged

Conversation

jjohnsoncertinia
Copy link
Contributor

No description provided.


object HoverItem {
implicit val rw: RW[HoverItem] = macroRW
implicit val rwLocation: RW[Location] = macroRW
Copy link
Contributor Author

Choose a reason for hiding this comment

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

I'm not exactly sure what these variables do but the other objects have them so I just copied them.

Copy link
Contributor

@pwrightcertinia pwrightcertinia Aug 9, 2023

Choose a reason for hiding this comment

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

These will be used by apex-ls own RPC implementation to do the json serialization. We are not using that right now, so the rpc endpoint is not fully defined yet. Given a certain type, it will use the implicit val for that type (which is why we also need another val for the Location type) to perform the serialise.

return toString + " implements " + interfaces.map(i => i.name).mkString(", ")
} else if (
// Seems like all classes extend a default 'Object$' class
superClassDeclaration.isDefined && superClassDeclaration.get.name.value != "Object$"
Copy link
Contributor

@pwrightcertinia pwrightcertinia Aug 9, 2023

Choose a reason for hiding this comment

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

I feel like there is a different way to do this that isn't a string check - something like superClass.contains(TypeNames.InternalObject) might do it ? @kjonescertinia help

Copy link
Contributor

@kjonescertinia kjonescertinia Aug 9, 2023

Choose a reason for hiding this comment

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

Yeah, that should do it, superClass just gives you the TypeName which is cheap, superClassDeclaration resolves the type to give you the declaration object which can be a bit more expensive.
The other bit to handle here is classes which have both a superclass and implement some interfaces. I would probably structure that just as string concat of parts where the parts may have content like "extends A" or maybe empty.
One extra bit is that if you can make use of the toString on TypeName. It masks some of the internal names to make things a bit more readable e.g. for InternalObject it will give you "Object" not "Internal.Object$".

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I have made these changes. Also added a test case for when a class extends and implements.

@jjohnsoncertinia jjohnsoncertinia self-assigned this Aug 10, 2023
@pwrightcertinia pwrightcertinia merged commit 071177d into main Aug 14, 2023
@pwrightcertinia pwrightcertinia deleted the 18-vscode-hoverprovider-ls branch August 14, 2023 10:38
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.

3 participants