diff options
Diffstat (limited to 'lib/stdlib/src/io.erl')
| -rw-r--r-- | lib/stdlib/src/io.erl | 20 | 
1 files changed, 3 insertions, 17 deletions
| diff --git a/lib/stdlib/src/io.erl b/lib/stdlib/src/io.erl index 78412ab2bc..6aeb076a0b 100644 --- a/lib/stdlib/src/io.erl +++ b/lib/stdlib/src/io.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1996-2010. All Rights Reserved. +%% Copyright Ericsson AB 1996-2011. All Rights Reserved.  %%  %% The contents of this file are subject to the Erlang Public License,  %% Version 1.1, (the "License"); you may not use this file except in @@ -55,26 +55,12 @@  to_tuple(T) when is_tuple(T) -> T;  to_tuple(T) -> {T}. -%% Problem: the variables Other, Name and Args may collide with surrounding -%% ones. -%% Give extra args to macro, being the variables to use. --define(O_REQUEST(Io, Request), -    case request(Io, Request) of -	{error, Reason} -> -	    [Name | Args] = tuple_to_list(to_tuple(Request)), -	    erlang:error(conv_reason(Name, Reason), [Name, Io | Args]); -	Other -> -	    Other -    end). -  o_request(Io, Request, Func) ->      case request(Io, Request) of  	{error, Reason} ->  	    [_Name | Args] = tuple_to_list(to_tuple(Request)), -	    {'EXIT',{undef,[_Current|Mfas]}} = (catch erlang:error(undef)), -	    MFA = {io, Func, [Io | Args]}, -	    exit({conv_reason(Func, Reason),[MFA|Mfas]}); -%	    erlang:error(conv_reason(Name, Reason), [Name, Io | Args]); +	    {'EXIT',{get_stacktrace,[_Current|Mfas]}} = (catch erlang:error(get_stacktrace)), +	    erlang:raise(error, conv_reason(Func, Reason), [{io, Func, [Io | Args]}|Mfas]);  	Other ->  	    Other      end. | 
