diff options
| author | Björn Gustavsson <[email protected]> | 2017-05-09 09:23:25 +0200 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2017-05-09 09:23:25 +0200 | 
| commit | e1c70e41196e8118d9f24b8d9023cb0f876ee0df (patch) | |
| tree | a47d5681431f8e9d543b0f86ba02463fb48a6667 /lib/compiler | |
| parent | c002dc9493a2ae9b01d49e39b9e89ef38b165973 (diff) | |
| parent | 3393e2249d0987ec25eefbacb7b24c061fd7a64e (diff) | |
| download | otp-e1c70e41196e8118d9f24b8d9023cb0f876ee0df.tar.gz otp-e1c70e41196e8118d9f24b8d9023cb0f876ee0df.tar.bz2 otp-e1c70e41196e8118d9f24b8d9023cb0f876ee0df.zip | |
Merge pull request #1439 from josevalim/jv-atu8-function
Add a test for utf8 function names
Diffstat (limited to 'lib/compiler')
| -rw-r--r-- | lib/compiler/src/v3_kernel_pp.erl | 2 | ||||
| -rw-r--r-- | lib/compiler/test/compile_SUITE.erl | 21 | 
2 files changed, 20 insertions, 3 deletions
| diff --git a/lib/compiler/src/v3_kernel_pp.erl b/lib/compiler/src/v3_kernel_pp.erl index 187e69a22c..716280a95c 100644 --- a/lib/compiler/src/v3_kernel_pp.erl +++ b/lib/compiler/src/v3_kernel_pp.erl @@ -145,7 +145,7 @@ format_1(#k_local{name=N,arity=A}, Ctxt) ->      "local " ++ format_fa_pair({N,A}, Ctxt);  format_1(#k_remote{mod=M,name=N,arity=A}, _Ctxt) ->      %% This is for our internal translator. -    io_lib:format("remote ~s:~s/~w", [format(M),format(N),A]); +    io_lib:format("remote ~ts:~ts/~w", [format(M),format(N),A]);  format_1(#k_internal{name=N,arity=A}, Ctxt) ->      "internal " ++ format_fa_pair({N,A}, Ctxt);  format_1(#k_seq{arg=A,body=B}, Ctxt) -> diff --git a/lib/compiler/test/compile_SUITE.erl b/lib/compiler/test/compile_SUITE.erl index dbf91400ad..1d9c7c44fa 100644 --- a/lib/compiler/test/compile_SUITE.erl +++ b/lib/compiler/test/compile_SUITE.erl @@ -31,7 +31,7 @@  	 file_1/1, forms_2/1, module_mismatch/1, big_file/1, outdir/1,  	 binary/1, makedep/1, cond_and_ifdef/1, listings/1, listings_big/1,  	 other_output/1, kernel_listing/1, encrypted_abstr/1, -	 strict_record/1, utf8_atoms/1, extra_chunks/1, +	 strict_record/1, utf8_atoms/1, utf8_functions/1, extra_chunks/1,  	 cover/1, env/1, core/1,  	 core_roundtrip/1, asm/1, optimized_guards/1,  	 sys_pre_attributes/1, dialyzer/1, @@ -49,7 +49,7 @@ all() ->      [app_test, appup_test, file_1, forms_2, module_mismatch, big_file, outdir,       binary, makedep, cond_and_ifdef, listings, listings_big,       other_output, kernel_listing, encrypted_abstr, -     strict_record, utf8_atoms, extra_chunks, +     strict_record, utf8_atoms, utf8_functions, extra_chunks,       cover, env, core, core_roundtrip, asm, optimized_guards,       sys_pre_attributes, dialyzer, warnings, pre_load_check,       env_compiler_options, custom_debug_info]. @@ -727,6 +727,23 @@ utf8_atoms(Config) when is_list(Config) ->      NoUtf8AtomForms = [{attribute,Anno,module,no_utf8_atom}|Forms],      error = compile:forms(NoUtf8AtomForms, [binary, r19]). +utf8_functions(Config) when is_list(Config) -> +    Anno = erl_anno:new(1), +    Atom = binary_to_atom(<<"こんにちは"/utf8>>, utf8), +    Forms = [{attribute,Anno,compile,[export_all]}, +	     {function,Anno,Atom,0,[{clause,Anno,[],[],[{atom,Anno,world}]}]}], + +    Utf8FunctionForms = [{attribute,Anno,module,utf8_function}|Forms], +    {ok,utf8_function,Utf8FunctionBin} = +	compile:forms(Utf8FunctionForms, [binary]), +    {ok,{utf8_function,[{atoms,_}]}} = +	beam_lib:chunks(Utf8FunctionBin, [atoms]), +    code:load_binary(utf8_function, "compile_SUITE", Utf8FunctionBin), +    world = utf8_function:Atom(), + +    NoUtf8FunctionForms = [{attribute,Anno,module,no_utf8_function}|Forms], +    error = compile:forms(NoUtf8FunctionForms, [binary, r19]). +  extra_chunks(Config) when is_list(Config) ->      Anno = erl_anno:new(1),      Forms = [{attribute,Anno,module,extra_chunks}], | 
