Skip to content
This repository was archived by the owner on Jun 15, 2023. It is now read-only.

Fix parsing of first class module exprs as part of binary/ternary expr #256

Merged
merged 2 commits into from
Feb 4, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 4 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
## Unreleased

## 9.0
* Fix parsing of first class module exprs as part of binary/ternary expr in [#256](https://github.com/rescript-lang/syntax/pull/256)

* Fix parsing of poly-var typexpr consisting of one tag-spec-first in [254](https://github.com/rescript-lang/syntax/pull/254)
## ReScript 9.0.0

* Fix parsing of poly-var typexpr consisting of one tag-spec-first in [#254](https://github.com/rescript-lang/syntax/pull/254)
* Implement new syntax for guards on pattern match cases in [#248](https://github.com/rescript-lang/syntax/pull/248)
* Implement intelligent breaking for poly-var type expressions in [#246](https://github.com/rescript-lang/syntax/pull/246)
* Improve indentation of fast pipe chain in let binding in [#244](https://github.com/rescript-lang/syntax/pull/244)
Expand Down
8 changes: 7 additions & 1 deletion src/res_core.ml
Original file line number Diff line number Diff line change
Expand Up @@ -2961,7 +2961,10 @@ and parseExprBlockItem p =
Parser.next p;
begin match p.token with
| Lparen ->
parseFirstClassModuleExpr ~startPos p
let expr = parseFirstClassModuleExpr ~startPos p in
let a = parsePrimaryExpr ~operand:expr p in
let expr = parseBinaryExpr ~a p 1 in
parseTernaryExpr expr p
| _ ->
let name = match p.Parser.token with
| Uident ident ->
Expand Down Expand Up @@ -5558,6 +5561,9 @@ and parseModuleOrModuleTypeImplOrPackExpr ~attrs p =
| Typ -> parseModuleTypeImpl ~attrs startPos p
| Lparen ->
let expr = parseFirstClassModuleExpr ~startPos p in
let a = parsePrimaryExpr ~operand:expr p in
let expr = parseBinaryExpr ~a p 1 in
let expr = parseTernaryExpr expr p in
Ast_helper.Str.eval ~attrs expr
| _ -> parseMaybeRecModuleBinding ~attrs ~startPos p

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -470,7 +470,41 @@ let build_dispatch_table handlers =
[@ns.namedArgLoc ]) table)
[@ns.braces ])
;;(module Three)
;;((module Three) : (module X_int))"
;;((module Three) : (module X_int))
;;(module Teenager).(0)
;;((module Teenager) |. age) |. Js.log
;;((module Teenager).(0)) |. Js.log
;;((if ((module Teenager) |. age) |. isAdult
then Js.log \\"has responsibilities\\"
else Js.log \\"can play in the playground\\")[@ns.ternary ])
;;((if ((module Streets).(0)) |. isExpensive
then Js.log \\"big money\\"
else Js.log \\"affordable\\")[@ns.ternary ])
let () = ((((module Teenager) |. age) |. Js.log)[@ns.braces ])
let () = (((module Teenager).(0))[@ns.braces ])
let () =
((if ((module Teenager) |. age) |. isAdult
then Js.log \\"has responsibilities\\"
else Js.log \\"can play in the playground\\")
[@ns.braces ][@ns.ternary ])
let () =
((if ((module Streets).(0)) |. isExpensive
then Js.log \\"big money\\"
else Js.log \\"affordable\\")
[@ns.braces ][@ns.ternary ])
let () =
((let a = 1 in
let b = 2 in (module Teenager).(0); ((module Teenager) |. age) |. Js.log)
[@ns.braces ])
let () =
((let a = 1 in
let b = 2 in
((module Teenager) |. age) |. Js.log;
((if (((module Teenager).(0)) |. age) |. isAdult
then Js.log \\"has responsibilities\\"
else Js.log \\"can play in the playground\\")
[@ns.ternary ]))
[@ns.braces ])"
`;

exports[`float.js 1`] = `
Expand Down
33 changes: 33 additions & 0 deletions tests/parsing/grammar/expressions/firstClassModule.js
Original file line number Diff line number Diff line change
Expand Up @@ -60,3 +60,36 @@ let build_dispatch_table = handlers => {

module(Three)
module(Three: X_int)

module(Teenager)[0]
module(Teenager)->age->Js.log
module(Teenager)[0]->Js.log
module(Teenager)->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
module(Streets)[0]->isExpensive ? Js.log("big money") : Js.log("affordable")

let () = {
module(Teenager)->age->Js.log
}
let () = {
module(Teenager)[0]
}
let () = {
module(Teenager)->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
}
let () = {
module(Streets)[0]->isExpensive ? Js.log("big money") : Js.log("affordable")
}

let () = {
let a = 1
let b = 2
module(Teenager)[0]
module(Teenager)->age->Js.log
}

let () = {
let a = 1
let b = 2
module(Teenager)->age->Js.log
module(Teenager)[0]->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
}
39 changes: 39 additions & 0 deletions tests/printer/expr/__snapshots__/render.spec.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -2032,6 +2032,45 @@ let three = module(Three)

let x = @attr module(Foo)
let x = @attr module(Foo: FirstClass)

module(Teenager)[0]
module(Teenager)->age->Js.log
module(Teenager)[0]->Js.log
module(Teenager)->age->isAdult
? Js.log(\\"has responsibilities\\")
: Js.log(\\"can play in the playground\\")
module(Streets)[0]->isExpensive ? Js.log(\\"big money\\") : Js.log(\\"affordable\\")

let () = {
module(Teenager)->age->Js.log
}
let () = {
module(Teenager)[0]
}
let () = {
module(Teenager)->age->isAdult
? Js.log(\\"has responsibilities\\")
: Js.log(\\"can play in the playground\\")
}
let () = {
module(Streets)[0]->isExpensive ? Js.log(\\"big money\\") : Js.log(\\"affordable\\")
}

let () = {
let a = 1
let b = 2
module(Teenager)[0]
module(Teenager)->age->Js.log
}

let () = {
let a = 1
let b = 2
module(Teenager)->age->Js.log
module(Teenager)[0]->age->isAdult
? Js.log(\\"has responsibilities\\")
: Js.log(\\"can play in the playground\\")
}
"
`;

Expand Down
35 changes: 35 additions & 0 deletions tests/printer/expr/firstClassModule.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,38 @@ let three = module(Three)

let x = @attr module(Foo)
let x = @attr module(Foo: FirstClass)

module(Teenager)[0]
module(Teenager)->age->Js.log
module(Teenager)[0]->Js.log
module(Teenager)->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
module(Streets)[0]->isExpensive ? Js.log("big money") : Js.log("affordable")


let () = {
module(Teenager)->age->Js.log
}
let () = {
module(Teenager)[0]
}
let () = {
module(Teenager)->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
}
let () = {
module(Streets)[0]->isExpensive ? Js.log("big money") : Js.log("affordable")
}

let () = {
let a = 1
let b = 2
module(Teenager)[0]
module(Teenager)->age->Js.log
}


let () = {
let a = 1
let b = 2
module(Teenager)->age->Js.log
module(Teenager)[0]->age->isAdult ? Js.log("has responsibilities") : Js.log("can play in the playground")
}