diff options
author | Björn Gustavsson <[email protected]> | 2012-08-22 14:54:45 +0200 |
---|---|---|
committer | Björn Gustavsson <[email protected]> | 2012-08-22 16:16:26 +0200 |
commit | e4e5d08621137473674cf3cdce0b36a43a8d6d15 (patch) | |
tree | be27bd18de935d599efa2b48363d9df6d0edc766 /lib/compiler/src/compile.erl | |
parent | 064b42237d891d5fdcb6c1a351980b8291437618 (diff) | |
download | otp-e4e5d08621137473674cf3cdce0b36a43a8d6d15.tar.gz otp-e4e5d08621137473674cf3cdce0b36a43a8d6d15.tar.bz2 otp-e4e5d08621137473674cf3cdce0b36a43a8d6d15.zip |
compiler: Warn if the size of a binary segment is invalid
The compiler would silently accept and Dialyzer would crash on
code like:
<<X:(2.5)>>
It is never acceptable for Dialyzer to crash. The compiler should
at least generate a warning for such code. It is tempting to let
the compiler generate an error, but that would mean that code like:
Sz = 42.0,
<<X:Sz>>.
would be possible to compile with optimizations disabled, but not
with optimizations enabled.
Dialyzer crashes because it calls cerl:bitstr_bitsize/1, which
crashes if the type of size for the segment is invalid. The easiest
way to avoid that crash is to extend the sanity checks in v3_core
to also include the size field of binary segments. That will cause
the compiler to issue a warning and to replace the bad binary
construction with a call to erlang:error/1. (It also means that
Dialyzer will not issue a warning for bad size fields.)
Diffstat (limited to 'lib/compiler/src/compile.erl')
0 files changed, 0 insertions, 0 deletions