Skip to content

Commit

Permalink
Merge pull request #576 from purescript/403
Browse files Browse the repository at this point in the history
Fix #403
  • Loading branch information
paf31 committed Aug 25, 2014
2 parents 21b4a49 + f17896d commit 7af7355
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 1 deletion.
7 changes: 7 additions & 0 deletions examples/passing/NegativeBinder.purs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
module Main where

test :: Number -> Boolean
test -1 = false
test _ = true

main = Debug.Trace.trace "Done"
9 changes: 8 additions & 1 deletion src/Language/PureScript/Parser/Declarations.hs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,9 @@ module Language.PureScript.Parser.Declarations (
) where

import Data.Maybe (isJust, fromMaybe)

import Control.Applicative
import Control.Arrow ((+++))

import Language.PureScript.Parser.State
import Language.PureScript.Parser.Common
Expand Down Expand Up @@ -365,7 +367,12 @@ parseBooleanBinder :: P.Parsec String ParseState Binder
parseBooleanBinder = BooleanBinder <$> booleanLiteral

parseNumberBinder :: P.Parsec String ParseState Binder
parseNumberBinder = NumberBinder <$> C.integerOrFloat
parseNumberBinder = NumberBinder <$> (C.lexeme sign <*> C.integerOrFloat)
where
sign :: P.Parsec String ParseState (Either Integer Double -> Either Integer Double)
sign = (P.char '-' >> return (negate +++ negate))
<|> (P.char '+' >> return id)
<|> return id

parseVarBinder :: P.Parsec String ParseState Binder
parseVarBinder = VarBinder <$> C.parseIdent
Expand Down

0 comments on commit 7af7355

Please sign in to comment.