diff options
Diffstat (limited to 'compiler/parser')
| -rw-r--r-- | compiler/parser/Lexer.x | 5 | ||||
| -rw-r--r-- | compiler/parser/Parser.y.pp | 70 | 
2 files changed, 40 insertions, 35 deletions
| diff --git a/compiler/parser/Lexer.x b/compiler/parser/Lexer.x index 76a02d6c60..43a400471e 100644 --- a/compiler/parser/Lexer.x +++ b/compiler/parser/Lexer.x @@ -483,6 +483,7 @@ data Token    | ITlanguage_prag    | ITvect_prag    | ITvect_scalar_prag +  | ITnovect_prag    | ITdotdot  			-- reserved symbols    | ITcolon @@ -2281,7 +2282,8 @@ oneWordPrags = Map.fromList([("rules", rulePrag),                             ("core", token ITcore_prag),                             ("unpack", token ITunpack_prag),                             ("ann", token ITann_prag), -                           ("vectorize", token ITvect_prag)]) +                           ("vectorize", token ITvect_prag), +                           ("novectorize", token ITnovect_prag)])  twoWordPrags = Map.fromList([("inline conlike", token (ITinline_prag Inline ConLike)),                               ("notinline conlike", token (ITinline_prag NoInline ConLike)), @@ -2307,6 +2309,7 @@ clean_pragma prag = canon_ws (map toLower (unprefix prag))                                                "noinline" -> "notinline"                                                "specialise" -> "specialize"                                                "vectorise" -> "vectorize" +                                              "novectorise" -> "novectorize"                                                "constructorlike" -> "conlike"                                                _ -> prag'                            canon_ws s = unwords (map canonical (words s)) diff --git a/compiler/parser/Parser.y.pp b/compiler/parser/Parser.y.pp index 01d768a4d7..b663ac2aba 100644 --- a/compiler/parser/Parser.y.pp +++ b/compiler/parser/Parser.y.pp @@ -252,21 +252,22 @@ incorrect.   'by'       { L _ ITby }        -- for list transform extension   'using'    { L _ ITusing }     -- for list transform extension - '{-# INLINE'      	  { L _ (ITinline_prag _ _) } - '{-# SPECIALISE'  	  { L _ ITspec_prag } + '{-# INLINE'             { L _ (ITinline_prag _ _) } + '{-# SPECIALISE'         { L _ ITspec_prag }   '{-# SPECIALISE_INLINE'  { L _ (ITspec_inline_prag _) } - '{-# SOURCE'	   { L _ ITsource_prag } - '{-# RULES'	   { L _ ITrules_prag } - '{-# CORE'        { L _ ITcore_prag }              -- hdaume: annotated core - '{-# SCC'	   { L _ ITscc_prag } - '{-# GENERATED'   { L _ ITgenerated_prag } - '{-# DEPRECATED'  { L _ ITdeprecated_prag } - '{-# WARNING'     { L _ ITwarning_prag } - '{-# UNPACK'      { L _ ITunpack_prag } - '{-# ANN'         { L _ ITann_prag } + '{-# SOURCE'      				{ L _ ITsource_prag } + '{-# RULES'       				{ L _ ITrules_prag } + '{-# CORE'        				{ L _ ITcore_prag }              -- hdaume: annotated core + '{-# SCC'                { L _ ITscc_prag } + '{-# GENERATED'          { L _ ITgenerated_prag } + '{-# DEPRECATED'         { L _ ITdeprecated_prag } + '{-# WARNING'            { L _ ITwarning_prag } + '{-# UNPACK'             { L _ ITunpack_prag } + '{-# ANN'                { L _ ITann_prag }   '{-# VECTORISE'          { L _ ITvect_prag }   '{-# VECTORISE_SCALAR'   { L _ ITvect_scalar_prag } - '#-}'		   { L _ ITclose_prag } + '{-# NOVECTORISE'        { L _ ITnovect_prag } + '#-}'             				{ L _ ITclose_prag }   '..'		{ L _ ITdotdot }  			-- reserved symbols   ':'		{ L _ ITcolon } @@ -546,33 +547,34 @@ ops   	:: { Located [Located RdrName] }  -- Top-Level Declarations  topdecls :: { OrdList (LHsDecl RdrName) } -        : topdecls ';' topdecl		        { $1 `appOL` $3 } -        | topdecls ';'			        { $1 } -	| topdecl			        { $1 } +        : topdecls ';' topdecl                  { $1 `appOL` $3 } +        | topdecls ';'                          { $1 } +        | topdecl                               { $1 }  topdecl :: { OrdList (LHsDecl RdrName) } -  	: cl_decl			{ unitOL (L1 (TyClD (unLoc $1))) } -  	| ty_decl			{ unitOL (L1 (TyClD (unLoc $1))) } -	| 'instance' inst_type where_inst -	    { let (binds, sigs, ats, _) = cvBindsAndSigs (unLoc $3) -	      in  -	      unitOL (L (comb3 $1 $2 $3) (InstD (InstDecl $2 binds sigs ats)))} +        : cl_decl                       { unitOL (L1 (TyClD (unLoc $1))) } +        | ty_decl                       { unitOL (L1 (TyClD (unLoc $1))) } +        | 'instance' inst_type where_inst +            { let (binds, sigs, ats, _) = cvBindsAndSigs (unLoc $3) +              in  +              unitOL (L (comb3 $1 $2 $3) (InstD (InstDecl $2 binds sigs ats)))}          | stand_alone_deriving                  { unitOL (LL (DerivD (unLoc $1))) } -	| 'default' '(' comma_types0 ')'	{ unitOL (LL $ DefD (DefaultDecl $3)) } -	| 'foreign' fdecl			{ unitOL (LL (unLoc $2)) } +        | 'default' '(' comma_types0 ')'        { unitOL (LL $ DefD (DefaultDecl $3)) } +        | 'foreign' fdecl                       { unitOL (LL (unLoc $2)) }          | '{-# DEPRECATED' deprecations '#-}'   { $2 }          | '{-# WARNING' warnings '#-}'          { $2 } -	| '{-# RULES' rules '#-}'		{ $2 } -	| '{-# VECTORISE_SCALAR' qvar '#-}'	{ unitOL $ LL $ VectD (HsVect $2 Nothing) } -	| '{-# VECTORISE' qvar '=' exp '#-}'	{ unitOL $ LL $ VectD (HsVect $2 (Just $4)) } -	| annotation { unitOL $1 } -      	| decl					{ unLoc $1 } - -	-- Template Haskell Extension -	-- The $(..) form is one possible form of infixexp -	-- but we treat an arbitrary expression just as if  -	-- it had a $(..) wrapped around it -	| infixexp 				{ unitOL (LL $ mkTopSpliceDecl $1) }  +        | '{-# RULES' rules '#-}'               { $2 } +        | '{-# VECTORISE_SCALAR' qvar '#-}'     { unitOL $ LL $ VectD (HsVect   $2 Nothing) } +        | '{-# VECTORISE' qvar '=' exp '#-}'    { unitOL $ LL $ VectD (HsVect   $2 (Just $4)) } +        | '{-# NOVECTORISE' qvar '#-}'     			{ unitOL $ LL $ VectD (HsNoVect $2) } +        | annotation { unitOL $1 } +        | decl                                  { unLoc $1 } + +        -- Template Haskell Extension +        -- The $(..) form is one possible form of infixexp +        -- but we treat an arbitrary expression just as if  +        -- it had a $(..) wrapped around it +        | infixexp                              { unitOL (LL $ mkTopSpliceDecl $1) }   -- Type classes  -- | 
