diff --git a/Build/InstallDesktopFile.hs b/Build/InstallDesktopFile.hs index 3f8b980cc3..9c721f9685 100644 --- a/Build/InstallDesktopFile.hs +++ b/Build/InstallDesktopFile.hs @@ -21,6 +21,7 @@ import Control.Monad import System.Directory import System.Environment import System.Posix.User +import System.Posix.Types import System.Posix.Files import System.FilePath @@ -73,38 +74,56 @@ writeFDODesktop command = do writeOSXDesktop :: FilePath -> IO () writeOSXDesktop command = do home <- myHomeDir + let base = "Library" "LaunchAgents" label ++ ".plist" autostart <- ifM isRoot ( inDestDir $ "/" base , inDestDir $ home base) createDirectoryIfMissing True (parentDir autostart) - writeFile autostart $ unlines - [ "" - , "" - , "" - , "" - , "Label" - , "" ++ label ++ "" - , "ProgramArguments" - , "" - , "" ++ command ++ "" - , "assistant" - , "--autostart" - , "" - , "RunAtLoad" - , "" - , "" - ] + writeFile autostart $ genOSXAutoStartFile label command - ifM isRoot - ( return () - , do - let commandfile = home "Desktop" "git-annex-webapp.command" - writeFile commandfile $ unwords [command, "webapp"] - mode <- fileMode <$> getFileStatus commandfile - setFileMode commandfile $ mode `unionFileModes` ownerExecuteMode - ) - + let appdir = "git-annex.app" + installOSXAppFile appdir "Contents/Info.plist" Nothing + installOSXAppFile appdir "Contents/Resources/git-annex.icns" Nothing + installOSXAppFile appdir "Contents/MacOS/git-annex" (Just webappscript) where label = "com.branchable.git-annex.assistant" + webappscript = unlines + [ "#!/bin/sh" + , command ++ " webapp" + ] + +installOSXAppFile :: FilePath -> FilePath -> Maybe String -> IO () +installOSXAppFile appdir appfile mcontent = do + let src = "ui-macos" appdir appfile + home <- myHomeDir + dest <- ifM isRoot + -- no idea where to install as root + ( return $ "/Library/git-annex" appdir appfile + , return $ home "Desktop" appdir appfile + ) + content <- maybe (readFile src) return mcontent + createDirectoryIfMissing True (parentDir dest) + writeFile dest content + mode <- fileMode <$> getFileStatus src + setFileMode dest mode + +genOSXAutoStartFile :: String -> String -> String +genOSXAutoStartFile label command = unlines + [ "" + , "" + , "" + , "" + , "Label" + , "" ++ label ++ "" + , "ProgramArguments" + , "" + , "" ++ command ++ "" + , "assistant" + , "--autostart" + , "" + , "RunAtLoad" + , "" + , "" + ] writeDesktop :: FilePath -> IO () #ifdef darwin_HOST_OS diff --git a/ui-macos/git-annex.app/Contents/MacOS/git-annex b/ui-macos/git-annex.app/Contents/MacOS/git-annex index 868a488652..f814fc08d1 100755 --- a/ui-macos/git-annex.app/Contents/MacOS/git-annex +++ b/ui-macos/git-annex.app/Contents/MacOS/git-annex @@ -1,3 +1,5 @@ #!/bin/sh - +# The contents of this file are not installed; instead a script +# is generated containing the full path to the real git-annex +# executable. git annex webapp