mirror of
https://github.com/correl/rebar.git
synced 2025-01-07 03:00:15 +00:00
On windows, avoid symlink during upgrade
a) make_symlink throws "not supported" on OS < Vista (e.g. 2003) b) tarball creation stores windows symlinks as absolute paths instead of relative, causing service to fail to start after upgrade is made permanent.
This commit is contained in:
parent
816d1805d5
commit
c15d99d8bb
1 changed files with 17 additions and 5 deletions
|
@ -64,7 +64,7 @@
|
||||||
{ok, _} = boot_files(TargetDir, NewVer, NewName),
|
{ok, _} = boot_files(TargetDir, NewVer, NewName),
|
||||||
|
|
||||||
%% Extract upgrade and tar it back up with changes
|
%% Extract upgrade and tar it back up with changes
|
||||||
make_tar(NameVer),
|
make_tar(NameVer, NewVer, NewName),
|
||||||
|
|
||||||
%% Clean up files that systools created
|
%% Clean up files that systools created
|
||||||
ok = cleanup(NameVer),
|
ok = cleanup(NameVer),
|
||||||
|
@ -149,9 +149,14 @@ boot_files(TargetDir, Ver, Name) ->
|
||||||
ok = file:make_dir(filename:join([".", ?TMP])),
|
ok = file:make_dir(filename:join([".", ?TMP])),
|
||||||
ok = file:make_dir(filename:join([".", ?TMP, "releases"])),
|
ok = file:make_dir(filename:join([".", ?TMP, "releases"])),
|
||||||
ok = file:make_dir(filename:join([".", ?TMP, "releases", Ver])),
|
ok = file:make_dir(filename:join([".", ?TMP, "releases", Ver])),
|
||||||
ok = file:make_symlink(
|
case os:type() of
|
||||||
filename:join(["start.boot"]),
|
{win32,_} ->
|
||||||
filename:join([".", ?TMP, "releases", Ver, Name ++ ".boot"])),
|
ok;
|
||||||
|
_ ->
|
||||||
|
ok = file:make_symlink(
|
||||||
|
filename:join(["start.boot"]),
|
||||||
|
filename:join([".", ?TMP, "releases", Ver, Name ++ ".boot"]))
|
||||||
|
end,
|
||||||
{ok, _} =
|
{ok, _} =
|
||||||
file:copy(
|
file:copy(
|
||||||
filename:join([TargetDir, "releases", Ver, "start_clean.boot"]),
|
filename:join([TargetDir, "releases", Ver, "start_clean.boot"]),
|
||||||
|
@ -165,13 +170,20 @@ boot_files(TargetDir, Ver, Name) ->
|
||||||
filename:join([TargetDir, "releases", Ver, "vm.args"]),
|
filename:join([TargetDir, "releases", Ver, "vm.args"]),
|
||||||
filename:join([".", ?TMP, "releases", Ver, "vm.args"])).
|
filename:join([".", ?TMP, "releases", Ver, "vm.args"])).
|
||||||
|
|
||||||
make_tar(NameVer) ->
|
make_tar(NameVer, NewVer, NewName) ->
|
||||||
Filename = NameVer ++ ".tar.gz",
|
Filename = NameVer ++ ".tar.gz",
|
||||||
{ok, Cwd} = file:get_cwd(),
|
{ok, Cwd} = file:get_cwd(),
|
||||||
Absname = filename:join([Cwd, Filename]),
|
Absname = filename:join([Cwd, Filename]),
|
||||||
ok = file:set_cwd(?TMP),
|
ok = file:set_cwd(?TMP),
|
||||||
ok = erl_tar:extract(Absname, [compressed]),
|
ok = erl_tar:extract(Absname, [compressed]),
|
||||||
ok = file:delete(Absname),
|
ok = file:delete(Absname),
|
||||||
|
case os:type() of
|
||||||
|
{win32,_} ->
|
||||||
|
{ok, _} = file:copy(
|
||||||
|
filename:join([".", "releases", NewVer, "start.boot"]),
|
||||||
|
filename:join([".", "releases", NewVer, NewName ++ ".boot"]));
|
||||||
|
_ -> ok
|
||||||
|
end,
|
||||||
{ok, Tar} = erl_tar:open(Absname, [write, compressed]),
|
{ok, Tar} = erl_tar:open(Absname, [write, compressed]),
|
||||||
ok = erl_tar:add(Tar, "lib", []),
|
ok = erl_tar:add(Tar, "lib", []),
|
||||||
ok = erl_tar:add(Tar, "releases", []),
|
ok = erl_tar:add(Tar, "releases", []),
|
||||||
|
|
Loading…
Reference in a new issue