Skip to content

Conversation

@hdgarrood
Copy link
Collaborator

Seems to work. Fixes #174

@hdgarrood
Copy link
Collaborator Author

Ah, this behaves oddly if you give the module a name of an existing module in the package set. For example, if I call the current module Data.Semiring and try to use + within it, then I get a "ReferenceError: $foreign is not defined". Perhaps I should rewrite the module name to Main to ensure that it doesn't clash with any module name in the package set?

@hdgarrood
Copy link
Collaborator Author

This now seems to work even if I try to redefine an existing module. I haven't been able to think of a way that rewriting the module name like this would be an issue, it seems like a slightly nicer UX for what is essentially the same idea (only modules with a specific module name are allowed).

Copy link
Member

@thomashoneyman thomashoneyman left a comment

Choose a reason for hiding this comment

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

A nice improvement. We’ll have to revisit this if Try PureScript ever supports multiple files / modules but that’s a faraway future.

-- Rewrite the module name to "$Main" in order to ensure that the
-- module name doesn't clash with any existing module names in
-- the package set.
let rewriteModuleName (P.Module ss coms _ decls refs) = P.Module ss coms (P.moduleNameFromString "$Main") decls refs
Copy link
Contributor

Choose a reason for hiding this comment

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

If someone attempts to play with module export syntax this might be cause problems with:

module Foo (module Bar, module Foo) where ...

Copy link
Contributor

Choose a reason for hiding this comment

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

I'll wager this is by far an edge case, however 😆

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Ah, good point. I think re-exporting main from elsewhere seems plausible to want to do, so perhaps this isn't the best approach. Maybe we should assemble a set of used module names from the externs files, and then instead of rewriting, just check that the given module name is not included in that set?

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.

Allow module names other than Main

3 participants