-- Author: Andy Stewart -- Maintainer: Andy Stewart -- -- Copyright (C) 2010 Andy Stewart, all rights reserved. -- -- This program is free software: you can redistribute it and/or modify -- it under the terms of the GNU General Public License as published by -- the Free Software Foundation, either version 3 of the License, or -- any later version. -- -- This program is distributed in the hope that it will be useful, -- but WITHOUT ANY WARRANTY; without even the implied warranty of -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -- GNU General Public License for more details. -- -- You should have received a copy of the GNU General Public License -- along with this program. If not, see . {-# LANGUAGE OverloadedStrings #-} module Manatee.Plugin.Anything.AnythingIrc where import DBus.Client hiding (Signal) import Manatee.Core.DBus import Manatee.Core.Types import Manatee.Plugin.Anything.Anything import Manatee.Plugin.Anything.Types -- import Network.URI import Text.Regex.TDFA -- | Search uri. anythingIrc :: Anything anythingIrc = Anything {anythingColumnTitle = ["Irc"] ,anythingColumnFun = [anythingCandidateUnpack] ,anythingSearch = AnythingSearch anythingIrcSearch ,anythingFilterRule = anythingFuzzyFilterRule True ,anythingCompletionRule = id ,anythingInputDepend = False ,anythingCommandFun = anythingIrcCommandFun ,anythingCalculateDelay = 0 } -- | Search uri. anythingIrcSearch :: AnythingInput -> Client -> IO [String] anythingIrcSearch input _ | input =~ ("^irc://.*$" :: String) :: Bool = return [input] | otherwise = return [] -- | Irc uri. anythingIrcCommandFun :: AnythingCommandFun anythingIrcCommandFun _ (AnythingCandidateWrap a) _ = return [("Join Channel", anythingIrcJoinChannel (candidateCommandName a))] -- | Open uri. anythingIrcJoinChannel :: String -> Client -> IO () anythingIrcJoinChannel info client = mkDaemonSignal client NewTab (NewTabArgs "PageIrc" info [])