diff options
Diffstat (limited to 'compiler/parser')
| -rw-r--r-- | compiler/parser/Lexer.x | 10 | ||||
| -rw-r--r-- | compiler/parser/Parser.y.pp | 4 | 
2 files changed, 11 insertions, 3 deletions
| diff --git a/compiler/parser/Lexer.x b/compiler/parser/Lexer.x index 5e6535678e..5c41d7238d 100644 --- a/compiler/parser/Lexer.x +++ b/compiler/parser/Lexer.x @@ -485,6 +485,8 @@ data Token    | IToptions_prag String    | ITinclude_prag String    | ITlanguage_prag +  | ITvect_prag +  | ITvect_scalar_prag    | ITdotdot  			-- reserved symbols    | ITcolon @@ -2275,13 +2277,14 @@ oneWordPrags = Map.fromList([("rules", rulePrag),                             ("generated", token ITgenerated_prag),                             ("core", token ITcore_prag),                             ("unpack", token ITunpack_prag), -                           ("ann", token ITann_prag)]) +                           ("ann", token ITann_prag), +                           ("vectorize", token ITvect_prag)])  twoWordPrags = Map.fromList([("inline conlike", token (ITinline_prag Inline ConLike)),                               ("notinline conlike", token (ITinline_prag NoInline ConLike)),                               ("specialize inline", token (ITspec_inline_prag True)), -                             ("specialize notinline", token (ITspec_inline_prag False))]) - +                             ("specialize notinline", token (ITspec_inline_prag False)), +                             ("vectorize scalar", token ITvect_scalar_prag)])  dispatch_pragmas :: Map String Action -> Action  dispatch_pragmas prags span buf len = case Map.lookup (clean_pragma (lexemeToString buf len)) prags of @@ -2300,6 +2303,7 @@ clean_pragma prag = canon_ws (map toLower (unprefix prag))                            canonical prag' = case prag' of                                                "noinline" -> "notinline"                                                "specialise" -> "specialize" +                                              "vectorise" -> "vectorize"                                                "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 a0cc96417c..bfadfbaff8 100644 --- a/compiler/parser/Parser.y.pp +++ b/compiler/parser/Parser.y.pp @@ -266,6 +266,8 @@ incorrect.   '{-# 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 }   '..'		{ L _ ITdotdot }  			-- reserved symbols @@ -563,6 +565,8 @@ topdecl :: { OrdList (LHsDecl RdrName) }          | '{-# 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 } | 
