diff options
Diffstat (limited to 'lib/stdlib/src')
| -rw-r--r-- | lib/stdlib/src/dets.erl | 23 | ||||
| -rw-r--r-- | lib/stdlib/src/filename.erl | 31 | 
2 files changed, 34 insertions, 20 deletions
| diff --git a/lib/stdlib/src/dets.erl b/lib/stdlib/src/dets.erl index e016d5a80e..0488c2bef2 100644 --- a/lib/stdlib/src/dets.erl +++ b/lib/stdlib/src/dets.erl @@ -616,12 +616,18 @@ next(Tab, Key) ->  %% Assuming that a file already exists, open it with the  %% parameters as already specified in the file itself.  %% Return a ref leading to the file. -open_file(File) -> -    case dets_server:open_file(to_list(File)) of -        badarg -> % Should not happen. -            erlang:error(dets_process_died, [File]); -        Reply ->  -            einval(Reply, [File]) +open_file(File0) -> +    File = to_list(File0), +    case is_list(File) of +        true -> +            case dets_server:open_file(File) of +                badarg -> % Should not happen. +                    erlang:error(dets_process_died, [File]); +                Reply -> +                    einval(Reply, [File]) +            end; +        false -> +	    erlang:error(badarg, [File0])      end.  -spec open_file(Name, Args) -> {'ok', Name} | {'error', Reason} when @@ -1088,6 +1094,7 @@ defaults(Tab, Args) ->                             debug = false},      Fun = fun repl/2,      Defaults = lists:foldl(Fun, Defaults0, Args), +    true = is_list(Defaults#open_args.file),      is_comp_min_max(Defaults).  to_list(T) when is_atom(T) -> atom_to_list(T); @@ -1112,9 +1119,7 @@ repl({delayed_write, {Delay,Size} = C}, Defs)      Defs#open_args{delayed_write = C};  repl({estimated_no_objects, I}, Defs)  ->      repl({min_no_slots, I}, Defs); -repl({file, File}, Defs) when is_list(File) -> -    Defs#open_args{file = File}; -repl({file, File}, Defs) when is_atom(File) -> +repl({file, File}, Defs) ->      Defs#open_args{file = to_list(File)};  repl({keypos, P}, Defs) when is_integer(P), P > 0 ->      Defs#open_args{keypos =P}; diff --git a/lib/stdlib/src/filename.erl b/lib/stdlib/src/filename.erl index a322bd002d..b7b7b562ab 100644 --- a/lib/stdlib/src/filename.erl +++ b/lib/stdlib/src/filename.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1997-2017. All Rights Reserved. +%% Copyright Ericsson AB 1997-2018. All Rights Reserved.  %%  %% Licensed under the Apache License, Version 2.0 (the "License");  %% you may not use this file except in compliance with the License. @@ -1012,24 +1012,33 @@ filename_string_to_binary(List) ->  %% basedir  %% http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html --type basedir_type() :: 'user_cache' | 'user_config' | 'user_data' -                      | 'user_log' -                      | 'site_config' | 'site_data'. +-type basedir_path_type() :: 'user_cache' | 'user_config' | 'user_data' +                           | 'user_log'. +-type basedir_paths_type() :: 'site_config' | 'site_data'. --spec basedir(Type,Application) -> file:filename_all() when -      Type :: basedir_type(), +-type basedir_opts() :: #{author => string() | binary(), +                          os => 'windows' | 'darwin' | 'linux', +                          version => string() | binary()}. + +-spec basedir(PathType,Application) -> file:filename_all() when +      PathType :: basedir_path_type(), +      Application :: string() | binary(); +             (PathsType,Application) -> [file:filename_all()] when +      PathsType :: basedir_paths_type(),        Application :: string() | binary().  basedir(Type,Application) when is_atom(Type), is_list(Application) orelse                                                is_binary(Application) ->      basedir(Type, Application, #{}). --spec basedir(Type,Application,Opts) -> file:filename_all() when -      Type :: basedir_type(), +-spec basedir(PathType,Application,Opts) -> file:filename_all() when +      PathType :: basedir_path_type(), +      Application :: string() | binary(), +      Opts :: basedir_opts(); +             (PathsType,Application,Opts) -> [file:filename_all()] when +      PathsType :: basedir_paths_type(),        Application :: string() | binary(), -      Opts :: #{author => string() | binary(), -                os => 'windows' | 'darwin' | 'linux', -                version => string() | binary()}. +      Opts :: basedir_opts().  basedir(Type,Application,Opts) when is_atom(Type), is_map(Opts),                                      is_list(Application) orelse | 
