summaryrefslogtreecommitdiff
path: root/Build/InstallDesktopFile.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Build/InstallDesktopFile.hs')
-rw-r--r--Build/InstallDesktopFile.hs40
1 files changed, 26 insertions, 14 deletions
diff --git a/Build/InstallDesktopFile.hs b/Build/InstallDesktopFile.hs
index 3bcaecf9a..cde36b738 100644
--- a/Build/InstallDesktopFile.hs
+++ b/Build/InstallDesktopFile.hs
@@ -1,5 +1,5 @@
{- Generating and installing a desktop menu entry file
- - and a desktop autostart file.
+ - and a desktop autostart file. (And OSX equivilants.)
-
- Copyright 2012 Joey Hess <joey@kitenet.net>
-
@@ -11,6 +11,7 @@ module Build.InstallDesktopFile where
import Utility.Exception
import Utility.FreeDesktop
import Utility.Path
+import Utility.Monad
import Locations.UserConfig
import Control.Applicative
@@ -18,6 +19,7 @@ import Control.Monad
import System.Directory
import System.Environment
import System.Posix.User
+import System.FilePath
{- The command can be either just "git-annex", or the full path to use
- to run it. -}
@@ -37,23 +39,33 @@ autostart command = genDesktopEntry
(command ++ " assistant --autostart")
[]
-writeDesktop :: FilePath -> IO ()
-writeDesktop command = do
- destdir <- catchDefaultIO (getEnv "DESTDIR") ""
+isRoot :: IO Bool
+isRoot = do
uid <- fromIntegral <$> getRealUserID
+ return $ uid == 0
- datadir <- if uid /= 0 then userDataDir else return systemDataDir
- writeDesktopMenuFile (desktop command) $
- desktopMenuFilePath "git-annex" datadir
+inDestDir :: FilePath -> IO FilePath
+inDestDir f = do
+ destdir <- catchDefaultIO (getEnv "DESTDIR") ""
+ return $ destdir </> f
+
+writeDesktop :: FilePath -> IO ()
+writeDesktop command = do
+ datadir <- ifM isRoot ( return systemDataDir, userDataDir )
+ writeDesktopMenuFile (desktop command)
+ =<< inDestDir (desktopMenuFilePath "git-annex" datadir)
- configdir <- if uid /= 0 then userConfigDir else return systemConfigDir
- writeDesktopMenuFile (autostart command) $
- autoStartPath "git-annex" configdir
+ configdir <- ifM isRoot ( return systemConfigDir, userConfigDir )
+ writeDesktopMenuFile (autostart command)
+ =<< inDestDir (autoStartPath "git-annex" configdir)
- when (uid /= 0) $ do
- programfile <- programFile
- createDirectoryIfMissing True (parentDir programfile)
- writeFile programfile command
+ ifM isRoot
+ ( return ()
+ , do
+ programfile <- inDestDir =<< programFile
+ createDirectoryIfMissing True (parentDir programfile)
+ writeFile programfile command
+ )
main = getArgs >>= go
where