-- Author: Andy Stewart -- Maintainer: Andy Stewart -- -- Copyright (C) 2010 ~ 2011 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 . import Distribution.Simple import Manatee.Core.Config import Manatee.Core.Types import Manatee.Toolkit.Cabal.Utils import Manatee.Toolkit.General.List import Manatee.Toolkit.General.Map import Manatee.Extension.Browser.PageMode import qualified Data.Map as M main = defaultMainWithHooks simpleUserHooks { -- Update Rule after install successful. postInst = \ _ _ pack_des lbi -> do -- Update PageTypeRule. (PageTypeRule typeRule) <- readConfig pageTypeRulePath (PageTypeRule M.empty) writeConfig pageTypeRulePath (PageTypeRule (M.insert "PageBrowser" "manatee-browser" typeRule)) -- Update FileOpenRule let match = ContentTypeMatch "text/html" rule = ("Open URI", "PageBrowser", "file://") (FileOpenRule ruleMap) <- readConfig fileOpenRulePath (FileOpenRule M.empty) writeConfig fileOpenRulePath (FileOpenRule (let openRules = case findMinMatch ruleMap (\ oMath _ -> oMath == match) of Just (_, rules) -> insertUnique rule rules Nothing -> [rule] in M.insert match openRules ruleMap)) -- Update PageModeRule. (PageModeRule modeRule) <- readConfig pageModeRulePath (PageModeRule M.empty) writeConfig pageModeRulePath (PageModeRule (M.insert "PageBrowser" (Left $ pageModeName browserMode) modeRule)) -- Update Duplicate tab list. (PageModeDuplicateList list) <- readConfig pageModeDuplicateList (PageModeDuplicateList []) writeConfig pageModeDuplicateList (PageModeDuplicateList (insertUnique (pageModeName browserMode) list)) -- Update ExtensionGloalKeymap. (ExtensionGloalKeymap keymap) <- readConfig extensionGlobalKeymapPath (ExtensionGloalKeymap M.empty) writeConfig extensionGlobalKeymapPath (ExtensionGloalKeymap (M.insert "F5" ("Browser", ("PageBrowser", "http://www.google.com", [])) keymap)) -- Update Application info. let snapshotPath = getDataFilePath pack_des lbi "data/welcome/snapshot.png" (WelcomeApplication apps) <- readConfig welcomeApplicationPath (WelcomeApplication M.empty) writeConfig welcomeApplicationPath (WelcomeApplication (M.insert ("Web browser", snapshotPath) ("PageBrowser", "http://www.google.com", []) apps)) }