Skip to content

Commit

Permalink
[typing] Fix const literal reason description
Browse files Browse the repository at this point in the history
  • Loading branch information
goodmind committed Aug 20, 2019
1 parent 7fd3128 commit 01ef2d2
Showing 1 changed file with 11 additions and 11 deletions.
22 changes: 11 additions & 11 deletions src/typing/statement.ml
Original file line number Diff line number Diff line change
Expand Up @@ -4320,29 +4320,29 @@ and literal ?(is_const=false) cx loc lit =
then Literal (None, s), RString
else AnyLiteral, RLongStringLit (max_literal_length)
in
let lit_type = match lit with
| Literal (_, s) when is_const -> SingletonStrT s
| _ -> StrT lit
let lit_type, r_desc = match (lit, r_desc) with
| (Literal (_, s), _) when is_const -> SingletonStrT s, RStringLit s
| (_, r_desc) -> StrT lit, r_desc
in
DefT (annot_reason (mk_reason r_desc loc), make_trust (), lit_type)
end

| Boolean b ->
let lit_type = if is_const
then SingletonBoolT b
else BoolT (Some b)
let lit_type, r_desc = if is_const
then SingletonBoolT b, RBooleanLit b
else BoolT (Some b), RBoolean
in
DefT (annot_reason (mk_reason RBoolean loc), make_trust (), lit_type)
DefT (annot_reason (mk_reason r_desc loc), make_trust (), lit_type)

| Null ->
NullT.at loc |> with_trust make_trust

| Number f ->
let lit_type = if is_const
then SingletonNumT (f, lit.raw)
else NumT (Literal (None, (f, lit.raw)))
let lit_type, r_desc = if is_const
then SingletonNumT (f, lit.raw), RNumberLit lit.raw
else NumT (Literal (None, (f, lit.raw))), RNumber
in
DefT (annot_reason (mk_reason RNumber loc), make_trust (), lit_type)
DefT (annot_reason (mk_reason r_desc loc), make_trust (), lit_type)

| BigInt _ ->
let reason = annot_reason (mk_reason (RBigIntLit lit.raw) loc) in
Expand Down

0 comments on commit 01ef2d2

Please sign in to comment.