diff options
| -rw-r--r-- | src/Data/Char/Extended.hs | 12 | ||||
| -rw-r--r-- | src/Reaktor/Plugins/Mention.hs | 4 | 
2 files changed, 13 insertions, 3 deletions
diff --git a/src/Data/Char/Extended.hs b/src/Data/Char/Extended.hs index add079d..34d0c3e 100644 --- a/src/Data/Char/Extended.hs +++ b/src/Data/Char/Extended.hs @@ -1,9 +1,19 @@  module Data.Char.Extended      ( module Data.Char      , isAsciiLetter +    , isNick      ) where  import Data.Char  isAsciiLetter :: Char -> Bool -isAsciiLetter c = Data.Char.isAsciiUpper c || Data.Char.isAsciiLower c +isAsciiLetter c = isAsciiUpper c || isAsciiLower c + +-- RFC1459 +isNick :: Char -> Bool +isNick c = +    0x41 <= i && i <= 0x7D || -- letters / specials +    0x30 <= i && i <= 0x39 || -- digits +    0x2D == i                 -- minus +  where +    i = ord c diff --git a/src/Reaktor/Plugins/Mention.hs b/src/Reaktor/Plugins/Mention.hs index b288fdb..b0dcca1 100644 --- a/src/Reaktor/Plugins/Mention.hs +++ b/src/Reaktor/Plugins/Mention.hs @@ -3,7 +3,7 @@  {-# LANGUAGE RecordWildCards #-}  module Reaktor.Plugins.Mention (new) where -import qualified Data.Char +import qualified Data.Char.Extended as C  import qualified Data.Text as T  import Prelude.Extended  import Reaktor @@ -20,4 +20,4 @@ new Actions{..} = do    where      isMention nick text =        not (T.isPrefixOf (nick <> ":") text) && -      any (==nick) (T.split (not . Data.Char.isAlphaNum) text) +      any (==nick) (T.split (not . C.isNick) text)  | 
