diff options
| author | Hans Bolinder <[email protected]> | 2016-05-19 08:59:45 +0200 | 
|---|---|---|
| committer | Hans Bolinder <[email protected]> | 2016-06-09 11:28:00 +0200 | 
| commit | fb49e45402c0370c030ce3c128b08bccf960bf44 (patch) | |
| tree | f287e8eb12c276f2412020ee7420f9c55cb96bc6 /lib/stdlib/src | |
| parent | 38cdb3b5131257a8cc76b8f64e32b8ecf722bdb4 (diff) | |
| download | otp-fb49e45402c0370c030ce3c128b08bccf960bf44.tar.gz otp-fb49e45402c0370c030ce3c128b08bccf960bf44.tar.bz2 otp-fb49e45402c0370c030ce3c128b08bccf960bf44.zip | |
stdlib: Correct types and specs
Diffstat (limited to 'lib/stdlib/src')
| -rw-r--r-- | lib/stdlib/src/erl_expand_records.erl | 5 | ||||
| -rw-r--r-- | lib/stdlib/src/erl_lint.erl | 6 | ||||
| -rw-r--r-- | lib/stdlib/src/erl_parse.yrl | 30 | ||||
| -rw-r--r-- | lib/stdlib/src/erl_pp.erl | 4 | ||||
| -rw-r--r-- | lib/stdlib/src/lib.erl | 2 | ||||
| -rw-r--r-- | lib/stdlib/src/ms_transform.erl | 7 | ||||
| -rw-r--r-- | lib/stdlib/src/qlc.erl | 7 | ||||
| -rw-r--r-- | lib/stdlib/src/qlc_pt.erl | 18 | ||||
| -rw-r--r-- | lib/stdlib/src/sofs.erl | 3 | 
9 files changed, 49 insertions, 33 deletions
| diff --git a/lib/stdlib/src/erl_expand_records.erl b/lib/stdlib/src/erl_expand_records.erl index 9c0a7fb7d5..ebcbc54ab1 100644 --- a/lib/stdlib/src/erl_expand_records.erl +++ b/lib/stdlib/src/erl_expand_records.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 2005-2015. All Rights Reserved. +%% Copyright Ericsson AB 2005-2016. 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. @@ -37,8 +37,9 @@                   checked_ra=[]        % successfully accessed records                  }). --spec(module(AbsForms, CompileOptions) -> AbsForms when +-spec(module(AbsForms, CompileOptions) -> AbsForms2 when        AbsForms :: [erl_parse:abstract_form()], +      AbsForms2 :: [erl_parse:abstract_form()],        CompileOptions :: [compile:option()]).  %% Is is assumed that Fs is a valid list of forms. It should pass diff --git a/lib/stdlib/src/erl_lint.erl b/lib/stdlib/src/erl_lint.erl index 2508f96b91..0f0004ed42 100644 --- a/lib/stdlib/src/erl_lint.erl +++ b/lib/stdlib/src/erl_lint.erl @@ -467,7 +467,7 @@ used_vars(Exprs, BindingsList) ->  %%  really all ordsets!  -spec(module(AbsForms) -> {ok, Warnings} | {error, Errors, Warnings} when -      AbsForms :: [erl_parse:abstract_form()], +      AbsForms :: [erl_parse:abstract_form() | erl_parse:form_info()],        Warnings :: [{file:filename(),[ErrorInfo]}],        Errors :: [{FileName2 :: file:filename(),[ErrorInfo]}],        ErrorInfo :: error_info()). @@ -479,7 +479,7 @@ module(Forms) ->  -spec(module(AbsForms, FileName) ->               {ok, Warnings} | {error, Errors, Warnings} when -      AbsForms :: [erl_parse:abstract_form()], +      AbsForms :: [erl_parse:abstract_form() | erl_parse:form_info()],        FileName :: atom() | string(),        Warnings :: [{file:filename(),[ErrorInfo]}],        Errors :: [{FileName2 :: file:filename(),[ErrorInfo]}], @@ -492,7 +492,7 @@ module(Forms, FileName) ->  -spec(module(AbsForms, FileName, CompileOptions) ->               {ok, Warnings} | {error, Errors, Warnings} when -      AbsForms :: [erl_parse:abstract_form()], +      AbsForms :: [erl_parse:abstract_form() | erl_parse:form_info()],        FileName :: atom() | string(),        CompileOptions :: [compile:option()],        Warnings :: [{file:filename(),[ErrorInfo]}], diff --git a/lib/stdlib/src/erl_parse.yrl b/lib/stdlib/src/erl_parse.yrl index a896de4f1c..35faf95cba 100644 --- a/lib/stdlib/src/erl_parse.yrl +++ b/lib/stdlib/src/erl_parse.yrl @@ -534,7 +534,7 @@ Erlang code.  -compile([{hipe,[{regalloc,linear_scan}]}]).  -export_type([abstract_clause/0, abstract_expr/0, abstract_form/0, -              abstract_type/0, error_info/0]). +              abstract_type/0, form_info/0, error_info/0]).  %% Start of Abstract Format @@ -546,7 +546,6 @@ Erlang code.                         | af_export()                         | af_import()                         | af_export_type() -                       | af_optional_callbacks()                         | af_compile()                         | af_file()                         | af_record_decl() @@ -573,9 +572,6 @@ Erlang code.  -type af_ta_list() :: [{type_name(), arity()}]. --type af_optional_callbacks() :: -        {'attribute', anno(), 'optional_callbacks', af_fa_list()}. -  -type af_compile() :: {'attribute', anno(), 'compile', any()}.  -type af_file() :: {'attribute', anno(), 'file', {string(), anno()}}. @@ -867,16 +863,22 @@ Erlang code.                                     | af_unary_op(af_singleton_integer_type())                                     | af_binary_op(af_singleton_integer_type()). --type af_literal() :: af_atom() | af_integer() | af_float() | af_string(). +-type af_literal() :: af_atom() +                    | af_character() +                    | af_float() +                    | af_integer() +                    | af_string().  -type af_atom() :: af_lit_atom(atom()).  -type af_lit_atom(A) :: {'atom', anno(), A}. --type af_integer() :: {'integer', anno(), non_neg_integer()}. +-type af_character() :: {'char', anno(), char()}.  -type af_float() :: {'float', anno(), float()}. +-type af_integer() :: {'integer', anno(), non_neg_integer()}. +  -type af_string() :: {'string', anno(), string()}.  -type af_match(T) :: {'match', anno(), af_pattern(), T}. @@ -944,6 +946,10 @@ Erlang code.  -type type_name() :: atom(). +-type form_info() :: {'eof', erl_anno:line()} +                   | {'error', erl_scan:error_info() | error_info()} +                   | {'warning', erl_scan:error_info() | error_info()}. +  %% End of Abstract Format  %% XXX. To be refined. @@ -1513,14 +1519,14 @@ map_anno(F0, Abstr) ->      {NewAbstr, []} = modify_anno1(Abstr, [], F),      NewAbstr. --spec fold_anno(Fun, Acc0, Abstr) -> NewAbstr when +-spec fold_anno(Fun, Acc0, Abstr) -> Acc1 when        Fun :: fun((Anno, AccIn) -> AccOut),        Anno :: erl_anno:anno(),        Acc0 :: term(), +      Acc1 :: term(),        AccIn :: term(),        AccOut :: term(), -      Abstr :: erl_parse_tree(), -      NewAbstr :: erl_parse_tree(). +      Abstr :: erl_parse_tree().  fold_anno(F0, Acc0, Abstr) ->      F = fun(A, Acc) -> {A, F0(A, Acc)} end, @@ -1545,7 +1551,9 @@ mapfold_anno(F, Acc0, Abstr) ->        Abstr :: erl_parse_tree().  new_anno(Term) -> -    map_anno(fun erl_anno:new/1, Term). +    F = fun(L, Acc) -> {erl_anno:new(L), Acc} end, +    {NewAbstr, []} = modify_anno1(Term, [], F), +    NewAbstr.  -spec anno_to_term(Abstr) -> term() when        Abstr :: erl_parse_tree(). diff --git a/lib/stdlib/src/erl_pp.erl b/lib/stdlib/src/erl_pp.erl index ca764675fc..71a3835b66 100644 --- a/lib/stdlib/src/erl_pp.erl +++ b/lib/stdlib/src/erl_pp.erl @@ -70,13 +70,13 @@  %%%  -spec(form(Form) -> io_lib:chars() when -      Form :: erl_parse:abstract_form()). +      Form :: erl_parse:abstract_form() | erl_parse:form_info()).  form(Thing) ->      form(Thing, none).  -spec(form(Form, Options) -> io_lib:chars() when -      Form :: erl_parse:abstract_form(), +      Form :: erl_parse:abstract_form() | erl_parse:form_info(),        Options :: options()).  form(Thing, Options) -> diff --git a/lib/stdlib/src/lib.erl b/lib/stdlib/src/lib.erl index 6fba63a895..56654097d9 100644 --- a/lib/stdlib/src/lib.erl +++ b/lib/stdlib/src/lib.erl @@ -73,7 +73,7 @@ nonl([H|T]) -> [H|nonl(T)].  send(To, Msg) -> To ! Msg. --spec sendw(To, Msg) -> Msg when +-spec sendw(To, Msg) -> term() when        To :: pid() | atom() | {atom(), node()},        Msg :: term(). diff --git a/lib/stdlib/src/ms_transform.erl b/lib/stdlib/src/ms_transform.erl index 24b5fde1db..c0eea652e7 100644 --- a/lib/stdlib/src/ms_transform.erl +++ b/lib/stdlib/src/ms_transform.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %%  -%% Copyright Ericsson AB 2002-2015. All Rights Reserved. +%% Copyright Ericsson AB 2002-2016. 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. @@ -224,8 +224,9 @@ transform_from_shell(Dialect, Clauses, BoundEnvironment) ->  %% Called when translating during compiling  %% --spec parse_transform(Forms, Options) -> Forms when -      Forms :: [erl_parse:abstract_form()], +-spec parse_transform(Forms, Options) -> Forms2 when +      Forms :: [erl_parse:abstract_form() | erl_parse:form_info()], +      Forms2 :: [erl_parse:abstract_form() | erl_parse:form_info()],        Options :: term().  parse_transform(Forms, _Options) -> diff --git a/lib/stdlib/src/qlc.erl b/lib/stdlib/src/qlc.erl index b396ba7057..f3665824f2 100644 --- a/lib/stdlib/src/qlc.erl +++ b/lib/stdlib/src/qlc.erl @@ -734,10 +734,11 @@ table(TraverseFun, Options) when is_function(TraverseFun) ->  table(T1, T2) ->      erlang:error(badarg, [T1, T2]). --spec(transform_from_evaluator(LC, Bs) -> Expr when +-spec(transform_from_evaluator(LC, Bs) -> Return when        LC :: abstract_expr(), -      Expr :: abstract_expr(), -      Bs :: erl_eval:binding_struct()). +      Bs :: erl_eval:binding_struct(), +      Return :: {ok, abstract_expr()} +              | {not_ok, {error, module(), Reason :: term()}}).  transform_from_evaluator(LC, Bs0) ->      qlc_pt:transform_from_evaluator(LC, Bs0). diff --git a/lib/stdlib/src/qlc_pt.erl b/lib/stdlib/src/qlc_pt.erl index e4b9768b12..0db63b81f4 100644 --- a/lib/stdlib/src/qlc_pt.erl +++ b/lib/stdlib/src/qlc_pt.erl @@ -67,8 +67,8 @@  %%%  -spec(parse_transform(Forms, Options) -> Forms2 when -      Forms :: [erl_parse:abstract_form()], -      Forms2 :: [erl_parse:abstract_form()], +      Forms :: [erl_parse:abstract_form() | erl_parse:form_info()], +      Forms2 :: [erl_parse:abstract_form() | erl_parse:form_info()],        Options :: [Option],        Option :: type_checker | compile:option()). @@ -117,19 +117,21 @@ parse_transform(Forms0, Options) ->          true = ets:delete(NodeInfo)      end. --spec(transform_from_evaluator(LC, Bs) -> Expr when +-spec(transform_from_evaluator(LC, Bs) -> Return when        LC :: erl_parse:abstract_expr(), -      Expr :: erl_parse:abstract_expr(), -      Bs :: erl_eval:binding_struct()). +      Bs :: erl_eval:binding_struct(), +      Return :: {ok, erl_parse:abstract_expr()} +              | {not_ok, {error, module(), Reason :: term()}}).  transform_from_evaluator(LC, Bindings) ->      ?DEBUG("qlc Parse Transform (Evaluator Version)~n", []),      transform_expression(LC, Bindings, false). --spec(transform_expression(LC, Bs) -> Expr when +-spec(transform_expression(LC, Bs) -> Return when        LC :: erl_parse:abstract_expr(), -      Expr :: erl_parse:abstract_expr(), -      Bs :: erl_eval:binding_struct()). +      Bs :: erl_eval:binding_struct(), +      Return :: {ok, erl_parse:abstract_expr()} +              | {not_ok, [{error, Reason :: term()}]}).  transform_expression(LC, Bindings) ->      transform_expression(LC, Bindings, true). diff --git a/lib/stdlib/src/sofs.erl b/lib/stdlib/src/sofs.erl index b18df2ad09..c244e06ca4 100644 --- a/lib/stdlib/src/sofs.erl +++ b/lib/stdlib/src/sofs.erl @@ -621,6 +621,9 @@ canonical_relation(Sets) when ?IS_SET(Sets) ->  %%% Functions on binary relations only.  %%% +-spec(rel2fam(BinRel) -> Family when +      Family :: family(), +      BinRel :: binary_relation()).  rel2fam(R) ->      relation_to_family(R). | 
