summaryrefslogtreecommitdiff
path: root/Command
diff options
context:
space:
mode:
Diffstat (limited to 'Command')
-rw-r--r--Command/WebApp.hs12
1 files changed, 11 insertions, 1 deletions
diff --git a/Command/WebApp.hs b/Command/WebApp.hs
index 8c11c18bd..87a648bdd 100644
--- a/Command/WebApp.hs
+++ b/Command/WebApp.hs
@@ -22,6 +22,7 @@ import Utility.Daemon (checkDaemon)
#ifdef __ANDROID__
import Utility.Env
#endif
+import Utility.UserInfo
import Annex.Init
import qualified Git
import qualified Git.Config
@@ -60,7 +61,7 @@ start = start' True
start' :: Bool -> WebAppOptions -> CommandStart
start' allowauto o = do
liftIO ensureInstalled
- ifM isInitialized
+ ifM (isInitialized <&&> notHome)
( maybe notinitialized (go <=< needsUpgrade) =<< getVersion
, if allowauto
then liftIO $ startNoRepo o
@@ -99,6 +100,15 @@ start' allowauto o = do
liftIO $ cannotStartIn (Git.repoLocation g) "repository has not been initialized by git-annex"
liftIO $ firstRun o
+{- If HOME is a git repo, even if it's initialized for git-annex,
+ - the user almost certianly does not want to run the assistant there. -}
+notHome :: Annex Bool
+notHome = do
+ g <- Annex.gitRepo
+ d <- liftIO $ absPath (Git.repoLocation g)
+ h <- liftIO $ absPath =<< myHomeDir
+ return (d /= h)
+
{- When run without a repo, start the first available listed repository in
- the autostart file. If none, it's our first time being run! -}
startNoRepo :: WebAppOptions -> IO ()