diff options
Diffstat (limited to 'lib/stdlib/src')
| -rw-r--r-- | lib/stdlib/src/c.erl | 2 | ||||
| -rw-r--r-- | lib/stdlib/src/proc_lib.erl | 6 | ||||
| -rw-r--r-- | lib/stdlib/src/shell.erl | 16 | ||||
| -rw-r--r-- | lib/stdlib/src/string.erl | 10 | 
4 files changed, 21 insertions, 13 deletions
| diff --git a/lib/stdlib/src/c.erl b/lib/stdlib/src/c.erl index 4ab9234b81..c04a201ce1 100644 --- a/lib/stdlib/src/c.erl +++ b/lib/stdlib/src/c.erl @@ -255,7 +255,7 @@ safe_recompile(File, Options, BeamFile) ->  compile_and_load(File, Opts0) when is_list(Opts0) ->      Opts = [report_errors, report_warnings              | ensure_from(filename:extension(File), -                          ensure_outdir(filename:dirname(File), Opts0))], +                          ensure_outdir(".", Opts0))],      case compile:file(File, Opts) of  	{ok,Mod} ->				%Listing file.  	    purge_and_load(Mod, File, Opts); diff --git a/lib/stdlib/src/proc_lib.erl b/lib/stdlib/src/proc_lib.erl index 9ce8e7d60e..d4d1bdccec 100644 --- a/lib/stdlib/src/proc_lib.erl +++ b/lib/stdlib/src/proc_lib.erl @@ -779,11 +779,13 @@ format_link_report([Link|Reps], Indent, Extra) ->      LinkIndent = ["  ",Indent],      [Indent,"neighbour:\n",format_report(Rep, LinkIndent, Extra)|       format_link_report(Reps, Indent, Extra)]; -format_link_report([], _, _) -> -    []. +format_link_report(Rep, Indent, Extra) -> +    format_report(Rep, Indent, Extra).  format_report(Rep, Indent, Extra) when is_list(Rep) ->      format_rep(Rep, Indent, Extra); +format_report(Rep, Indent, {Enc,unlimited}) -> +    io_lib:format("~s~"++modifier(Enc)++"p~n", [Indent, Rep]);  format_report(Rep, Indent, {Enc,Depth}) ->      io_lib:format("~s~"++modifier(Enc)++"P~n", [Indent, Rep, Depth]). diff --git a/lib/stdlib/src/shell.erl b/lib/stdlib/src/shell.erl index 6eafc7b209..26b3960f4f 100644 --- a/lib/stdlib/src/shell.erl +++ b/lib/stdlib/src/shell.erl @@ -727,7 +727,7 @@ result_will_be_saved() ->  used_record_defs(E, RT) ->      %% Be careful to return a list where used records come before      %% records that use them. The linter wants them ordered that way. -    UR = case used_records(E, [], RT) of +    UR = case used_records(E, [], RT, []) of               [] ->                    [];               L0 -> @@ -737,13 +737,19 @@ used_record_defs(E, RT) ->           end,      record_defs(RT, UR). -used_records(E, U0, RT) -> +used_records(E, U0, RT, Skip) ->      case used_records(E) of          {name,Name,E1} -> -            U = used_records(ets:lookup(RT, Name), [Name | U0], RT), -            used_records(E1, U, RT); +            U = case lists:member(Name, Skip) of +                    true -> +                        U0; +                    false -> +                        R = ets:lookup(RT, Name), +                        used_records(R, [Name | U0], RT, [Name | Skip]) +                end, +            used_records(E1, U, RT, Skip);          {expr,[E1 | Es]} -> -            used_records(Es, used_records(E1, U0, RT), RT); +            used_records(Es, used_records(E1, U0, RT, Skip), RT, Skip);          _ ->              U0      end. diff --git a/lib/stdlib/src/string.erl b/lib/stdlib/src/string.erl index 6f7009b5d9..4972da297d 100644 --- a/lib/stdlib/src/string.erl +++ b/lib/stdlib/src/string.erl @@ -384,7 +384,7 @@ to_float(String) ->      end.  to_number(String, Number, Rest, List, _Tail) when is_binary(String) -> -    BSz = length(List)-length(Rest), +    BSz = erlang:length(List)-erlang:length(Rest),      <<_:BSz/binary, Cont/binary>> = String,      {Number, Cont};  to_number(_, Number, Rest, _, Tail) -> @@ -1344,7 +1344,7 @@ bin_search_str(Bin0, Start, Cont, [CP|_]=SearchCPs) ->        String :: string(),        Length :: non_neg_integer(). -len(S) -> length(S). +len(S) -> erlang:length(S).  %% equal(String1, String2)  %%  Test if 2 strings are equal. @@ -1689,7 +1689,7 @@ left(String, Len) when is_integer(Len) -> left(String, Len, $\s).        Character :: char().  left(String, Len, Char) when is_integer(Char) -> -    Slen = length(String), +    Slen = erlang:length(String),      if  	Slen > Len -> substr(String, 1, Len);  	Slen < Len -> l_pad(String, Len-Slen, Char); @@ -1714,7 +1714,7 @@ right(String, Len) when is_integer(Len) -> right(String, Len, $\s).        Character :: char().  right(String, Len, Char) when is_integer(Char) -> -    Slen = length(String), +    Slen = erlang:length(String),      if  	Slen > Len -> substr(String, Slen-Len+1);  	Slen < Len -> r_pad(String, Len-Slen, Char); @@ -1741,7 +1741,7 @@ centre(String, Len) when is_integer(Len) -> centre(String, Len, $\s).  centre(String, 0, Char) when is_list(String), is_integer(Char) ->      [];                       % Strange cases to centre string  centre(String, Len, Char) when is_integer(Char) -> -    Slen = length(String), +    Slen = erlang:length(String),      if  	Slen > Len -> substr(String, (Slen-Len) div 2 + 1, Len);  	Slen < Len -> | 
