diff options
Diffstat (limited to 'src/rebar_deps.erl')
-rw-r--r-- | src/rebar_deps.erl | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/src/rebar_deps.erl b/src/rebar_deps.erl index 11c78d0..5ba0af3 100644 --- a/src/rebar_deps.erl +++ b/src/rebar_deps.erl @@ -203,15 +203,25 @@ download_source(AppDir, {hg, Url, Rev}) -> download_source(AppDir, {git, Url, Rev}) -> ok = filelib:ensure_dir(AppDir), rebar_utils:sh(?FMT("git clone -n ~s", [Url]), [], filename:dirname(AppDir)), - rebar_utils:sh(?FMT("git checkout ~s", [Rev]), [], AppDir). - + rebar_utils:sh(?FMT("git checkout ~s", [Rev]), [], AppDir); +download_source(AppDir, {bzr, Url, Rev}) -> + ok = filelib:ensure_dir(AppDir), + rebar_utils:sh(?FMT("bzr branch -r ~s ~s ~s", + [Rev, Url, filename:basename(AppDir)]), [], + filename:dirname(AppDir)); +download_source(AppDir, {svn, Url, Rev}) -> + ok = filelib:ensure_dir(AppDir), + rebar_utils:sh(?FMT("svn checkout -r ~s ~s ~s", + [Rev, Url, filename:basename(AppDir)]), [], + filename:dirname(AppDir)). %% =================================================================== %% Source helper functions %% =================================================================== -source_engine_avail({Name, _, _}) when Name == hg; Name == git -> +source_engine_avail({Name, _, _}) + when Name == hg; Name == git; Name == svn; Name == bzr -> case scm_client_vsn(Name) >= required_scm_client_vsn(Name) of true -> true; @@ -232,11 +242,17 @@ scm_client_vsn(Path, VsnArg, VsnRegex) -> end. required_scm_client_vsn(hg) -> {1, 4}; -required_scm_client_vsn(git) -> {1, 6}. +required_scm_client_vsn(git) -> {1, 6}; +required_scm_client_vsn(bzr) -> {2, 0}; +required_scm_client_vsn(svn) -> {1, 6}. scm_client_vsn(hg) -> scm_client_vsn(os:find_executable(hg), " --version", "version (\\d+).(\\d+)"); scm_client_vsn(git) -> scm_client_vsn(os:find_executable(git), " --version", "git version (\\d+).(\\d+)"); +scm_client_vsn(bzr) -> + scm_client_vsn(os:find_executable(bzr), " --version", "Bazaar \\(bzr\\) (\\d+).(\\d+)"); +scm_client_vsn(svn) -> + scm_client_vsn(os:find_executable(svn), " --version", "svn, version (\\d+).(\\d+)"); scm_client_vsn(_) -> undefined. |