1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
|
-- re2hs $INPUT -o $OUTPUT -i
{-# OPTIONS_GHC -Wno-unused-record-wildcards #-}
{-# LANGUAGE OverloadedStrings #-}
import Control.Monad (when)
import Data.ByteString (ByteString, index)
%{include "definitions.hs" %}
data State = State {
_yyinput :: ByteString,
_yycursor :: Int,
_yymarker :: Int,
_yyaccept :: Int
}
%{
re2c:YYFN = ["lexer;Number", "State{..};State"];
re2c:yyfill:enable = 0;
* { NNaN }
number { INum }
!include "extra_rules.re.inc";
%}
main :: IO ()
main = do
let test s n = do
let st = State {
_yyinput = s,
_yycursor = 0,
_yymarker = 0,
_yyaccept = 0}
when (lexer st /= n) $ error "failed"
test "123\0" INum
test "123.4567\0" FNum
|