git-annex config annex.largefiles
annex.largefiles can be configured by git-annex config, to more easily set a default that will also be used by clones, without needing to shoehorn the expression into the gitattributes file. The git config and gitattributes override that. Whenever something is added to git-annex config, we have to consider what happens if a user puts a purposfully bad value in there. Or, if a new git-annex adds some new value that an old git-annex can't parse. In this case, a global annex.largefiles that can't be parsed currently makes an error be thrown. That might not be ideal, but the gitattribute behaves the same, and is almost equally repo-global. Performance notes: git-annex add and addurl construct a matcher once and uses it for every file, so the added time penalty for reading the global config log is minor. If the gitattributes annex.largefiles were deprecated, git-annex add would get around 2% faster (excluding hashing), because looking that up for each file is not fast. So this new way of setting it is progress toward speeding up add. git-annex smudge does need to load the log every time. As well as checking the git attribute. Not ideal. Setting annex.gitaddtoannex=false avoids both overheads.
This commit is contained in:
parent
ce3fb0b2e5
commit
4acbb40112
9 changed files with 119 additions and 63 deletions
4
Annex.hs
4
Annex.hs
|
@ -214,7 +214,7 @@ newState c r = do
|
||||||
new :: Git.Repo -> IO AnnexState
|
new :: Git.Repo -> IO AnnexState
|
||||||
new r = do
|
new r = do
|
||||||
r' <- Git.Config.read =<< Git.relPath r
|
r' <- Git.Config.read =<< Git.relPath r
|
||||||
let c = extractGitConfig r'
|
let c = extractGitConfig FromGitConfig r'
|
||||||
newState c =<< fixupRepo r' c
|
newState c =<< fixupRepo r' c
|
||||||
|
|
||||||
{- Performs an action in the Annex monad from a starting state,
|
{- Performs an action in the Annex monad from a starting state,
|
||||||
|
@ -325,7 +325,7 @@ changeGitRepo r = do
|
||||||
r' <- liftIO $ adjuster r
|
r' <- liftIO $ adjuster r
|
||||||
changeState $ \s -> s
|
changeState $ \s -> s
|
||||||
{ repo = r'
|
{ repo = r'
|
||||||
, gitconfig = extractGitConfig r'
|
, gitconfig = extractGitConfig FromGitConfig r'
|
||||||
}
|
}
|
||||||
|
|
||||||
{- Adds an adjustment to the Repo data. Adjustments persist across reloads
|
{- Adds an adjustment to the Repo data. Adjustments persist across reloads
|
||||||
|
|
|
@ -30,8 +30,9 @@ import Annex.Common
|
||||||
import Limit
|
import Limit
|
||||||
import Utility.Matcher
|
import Utility.Matcher
|
||||||
import Types.Group
|
import Types.Group
|
||||||
import qualified Annex
|
|
||||||
import Types.FileMatcher
|
import Types.FileMatcher
|
||||||
|
import Types.GitConfig
|
||||||
|
import Config.GitConfig
|
||||||
import Git.FilePath
|
import Git.FilePath
|
||||||
import Types.Remote (RemoteConfig)
|
import Types.Remote (RemoteConfig)
|
||||||
import Annex.CheckAttr
|
import Annex.CheckAttr
|
||||||
|
@ -200,17 +201,24 @@ mkLargeFilesParser = do
|
||||||
where
|
where
|
||||||
|
|
||||||
{- Generates a matcher for files large enough (or meeting other criteria)
|
{- Generates a matcher for files large enough (or meeting other criteria)
|
||||||
- to be added to the annex, rather than directly to git. -}
|
- to be added to the annex, rather than directly to git.
|
||||||
|
-
|
||||||
|
- annex.largefiles is configured in git config, or git attributes,
|
||||||
|
- or global git-annex config, in that order.
|
||||||
|
-}
|
||||||
largeFilesMatcher :: Annex GetFileMatcher
|
largeFilesMatcher :: Annex GetFileMatcher
|
||||||
largeFilesMatcher = go =<< annexLargeFiles <$> Annex.getGitConfig
|
largeFilesMatcher = go =<< getGitConfigVal' annexLargeFiles
|
||||||
where
|
where
|
||||||
go (Just expr) = do
|
go (HasGitConfig (Just expr)) = do
|
||||||
matcher <- mkmatcher expr
|
matcher <- mkmatcher expr
|
||||||
return $ const $ return matcher
|
return $ const $ return matcher
|
||||||
go Nothing = return $ \file -> do
|
go v = return $ \file -> do
|
||||||
expr <- checkAttr "annex.largefiles" file
|
expr <- checkAttr "annex.largefiles" file
|
||||||
if null expr || expr == unspecifiedAttr
|
if null expr || expr == unspecifiedAttr
|
||||||
then return matchAll
|
then case v of
|
||||||
|
HasGlobalConfig (Just expr') ->
|
||||||
|
mkmatcher expr'
|
||||||
|
_ -> return matchAll
|
||||||
else mkmatcher expr
|
else mkmatcher expr
|
||||||
|
|
||||||
mkmatcher expr = do
|
mkmatcher expr = do
|
||||||
|
|
|
@ -7,6 +7,10 @@ git-annex (7.20191219) UNRELEASED; urgency=medium
|
||||||
* Added build dependency on the filepath-bytestring library.
|
* Added build dependency on the filepath-bytestring library.
|
||||||
* Fixed an oversight that had always prevented annex.resolvemerge
|
* Fixed an oversight that had always prevented annex.resolvemerge
|
||||||
from being honored, when it was configured by git-annex config.
|
from being honored, when it was configured by git-annex config.
|
||||||
|
* annex.largefiles can be configured by git-annex config,
|
||||||
|
to more easily set a default that will also be used by clones,
|
||||||
|
without needing to shoehorn the expression into the gitattributes file.
|
||||||
|
The git config and gitattributes override that.
|
||||||
|
|
||||||
-- Joey Hess <id@joeyh.name> Wed, 18 Dec 2019 15:12:40 -0400
|
-- Joey Hess <id@joeyh.name> Wed, 18 Dec 2019 15:12:40 -0400
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{- git-annex configuration
|
{- git-annex configuration
|
||||||
-
|
-
|
||||||
- Copyright 2017 Joey Hess <id@joeyh.name>
|
- Copyright 2017-2019 Joey Hess <id@joeyh.name>
|
||||||
-
|
-
|
||||||
- Licensed under the GNU AGPL version 3 or higher.
|
- Licensed under the GNU AGPL version 3 or higher.
|
||||||
-}
|
-}
|
||||||
|
@ -20,20 +20,21 @@ import Logs.Config
|
||||||
- Note: Be sure to add the config value to mergeGitConfig.
|
- Note: Be sure to add the config value to mergeGitConfig.
|
||||||
-}
|
-}
|
||||||
getGitConfigVal :: (GitConfig -> Configurable a) -> Annex a
|
getGitConfigVal :: (GitConfig -> Configurable a) -> Annex a
|
||||||
getGitConfigVal f = do
|
getGitConfigVal f = getGitConfigVal' f >>= \case
|
||||||
v <- f <$> Annex.getGitConfig
|
HasGlobalConfig c -> return c
|
||||||
case v of
|
DefaultConfig d -> return d
|
||||||
HasConfig c -> return c
|
HasGitConfig c -> return c
|
||||||
DefaultConfig _ -> do
|
|
||||||
r <- Annex.gitRepo
|
getGitConfigVal' :: (GitConfig -> Configurable a) -> Annex (Configurable a)
|
||||||
m <- loadGlobalConfig
|
getGitConfigVal' f = (f <$> Annex.getGitConfig) >>= \case
|
||||||
let globalgc = extractGitConfig (r { config = m })
|
DefaultConfig _ -> do
|
||||||
-- This merge of the repo-global config and the git
|
r <- Annex.gitRepo
|
||||||
-- config makes all repository-global default
|
m <- loadGlobalConfig
|
||||||
-- values populate the GitConfig with HasConfig
|
let globalgc = extractGitConfig FromGlobalConfig (r { config = m })
|
||||||
-- values, so it will only need to be done once.
|
-- This merge of the repo-global config and the git
|
||||||
Annex.changeGitConfig (\gc -> mergeGitConfig gc globalgc)
|
-- config makes all repository-global default
|
||||||
v' <- f <$> Annex.getGitConfig
|
-- values populate the GitConfig with HasGlobalConfig
|
||||||
case v' of
|
-- values, so it will only need to be done once.
|
||||||
HasConfig c -> return c
|
Annex.changeGitConfig (\gc -> mergeGitConfig gc globalgc)
|
||||||
DefaultConfig d -> return d
|
f <$> Annex.getGitConfig
|
||||||
|
c -> return c
|
||||||
|
|
|
@ -857,13 +857,13 @@ mkState r u gc = do
|
||||||
where
|
where
|
||||||
go
|
go
|
||||||
| remoteAnnexCheckUUID gc = return
|
| remoteAnnexCheckUUID gc = return
|
||||||
(return True, return (r, extractGitConfig r))
|
(return True, return (r, extractGitConfig FromGitConfig r))
|
||||||
| otherwise = do
|
| otherwise = do
|
||||||
rv <- liftIO newEmptyMVar
|
rv <- liftIO newEmptyMVar
|
||||||
let getrepo = ifM (liftIO $ isEmptyMVar rv)
|
let getrepo = ifM (liftIO $ isEmptyMVar rv)
|
||||||
( do
|
( do
|
||||||
r' <- tryGitConfigRead False r
|
r' <- tryGitConfigRead False r
|
||||||
let t = (r', extractGitConfig r')
|
let t = (r', extractGitConfig FromGitConfig r')
|
||||||
void $ liftIO $ tryPutMVar rv t
|
void $ liftIO $ tryPutMVar rv t
|
||||||
return t
|
return t
|
||||||
, liftIO $ readMVar rv
|
, liftIO $ readMVar rv
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
module Types.GitConfig (
|
module Types.GitConfig (
|
||||||
Configurable(..),
|
Configurable(..),
|
||||||
|
ConfigSource(..),
|
||||||
GitConfig(..),
|
GitConfig(..),
|
||||||
extractGitConfig,
|
extractGitConfig,
|
||||||
mergeGitConfig,
|
mergeGitConfig,
|
||||||
|
@ -46,13 +47,17 @@ import qualified Data.Set as S
|
||||||
-- | A configurable value, that may not be fully determined yet because
|
-- | A configurable value, that may not be fully determined yet because
|
||||||
-- the global git config has not yet been loaded.
|
-- the global git config has not yet been loaded.
|
||||||
data Configurable a
|
data Configurable a
|
||||||
= HasConfig a
|
= HasGitConfig a
|
||||||
-- ^ Value is fully determined.
|
-- ^ The git config has a value.
|
||||||
|
| HasGlobalConfig a
|
||||||
|
-- ^ The global config has a value (and the git config does not).
|
||||||
| DefaultConfig a
|
| DefaultConfig a
|
||||||
-- ^ A default value is known, but not all config sources
|
-- ^ A default value is known, but not all config sources
|
||||||
-- have been read yet.
|
-- have been read yet.
|
||||||
deriving (Show)
|
deriving (Show)
|
||||||
|
|
||||||
|
data ConfigSource = FromGitConfig | FromGlobalConfig
|
||||||
|
|
||||||
{- Main git-annex settings. Each setting corresponds to a git-config key
|
{- Main git-annex settings. Each setting corresponds to a git-config key
|
||||||
- such as annex.foo -}
|
- such as annex.foo -}
|
||||||
data GitConfig = GitConfig
|
data GitConfig = GitConfig
|
||||||
|
@ -80,7 +85,7 @@ data GitConfig = GitConfig
|
||||||
, annexYoutubeDlOptions :: [String]
|
, annexYoutubeDlOptions :: [String]
|
||||||
, annexAriaTorrentOptions :: [String]
|
, annexAriaTorrentOptions :: [String]
|
||||||
, annexCrippledFileSystem :: Bool
|
, annexCrippledFileSystem :: Bool
|
||||||
, annexLargeFiles :: Maybe String
|
, annexLargeFiles :: Configurable (Maybe String)
|
||||||
, annexGitAddToAnnex :: Bool
|
, annexGitAddToAnnex :: Bool
|
||||||
, annexAddSmallFiles :: Bool
|
, annexAddSmallFiles :: Bool
|
||||||
, annexFsckNudge :: Bool
|
, annexFsckNudge :: Bool
|
||||||
|
@ -116,8 +121,8 @@ data GitConfig = GitConfig
|
||||||
, gpgCmd :: GpgCmd
|
, gpgCmd :: GpgCmd
|
||||||
}
|
}
|
||||||
|
|
||||||
extractGitConfig :: Git.Repo -> GitConfig
|
extractGitConfig :: ConfigSource -> Git.Repo -> GitConfig
|
||||||
extractGitConfig r = GitConfig
|
extractGitConfig configsource r = GitConfig
|
||||||
{ annexVersion = RepoVersion <$> getmayberead (annex "version")
|
{ annexVersion = RepoVersion <$> getmayberead (annex "version")
|
||||||
, annexUUID = maybe NoUUID toUUID $ getmaybe (annex "uuid")
|
, annexUUID = maybe NoUUID toUUID $ getmaybe (annex "uuid")
|
||||||
, annexNumCopies = NumCopies <$> getmayberead (annex "numcopies")
|
, annexNumCopies = NumCopies <$> getmayberead (annex "numcopies")
|
||||||
|
@ -151,7 +156,8 @@ extractGitConfig r = GitConfig
|
||||||
, annexYoutubeDlOptions = getwords (annex "youtube-dl-options")
|
, annexYoutubeDlOptions = getwords (annex "youtube-dl-options")
|
||||||
, annexAriaTorrentOptions = getwords (annex "aria-torrent-options")
|
, annexAriaTorrentOptions = getwords (annex "aria-torrent-options")
|
||||||
, annexCrippledFileSystem = getbool (annex "crippledfilesystem") False
|
, annexCrippledFileSystem = getbool (annex "crippledfilesystem") False
|
||||||
, annexLargeFiles = getmaybe (annex "largefiles")
|
, annexLargeFiles = configurable Nothing $
|
||||||
|
fmap Just $ getmaybe (annex "largefiles")
|
||||||
, annexGitAddToAnnex = getbool (annex "gitaddtoannex") True
|
, annexGitAddToAnnex = getbool (annex "gitaddtoannex") True
|
||||||
, annexAddSmallFiles = getbool (annex "addsmallfiles") True
|
, annexAddSmallFiles = getbool (annex "addsmallfiles") True
|
||||||
, annexFsckNudge = getbool (annex "fscknudge") True
|
, annexFsckNudge = getbool (annex "fscknudge") True
|
||||||
|
@ -209,7 +215,9 @@ extractGitConfig r = GitConfig
|
||||||
getwords k = fromMaybe [] $ words <$> getmaybe k
|
getwords k = fromMaybe [] $ words <$> getmaybe k
|
||||||
|
|
||||||
configurable d Nothing = DefaultConfig d
|
configurable d Nothing = DefaultConfig d
|
||||||
configurable _ (Just v) = HasConfig v
|
configurable _ (Just v) = case configsource of
|
||||||
|
FromGitConfig -> HasGitConfig v
|
||||||
|
FromGlobalConfig -> HasGlobalConfig v
|
||||||
|
|
||||||
annex k = ConfigKey $ "annex." <> k
|
annex k = ConfigKey $ "annex." <> k
|
||||||
|
|
||||||
|
@ -222,13 +230,15 @@ mergeGitConfig gitconfig repoglobals = gitconfig
|
||||||
{ annexAutoCommit = merge annexAutoCommit
|
{ annexAutoCommit = merge annexAutoCommit
|
||||||
, annexSyncContent = merge annexSyncContent
|
, annexSyncContent = merge annexSyncContent
|
||||||
, annexResolveMerge = merge annexResolveMerge
|
, annexResolveMerge = merge annexResolveMerge
|
||||||
|
, annexLargeFiles = merge annexLargeFiles
|
||||||
}
|
}
|
||||||
where
|
where
|
||||||
merge f = case f gitconfig of
|
merge f = case f gitconfig of
|
||||||
HasConfig v -> HasConfig v
|
HasGitConfig v -> HasGitConfig v
|
||||||
DefaultConfig d -> case f repoglobals of
|
DefaultConfig d -> case f repoglobals of
|
||||||
HasConfig v -> HasConfig v
|
HasGlobalConfig v -> HasGlobalConfig v
|
||||||
DefaultConfig _ -> HasConfig d
|
_ -> HasGitConfig d
|
||||||
|
HasGlobalConfig v -> HasGlobalConfig v
|
||||||
|
|
||||||
{- Per-remote git-annex settings. Each setting corresponds to a git-config
|
{- Per-remote git-annex settings. Each setting corresponds to a git-config
|
||||||
- key such as <remote>.annex-foo, or if that is not set, a default from
|
- key such as <remote>.annex-foo, or if that is not set, a default from
|
||||||
|
|
|
@ -27,6 +27,15 @@ repository see the setting, and so git-annex only looks for these:
|
||||||
These settings can be overridden on a per-repository basis using
|
These settings can be overridden on a per-repository basis using
|
||||||
`git config`.
|
`git config`.
|
||||||
|
|
||||||
|
* `annex.largefiles`
|
||||||
|
|
||||||
|
Used to configure which files are large enough to be added to the annex.
|
||||||
|
It is an expression that matches the large files, eg
|
||||||
|
"*.mp3 or largerthan(500kb)"
|
||||||
|
|
||||||
|
This sets a default, which can be overridden by annex.largefiles
|
||||||
|
attributes in `.gitattributes` files, or by `git config`.
|
||||||
|
|
||||||
* `annex.autocommit`
|
* `annex.autocommit`
|
||||||
|
|
||||||
Set to false to prevent the `git-annex assistant` and `git-annex sync`
|
Set to false to prevent the `git-annex assistant` and `git-annex sync`
|
||||||
|
|
|
@ -894,6 +894,9 @@ Like other git commands, git-annex is configured via `.git/config`.
|
||||||
"*.mp3 or largerthan(500kb)"
|
"*.mp3 or largerthan(500kb)"
|
||||||
|
|
||||||
Overrides any annex.largefiles attributes in `.gitattributes` files.
|
Overrides any annex.largefiles attributes in `.gitattributes` files.
|
||||||
|
|
||||||
|
To configure a default annex.largefiles for all clones of the repository,
|
||||||
|
this can be set in [[git-annex-config]](1).
|
||||||
|
|
||||||
This configures the behavior of both git-annex and git when adding
|
This configures the behavior of both git-annex and git when adding
|
||||||
files to the repository. By default, `git-annex add` adds all files
|
files to the repository. By default, `git-annex add` adds all files
|
||||||
|
@ -1695,9 +1698,12 @@ but the SHA256E backend for ogg files:
|
||||||
*.ogg annex.backend=SHA256E
|
*.ogg annex.backend=SHA256E
|
||||||
|
|
||||||
There is a annex.largefiles attribute, which is used to configure which
|
There is a annex.largefiles attribute, which is used to configure which
|
||||||
files are large enough to be added to the annex.
|
files are large enough to be added to the annex. Since attributes cannot
|
||||||
See the documentation above of the annex.largefiles git config
|
contain spaces, it is difficult to use for more complex annex.largefiles
|
||||||
and <https://git-annex.branchable.com/tips/largefiles> for details.
|
settings. Setting annex.largefiles in [[git-annex-config]](1) is an easier
|
||||||
|
way to configure it across all clones of the repository. See
|
||||||
|
<https://git-annex.branchable.com/tips/largefiles> for examples and more
|
||||||
|
documentation.
|
||||||
|
|
||||||
The numcopies setting can also be configured on a per-file-type basis via
|
The numcopies setting can also be configured on a per-file-type basis via
|
||||||
the `annex.numcopies` attribute in `.gitattributes` files. This overrides
|
the `annex.numcopies` attribute in `.gitattributes` files. This overrides
|
||||||
|
|
|
@ -26,28 +26,37 @@ the assistant.
|
||||||
For example, let's make only files larger than 100 kb be added to the annex,
|
For example, let's make only files larger than 100 kb be added to the annex,
|
||||||
and never `*.c` and `*.h` source code files.
|
and never `*.c` and `*.h` source code files.
|
||||||
|
|
||||||
Write this to the `.gitattributes` file:
|
git config annex.largefiles 'largerthan=100kb and not (include=*.c or include=*.h)'
|
||||||
|
|
||||||
* annex.largefiles=(largerthan=100kb)
|
That is a local configuration, so will only apply to your clone of the
|
||||||
|
repository. To set a default that will apply to all clones, unless
|
||||||
|
overridden, do this instead:
|
||||||
|
|
||||||
|
git annex config --set annex.largefiles 'largerthan=100kb and not (include=*.c or include=*.h)'
|
||||||
|
|
||||||
|
There's one other way to configure the same thing, you can put this in
|
||||||
|
the `.gitattributes` file:
|
||||||
|
|
||||||
|
* annex.largefiles=largerthan=100kb
|
||||||
*.c annex.largefiles=nothing
|
*.c annex.largefiles=nothing
|
||||||
*.h annex.largefiles=nothing
|
*.h annex.largefiles=nothing
|
||||||
|
|
||||||
Or, set the git configuration instead:
|
The syntax in .gitattributes is a bit different, because the .gitattributes
|
||||||
|
matches files itself, and the values of attributes cannot contain spaces.
|
||||||
git config annex.largefiles 'largerthan=100kb and not (include=*.c or include=*.h)'
|
So using .gitattributes for this is not recommended (but it does work for
|
||||||
|
older versions of git-annex, where the `git annex config` setting does
|
||||||
|
not). Any .gitattributes setting overrides the `git annex config` setting,
|
||||||
|
but will be overridden by the `git config` setting.
|
||||||
|
|
||||||
Both of these settings do the same thing. Setting it in the
|
Another example. If you wanted `git add` to put all files the annex
|
||||||
`.gitattributes` file makes any checkout of the repository share that
|
in your local repository:
|
||||||
configuration, so is often a good choice. Setting the annex.largefiles git
|
|
||||||
configuration lets different checkouts behave differently. The git
|
|
||||||
configuration overrides the `.gitattributes` configuration.
|
|
||||||
|
|
||||||
Or, perhaps you just want all files to be added to the annex, no matter
|
|
||||||
what. Just write "* annex.largefiles=anything" to the `.gitattributes`
|
|
||||||
file, or run:
|
|
||||||
|
|
||||||
git config annex.largefiles anything
|
git config annex.largefiles anything
|
||||||
|
|
||||||
|
Or in all clones:
|
||||||
|
|
||||||
|
git annex config --set annex.largefiles anything
|
||||||
|
|
||||||
## syntax
|
## syntax
|
||||||
|
|
||||||
The value of annex.largefiles is similar to a
|
The value of annex.largefiles is similar to a
|
||||||
|
@ -108,19 +117,28 @@ The following terms can be used in annex.largefiles:
|
||||||
|
|
||||||
These can be used to build up more complicated expressions.
|
These can be used to build up more complicated expressions.
|
||||||
|
|
||||||
The way the `.gitattributes` example above works is, `*.c` and `*.h` files
|
## gitattributes syntax
|
||||||
have the annex.largefiles attribute set to "nothing",
|
|
||||||
and so those files are never treated as large files. All other files use
|
|
||||||
the other value, which checks the file size.
|
|
||||||
|
|
||||||
Note that, since git attribute values cannot contain whitespace,
|
Here's that example `.gitattributes` again:
|
||||||
it's useful to instead parenthesize the terms of the annex.largefiles
|
|
||||||
attribute. This trick allows for more complicated expressions.
|
* annex.largefiles=largerthan=100kb
|
||||||
|
*.c annex.largefiles=nothing
|
||||||
|
*.h annex.largefiles=nothing
|
||||||
|
|
||||||
|
The way that works is, `*.c` and `*.h` files have the annex.largefiles
|
||||||
|
attribute set to "nothing", and so those files are never treated as large
|
||||||
|
files. All other files use the other value, which checks the file size.
|
||||||
|
|
||||||
|
Since git attribute values cannot contain whitespace, when you need
|
||||||
|
a more complicated annex.largefiles expression, you can instead
|
||||||
|
parenthesize the terms of the annex.largefiles attribute.
|
||||||
For example, this is the same as the git config shown earlier, shoehorned
|
For example, this is the same as the git config shown earlier, shoehorned
|
||||||
into a git attribute:
|
into a single git attribute:
|
||||||
|
|
||||||
* annex.largefiles=(largerthan=100kb)and(not((include=*.c)or(include=*.h)))
|
* annex.largefiles=(largerthan=100kb)and(not((include=*.c)or(include=*.h)))
|
||||||
|
|
||||||
|
It's generally a better idea to use `git annex config` instead.
|
||||||
|
|
||||||
## temporarily override
|
## temporarily override
|
||||||
|
|
||||||
If you've set up an annex.largefiles configuration but want to force a file to
|
If you've set up an annex.largefiles configuration but want to force a file to
|
||||||
|
|
Loading…
Reference in a new issue