aboutsummaryrefslogtreecommitdiff
path: root/src/Language/SimpleShell/Parser/Name.hs
blob: 235a9fb09fb504ebe72f04f7554bedc27d61a164 (plain)
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
{-# LANGUAGE FlexibleContexts #-}

module Language.SimpleShell.Parser.Name
  ( nameP
  , keyword
  )
where


import Language.SimpleShell.Parser.Common.Lexeme (lexeme)

import Control.Monad (void)
import Data.Text (Text, cons)
import Data.Char (isAlpha, isAlphaNum)
import Text.Megaparsec (MonadParsec, takeWhileP, satisfy, notFollowedBy, try)
import Text.Megaparsec.Char (string)


isNameStartChar :: Char -> Bool
isNameStartChar c = isAlpha c || c == '_'

isNameChar :: Char -> Bool
isNameChar c = isAlphaNum c || c == '_'


nameP :: (MonadParsec e Text m) => m Text
nameP =
  lexeme $ cons <$> satisfy isNameStartChar <*> takeWhileP Nothing isNameChar


keyword :: (MonadParsec e Text m) => Text -> m ()
keyword kw =
  void $ lexeme $ try $ string kw <* notFollowedBy (satisfy isNameChar)