diff options
author | Björn Gustavsson <[email protected]> | 2017-03-20 11:57:17 +0100 |
---|---|---|
committer | GitHub <[email protected]> | 2017-03-20 11:57:17 +0100 |
commit | a85efc31824b4d59f4ed1eefcd19e9d7c6ef021f (patch) | |
tree | 00c6f060c48e0e4f8fb4dde024d9711a1eab57a0 /lib/stdlib/src | |
parent | 748c2d938d309940b8365ed4f6af863b8129c5bf (diff) | |
parent | 6fe3935bc51c0fc62b2d740ac43e64ff276bbef8 (diff) | |
download | otp-a85efc31824b4d59f4ed1eefcd19e9d7c6ef021f.tar.gz otp-a85efc31824b4d59f4ed1eefcd19e9d7c6ef021f.tar.bz2 otp-a85efc31824b4d59f4ed1eefcd19e9d7c6ef021f.zip |
Merge pull request #1378 from bjorng/bjorn/disallow-unicode-module-names/OTP-14285
Don't allow module names with non-latin1 characters
Diffstat (limited to 'lib/stdlib/src')
-rw-r--r-- | lib/stdlib/src/erl_lint.erl | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/lib/stdlib/src/erl_lint.erl b/lib/stdlib/src/erl_lint.erl index 0ffca0886f..0789f5dfb7 100644 --- a/lib/stdlib/src/erl_lint.erl +++ b/lib/stdlib/src/erl_lint.erl @@ -156,6 +156,8 @@ format_error(pmod_unsupported) -> "parameterized modules are no longer supported"; %% format_error({redefine_mod_import, M, P}) -> %% io_lib:format("module '~s' already imported from package '~s'", [M, P]); +format_error(non_latin1_module_unsupported) -> + "module names with non-latin1 characters are not supported"; format_error(invalid_call) -> "invalid function call"; @@ -733,9 +735,15 @@ form(Form, #lint{state=State}=St) -> start_state({attribute,Line,module,{_,_}}=Form, St0) -> St1 = add_error(Line, pmod_unsupported, St0), attribute_state(Form, St1#lint{state=attribute}); -start_state({attribute,_,module,M}, St0) -> +start_state({attribute,Line,module,M}, St0) -> St1 = St0#lint{module=M}, - St1#lint{state=attribute}; + St2 = St1#lint{state=attribute}, + case is_non_latin1_name(M) of + true -> + add_error(Line, non_latin1_module_unsupported, St2); + false -> + St2 + end; start_state(Form, St) -> Anno = case Form of {eof, L} -> erl_anno:new(L); @@ -745,6 +753,9 @@ start_state(Form, St) -> St1 = add_error(Anno, undefined_module, St), attribute_state(Form, St1#lint{state=attribute}). +is_non_latin1_name(Name) -> + lists:any(fun(C) -> C > 255 end, atom_to_list(Name)). + %% attribute_state(Form, State) -> %% State' |