Skip to content

Conversation

@nicolasstucki
Copy link
Contributor

No description provided.

Copy link
Contributor

@liufengyun liufengyun left a comment

Choose a reason for hiding this comment

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

It seems the new abstract types are not used, what is the motivation of having more refined types?

abstract class TypeTreeCoreModule {

/** Type tree representing an inferred type */
type Synthetic <: TypeTree
Copy link
Contributor

Choose a reason for hiding this comment

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

Inferred instead of Synthetic?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Good idea. I will propose it in another PR.

@nicolasstucki
Copy link
Contributor Author

They will be used once we have constructors for them (#5438) and once we refine the pattern matching on abstract types (#5438). Meanwhile, they add some additional documentation.

@nicolasstucki nicolasstucki merged commit bcdc431 into scala:master Nov 21, 2018
@nicolasstucki nicolasstucki deleted the add-missing-tasty-types branch November 21, 2018 10:00
type Return = tpd.Return
type Repeated = tpd.SeqLiteral
type Inlined = tpd.Inlined
type SelectOuter = tpd.Select
Copy link
Contributor

Choose a reason for hiding this comment

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

What is SelectOuter? I think maybe there is no need for constructor for Inline

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Select outer is a special case of a Select where it keeps track of the inlined scoped to avoid ambiguities.

Inline is used to keep track of the source file where the tree came from to have a correct position. If the macros would just drop them, every position in the resulting tree would be incorrect.

@liufengyun
Copy link
Contributor

When working on gestalt, I have a hypothesis that macro authors will never need to inspect type trees, because type trees are not semantic -- instead they can always inspect types. If this assumption is true, it can help simplify the reflection API.

@nicolasstucki
Copy link
Contributor Author

That is assuming that we do not care about positions. For example we would not be able to emit an error such as:

fooMacro[List[Int]]
              ^^^

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