Skip to content

Commit

Permalink
Merge pull request #661 from tsloughter/copy-file-info
Browse files Browse the repository at this point in the history
only copy mode and time attributes when copying files
  • Loading branch information
lrascao authored Jun 23, 2018
2 parents d1ee878 + 81b25bb commit efd717e
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 14 deletions.
3 changes: 2 additions & 1 deletion rebar.config
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
%% -*- mode: Erlang; fill-column: 80; comment-column: 75; -*-
%% Dependencies ================================================================
{deps, [{erlware_commons, "1.0.5"},
{deps, [{erlware_commons, "1.2.0"},
{providers, "1.7.0"},
{getopt, "1.0.1"},
{cf, "0.2.2"},
Expand Down Expand Up @@ -55,6 +55,7 @@
{platform_define, "^R1[4|5]", deprecated_crypto},
{platform_define, "^((1[8|9])|2)", rand_module},
{platform_define, "^2", unicode_str},
{platform_define, "^(R|1|20)", fun_stacktrace},
no_debug_info,
warnings_as_errors
]},
Expand Down
4 changes: 2 additions & 2 deletions rebar.lock
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
{"1.1.0",
[{<<"bbmustache">>,{pkg,<<"bbmustache">>,<<"1.0.4">>},0},
{<<"cf">>,{pkg,<<"cf">>,<<"0.2.2">>},0},
{<<"erlware_commons">>,{pkg,<<"erlware_commons">>,<<"1.0.5">>},0},
{<<"erlware_commons">>,{pkg,<<"erlware_commons">>,<<"1.2.0">>},0},
{<<"getopt">>,{pkg,<<"getopt">>,<<"1.0.1">>},0},
{<<"providers">>,{pkg,<<"providers">>,<<"1.7.0">>},0}]}.
[
{pkg_hash,[
{<<"bbmustache">>, <<"7BA94F971C5AFD7B6617918A4BB74705E36CAB36EB84B19B6A1B7EE06427AA38">>},
{<<"cf">>, <<"7F2913FFF90ABCABD0F489896CFEB0B0674F6C8DF6C10B17A83175448029896C">>},
{<<"erlware_commons">>, <<"FC23D8E304140B65A811F653A76B2FB10B0CE744608CAF86E9125CEB349C9442">>},
{<<"erlware_commons">>, <<"2BAB99CF88941145767A502F1209886F1F0D31695EEF21978A30F15E645721E0">>},
{<<"getopt">>, <<"C73A9FA687B217F2FF79F68A3B637711BB1936E712B521D8CE466B29CBF7808A">>},
{<<"providers">>, <<"BBF730563914328EC2511D205E6477A94831DB7297DE313B3872A2B26C562EAB">>}]}
].
14 changes: 8 additions & 6 deletions src/rlx_prv_assembler.erl
Original file line number Diff line number Diff line change
Expand Up @@ -344,7 +344,7 @@ copy_dir(State, App, AppDir, TargetDir, SubDir) ->

%% no files are excluded, just copy the whole dir
copy_dir(SourceDir, TargetDir, []) ->
case ec_file:copy(SourceDir, TargetDir, [recursive]) of
case ec_file:copy(SourceDir, TargetDir, [recursive, {file_info, [mode, time]}]) of
{error, E} -> {error, E};
ok ->
ok
Expand All @@ -355,7 +355,7 @@ copy_dir(SourceDir, TargetDir, ExcludeFiles) ->
lists:foreach(fun(F) ->
ok = ec_file:copy(F,
filename:join([TargetDir,
filename:basename(F)]))
filename:basename(F)]), [{file_info, [mode, time]}])
end, SourceFiles -- ExcludeFiles).

create_release_info(State0, Release0, OutputDir) ->
Expand Down Expand Up @@ -655,7 +655,7 @@ copy_or_symlink_config_file(State, ConfigPath, RelConfPath) ->
true ->
ok = rlx_util:symlink_or_copy(ConfigPath, RelConfPath);
_ ->
ok = ec_file:copy(ConfigPath, RelConfPath)
ok = ec_file:copy(ConfigPath, RelConfPath, [{file_info, [mode, time]}])
end.

%% @doc Optionally add erts directory to release, if defined.
Expand Down Expand Up @@ -686,7 +686,7 @@ include_erts(State, Release, OutputDir, RelDir) ->
?RLX_ERROR({specified_erts_does_not_exist, ErtsVersion});
true ->
ok = ec_file:mkdir_p(LocalErts),
ok = ec_file:copy(ErtsDir, LocalErts, [recursive]),
ok = ec_file:copy(ErtsDir, LocalErts, [recursive, {file_info, [mode, time]}]),
case OsFamily of
unix ->
Erl = filename:join([LocalErts, "bin", "erl"]),
Expand Down Expand Up @@ -797,15 +797,17 @@ create_boot_file(RelDir, OutputDir, Options, State, Name) ->
end) of
ok ->
ok = ec_file:copy(filename:join([RelDir, Name++".boot"]),
filename:join([OutputDir, "bin", Name++".boot"])),
filename:join([OutputDir, "bin", Name++".boot"]),
[{file_info, [mode, time]}]),
ec_file:remove(filename:join([RelDir, Name++".rel"])),
ec_file:remove(filename:join([RelDir, Name++".script"])),
{ok, State};
error ->
?RLX_ERROR(boot_script_generation_error);
{ok, _, []} ->
ok = ec_file:copy(filename:join([RelDir, Name++".boot"]),
filename:join([OutputDir, "bin", Name++".boot"])),
filename:join([OutputDir, "bin", Name++".boot"]),
[{file_info, [mode, time]}]),
ec_file:remove(filename:join([RelDir, Name++".rel"])),
ec_file:remove(filename:join([RelDir, Name++".script"])),
{ok, State};
Expand Down
7 changes: 2 additions & 5 deletions src/rlx_prv_overlay.erl
Original file line number Diff line number Diff line change
Expand Up @@ -402,10 +402,8 @@ copy_to(State, FromFile0, ToFile0) ->
erlang:iolist_to_binary(filename:join(ToFile1,
filename:basename(FromFile1)))
end,
case ec_file:copy(FromFile1, ToFile2, [recursive]) of
case ec_file:copy(FromFile1, ToFile2, [recursive, {file_info, [mode, time]}]) of
ok ->
{ok, FileInfo} = file:read_file_info(FromFile1),
ok = file:write_file_info(ToFile2, FileInfo),
ok;
{error, Err} ->
?RLX_ERROR({copy_failed,
Expand Down Expand Up @@ -494,8 +492,7 @@ write_template(OverlayVars, FromFile, ToFile) ->
end,
case file:write_file(ToFile, IoData) of
ok ->
{ok, FileInfo} = file:read_file_info(FromFile),
ok = file:write_file_info(ToFile, FileInfo),
ok = ec_file:copy_file_info(ToFile, FromFile, [mode, time]),
ok;
{error, Reason} ->
?RLX_ERROR({unable_to_write, ToFile, Reason})
Expand Down

0 comments on commit efd717e

Please sign in to comment.