summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFred Hebert <mononcqc@ferd.ca>2018-04-26 21:55:30 -0400
committerFred Hebert <mononcqc@ferd.ca>2018-04-27 06:50:00 -0400
commitdf9c769afc4c3480305a1f204b37828531e10331 (patch)
tree12c647d5f328d9987bdc632683e4351a9b2098fb
parent7eca59670f43f5298dd9d126911e583eef7edd0f (diff)
Display warnings when cache dirs are read-only
This should provide more help to users directly and avoid having them go through opening tickets for help. Fixes #1767
-rw-r--r--src/rebar_packages.erl7
-rw-r--r--src/rebar_prv_local_install.erl11
2 files changed, 16 insertions, 2 deletions
diff --git a/src/rebar_packages.erl b/src/rebar_packages.erl
index 50d4025..8cebeca 100644
--- a/src/rebar_packages.erl
+++ b/src/rebar_packages.erl
@@ -97,7 +97,12 @@ registry_dir(State) ->
case rebar_state:get(State, rebar_packages_cdn, ?DEFAULT_CDN) of
?DEFAULT_CDN ->
RegistryDir = filename:join([CacheDir, "hex", "default"]),
- ok = filelib:ensure_dir(filename:join(RegistryDir, "placeholder")),
+ case filelib:ensure_dir(filename:join(RegistryDir, "placeholder")) of
+ ok -> ok;
+ {error, Posix} when Posix == eaccess; Posix == enoent ->
+ ?ABORT("Could not write to ~p. Please ensure the path is writeable.",
+ [RegistryDir])
+ end,
{ok, RegistryDir};
CDN ->
case rebar_utils:url_append_path(CDN, ?REMOTE_PACKAGE_DIR) of
diff --git a/src/rebar_prv_local_install.erl b/src/rebar_prv_local_install.erl
index 282c548..bb019c4 100644
--- a/src/rebar_prv_local_install.erl
+++ b/src/rebar_prv_local_install.erl
@@ -12,6 +12,7 @@
-export([extract_escript/2]).
-include("rebar.hrl").
+-include_lib("providers/include/providers.hrl").
-include_lib("kernel/include/file.hrl").
-define(PROVIDER, install).
@@ -54,6 +55,9 @@ do(State) ->
end.
-spec format_error(any()) -> iolist().
+format_error({non_writeable, Dir}) ->
+ io_lib:format("Could not write to ~p. Please ensure the path is writeable.",
+ [Dir]);
format_error(Reason) ->
io_lib:format("~p", [Reason]).
@@ -71,7 +75,12 @@ extract_escript(State, ScriptPath) ->
%% And add a rebar3 bin script to ~/.cache/rebar3/bin
Opts = rebar_state:opts(State),
OutputDir = filename:join(rebar_dir:global_cache_dir(Opts), "lib"),
- filelib:ensure_dir(filename:join(OutputDir, "empty")),
+ case filelib:ensure_dir(filename:join(OutputDir, "empty")) of
+ ok ->
+ ok;
+ {error, Posix} when Posix == eaccess; Posix == enoent ->
+ throw(?PRV_ERROR({non_writeable, OutputDir}))
+ end,
?INFO("Extracting rebar3 libs to ~ts...", [OutputDir]),
zip:extract(Archive, [{cwd, OutputDir}]),