From 4ea12beb77f9a46c72ec677e5934272ac6b2e850 Mon Sep 17 00:00:00 2001 From: Tristan Sloughter Date: Sat, 22 Nov 2014 14:16:06 -0600 Subject: fix git resource update check, bad url comparison --- src/rebar_git_resource.erl | 41 +++++++++++++++++++++++++++-------------- 1 file changed, 27 insertions(+), 14 deletions(-) (limited to 'src') diff --git a/src/rebar_git_resource.erl b/src/rebar_git_resource.erl index fee619a..bcd2374 100644 --- a/src/rebar_git_resource.erl +++ b/src/rebar_git_resource.erl @@ -22,23 +22,20 @@ lock(AppDir, {git, Url}) -> %% Return true if either the git url or tag/branch/ref is not the same as the currently %% checked out git repo for the dep needs_update(Dir, {git, Url, {tag, Tag}}) -> - {ok, CurrentUrl} = rebar_utils:sh(?FMT("git config --get remote.origin.url", []), - [{cd, Dir}]), {ok, Current} = rebar_utils:sh(?FMT("git describe --tags --exact-match", []), [{cd, Dir}]), Current1 = string:strip(string:strip(Current, both, $\n), both, $\r), - CurrentUrl1 = string:strip(string:strip(CurrentUrl, both, $\n), both, $\r), - ?DEBUG("Comparing git tag ~s with ~s and url ~s with ~s", [Tag, Current1, Url, CurrentUrl1]), - not ((Current1 =:= Tag) andalso (CurrentUrl1 =:= Url)); + + ?DEBUG("Comparing git tag ~s with ~s", [Tag, Current1]), + not ((Current1 =:= Tag) andalso compare_url(Dir, Url)); needs_update(Dir, {git, Url, {branch, Branch}}) -> - {ok, CurrentUrl} = rebar_utils:sh(?FMT("git config --get remote.origin.url", []), - [{cd, Dir}]), {ok, Current} = rebar_utils:sh(?FMT("git symbolic-ref -q --short HEAD", []), [{cd, Dir}]), Current1 = string:strip(string:strip(Current, both, $\n), both, $\r), - CurrentUrl1 = string:strip(string:strip(CurrentUrl, both, $\n), both, $\r), - ?DEBUG("Comparing git branch ~s with ~s and url ~s with ~s", [Branch, Current1, Url, CurrentUrl1]), - not ((Current1 =:= Branch) andalso (CurrentUrl1 =:= Url)); + ?DEBUG("Comparing git branch ~s with ~s", [Branch, Current1]), + not ((Current1 =:= Branch) andalso compare_url(Dir, Url)); +needs_update(Dir, {git, Url, "master"}) -> + needs_update(Dir, {git, Url, {branch, "master"}}); needs_update(Dir, {git, Url, Ref}) -> case Ref of {ref, Ref1} -> @@ -46,14 +43,30 @@ needs_update(Dir, {git, Url, Ref}) -> Ref1 -> Ref1 end, - {ok, CurrentUrl} = rebar_utils:sh(?FMT("git config --get remote.origin.url", []), - [{cd, Dir}]), + {ok, Current} = rebar_utils:sh(?FMT("git rev-parse -q HEAD", []), [{cd, Dir}]), Current1 = string:strip(string:strip(Current, both, $\n), both, $\r), + ?DEBUG("Comparing git ref ~s with ~s", [Ref1, Current1]), + not ((Current1 =:= Ref1) andalso compare_url(Dir, Url)). + +compare_url(Dir, Url) -> + {ok, CurrentUrl} = rebar_utils:sh(?FMT("git config --get remote.origin.url", []), + [{cd, Dir}]), CurrentUrl1 = string:strip(string:strip(CurrentUrl, both, $\n), both, $\r), - ?DEBUG("Comparing git ref ~s with ~s and url ~s with ~s", [Ref1, Current1, Url, CurrentUrl1]), - not ((Current1 =:= Ref1) andalso (CurrentUrl1 =:= Url)). + ParsedUrl = parse_git_url(Url), + ParsedCurrentUrl = parse_git_url(CurrentUrl1), + ParsedCurrentUrl =:= ParsedUrl. + +parse_git_url("git@" ++ HostPath) -> + [Host, Path] = string:tokens(HostPath, ":"), + {Host, filename:rootname(Path, ".git")}; +parse_git_url("git://" ++ HostPath) -> + [Host | Path] = string:tokens(HostPath, "/"), + {Host, filename:rootname(filename:join(Path), ".git")}; +parse_git_url("https://" ++ HostPath) -> + [Host | Path] = string:tokens(HostPath, "/"), + {Host, filename:rootname(filename:join(Path), ".git")}. download(Dir, {git, Url}) -> ?WARN("WARNING: It is recommended to use {branch, Name}, {tag, Tag} or {ref, Ref}, otherwise updating the dep may not work as expected.", []), -- cgit v1.1