diff options
| -rw-r--r-- | lib/common_test/test_server/ts_run.erl | 8 | ||||
| -rw-r--r-- | lib/debugger/src/dbg_wx_trace.erl | 6 | ||||
| -rw-r--r-- | lib/kernel/src/application_controller.erl | 4 | ||||
| -rw-r--r-- | lib/stdlib/doc/src/io.xml | 17 | ||||
| -rw-r--r-- | lib/stdlib/src/io_lib_pretty.erl | 2 | ||||
| -rw-r--r-- | lib/stdlib/test/io_SUITE.erl | 22 | 
6 files changed, 45 insertions, 14 deletions
| diff --git a/lib/common_test/test_server/ts_run.erl b/lib/common_test/test_server/ts_run.erl index 5dbbaca916..7e12b9652c 100644 --- a/lib/common_test/test_server/ts_run.erl +++ b/lib/common_test/test_server/ts_run.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1997-2016. 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. @@ -411,9 +411,9 @@ make_common_test_args(Args0, Options0, _Vars) ->  		end,      ConfigFiles = [{config,[filename:join(ConfigPath,File)  			    || File <- get_config_files()]}], -    io_lib:format("~100000p",[[{abort_if_missing_suites,true} |  -			       Args0++Trace++Cover++Logdir++ -			       ConfigFiles++Options++TimeTrap]]). +    io_lib:format("~0p",[[{abort_if_missing_suites,true} | +                          Args0++Trace++Cover++Logdir++ +                              ConfigFiles++Options++TimeTrap]]).  to_list(X) when is_atom(X) ->      atom_to_list(X); diff --git a/lib/debugger/src/dbg_wx_trace.erl b/lib/debugger/src/dbg_wx_trace.erl index 505d53005f..25f32ca7e7 100644 --- a/lib/debugger/src/dbg_wx_trace.erl +++ b/lib/debugger/src/dbg_wx_trace.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %%  -%% Copyright Ericsson AB 2008-2017. All Rights Reserved. +%% Copyright Ericsson AB 2008-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. @@ -518,8 +518,8 @@ gui_cmd({user_command, Cmd}, State) ->  gui_cmd({edit, {Var, Value}}, State) ->      Window = dbg_wx_trace_win:get_window(State#state.win),      Val = case State#state.strings of -              []        -> dbg_wx_win:to_string("~999999lp",[Value]); -              [str_on]  -> dbg_wx_win:to_string("~999999tp",[Value]) +              []        -> dbg_wx_win:to_string("~0lp",[Value]); +              [str_on]  -> dbg_wx_win:to_string("~0tp",[Value])            end,      case dbg_wx_win:entry(Window, "Edit variable", Var, {term, Val}) of  	cancel -> diff --git a/lib/kernel/src/application_controller.erl b/lib/kernel/src/application_controller.erl index ff5df667b5..6906ad0d6e 100644 --- a/lib/kernel/src/application_controller.erl +++ b/lib/kernel/src/application_controller.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1996-2017. All Rights Reserved. +%% Copyright Ericsson AB 1996-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. @@ -2013,5 +2013,5 @@ to_string(Term) ->  	true ->  	    Term;  	false -> -	    lists:flatten(io_lib:format("~134217728p", [Term])) +	    lists:flatten(io_lib:format("~0p", [Term]))      end. diff --git a/lib/stdlib/doc/src/io.xml b/lib/stdlib/doc/src/io.xml index f1037ec76b..d4a2713840 100644 --- a/lib/stdlib/doc/src/io.xml +++ b/lib/stdlib/doc/src/io.xml @@ -4,7 +4,7 @@  <erlref>    <header>      <copyright> -      <year>1996</year><year>2017</year> +      <year>1996</year><year>2018</year>        <holder>Ericsson AB. All Rights Reserved.</holder>      </copyright>      <legalnotice> @@ -332,11 +332,22 @@ Here T = [{attributes,[[{id,age,1.5},            {tag,{'PRIVATE',3}},            {mode,implicit}]  ok</pre> + +            <p>As from Erlang/OTP 21.0, a field width of value +	      <c>0</c> can be used for specifying that a line is +	      infinitely long, which means that no line breaks +	      are inserted. For example:</p> + +	    <pre> +5> <input>io:fwrite("~0p~n", [lists:seq(1, 30)]).</input> +[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30] +ok</pre> +              <p>When the modifier <c>l</c> is specified, no detection of                printable character lists takes place, for example:</p>              <pre> -5> <input>S = [{a,"a"}, {b, "b"}].</input> -6> <input>io:fwrite("~15p~n", [S]).</input> +6> <input>S = [{a,"a"}, {b, "b"}], +   io:fwrite("~15p~n", [S]).</input>  [{a,"a"},   {b,"b"}]  ok diff --git a/lib/stdlib/src/io_lib_pretty.erl b/lib/stdlib/src/io_lib_pretty.erl index 3d5a979b3e..dca1b37ef3 100644 --- a/lib/stdlib/src/io_lib_pretty.erl +++ b/lib/stdlib/src/io_lib_pretty.erl @@ -131,6 +131,8 @@ print(Term, Col, Ll, D, M0, T, RecDefFun, Enc, Str) when is_tuple(Term);      %% use Len as CHAR_MAX if M0 = -1      M = max_cs(M0, Len),      if +        Ll =:= 0 -> +            write(If);          Len < Ll - Col, Len =< M ->              %% write the whole thing on a single line when there is room              write(If); diff --git a/lib/stdlib/test/io_SUITE.erl b/lib/stdlib/test/io_SUITE.erl index 13f2cbd27b..91fe1133f6 100644 --- a/lib/stdlib/test/io_SUITE.erl +++ b/lib/stdlib/test/io_SUITE.erl @@ -31,7 +31,7 @@           otp_10836/1, io_lib_width_too_small/1,           io_with_huge_message_queue/1, format_string/1,  	 maps/1, coverage/1, otp_14178_unicode_atoms/1, otp_14175/1, -         otp_14285/1, limit_term/1, otp_14983/1]). +         otp_14285/1, limit_term/1, otp_14983/1, otp_15103/1]).  -export([pretty/2, trf/3]). @@ -63,7 +63,7 @@ all() ->       io_lib_print_binary_depth_one, otp_10302, otp_10755, otp_10836,       io_lib_width_too_small, io_with_huge_message_queue,       format_string, maps, coverage, otp_14178_unicode_atoms, otp_14175, -     otp_14285, limit_term, otp_14983]. +     otp_14285, limit_term, otp_14983, otp_15103].  %% Error cases for output.  error_1(Config) when is_list(Config) -> @@ -2615,3 +2615,21 @@ trf(Format, Args, T) ->  trf(Format, Args, T, Opts) ->      lists:flatten(io_lib:format(Format, Args, [{chars_limit, T}|Opts])). + +otp_15103(_Config) -> +    T = lists:duplicate(5, {a,b,c}), + +    S1 = io_lib:format("~0p", [T]), +    "[{a,b,c},{a,b,c},{a,b,c},{a,b,c},{a,b,c}]" = lists:flatten(S1), +    S2 = io_lib:format("~-0p", [T]), +    "[{a,b,c},{a,b,c},{a,b,c},{a,b,c},{a,b,c}]" = lists:flatten(S2), +    S3 = io_lib:format("~1p", [T]), +    "[{a,\n  b,\n  c},\n {a,\n  b,\n  c},\n {a,\n  b,\n  c},\n {a,\n  b,\n" +    "  c},\n {a,\n  b,\n  c}]" = lists:flatten(S3), + +    S4 = io_lib:format("~0P", [T, 5]), +    "[{a,b,c},{a,b,...},{a,...},{...}|...]" = lists:flatten(S4), +    S5 = io_lib:format("~1P", [T, 5]), +    "[{a,\n  b,\n  c},\n {a,\n  b,...},\n {a,...},\n {...}|...]" = +        lists:flatten(S5), +    ok. | 
