[all-commits] [llvm/llvm-project] f60e31: ADT: Fix that APSInt's string constructor claims i...
Raphael Isemann via All-commits
all-commits at lists.llvm.org
Wed Jun 10 07:37:30 PDT 2020
Branch: refs/heads/master
Home: https://github.com/llvm/llvm-project
Commit: f60e319419b848b5789d4713de38df381e4fe7b4
https://github.com/llvm/llvm-project/commit/f60e319419b848b5789d4713de38df381e4fe7b4
Author: Raphael Isemann <teemperor at gmail.com>
Date: 2020-06-10 (Wed, 10 Jun 2020)
Changed paths:
M llvm/lib/Support/APSInt.cpp
M llvm/unittests/ADT/APSIntTest.cpp
Log Message:
-----------
ADT: Fix that APSInt's string constructor claims it requires 5 bits to store a zero
Summary:
When constructing an APSInt from a string, the constructor doesn't correctly
truncate the bit width of the result if the passed in string was "0" (or any
alternative way to express 0 like "-0" or "000"). Instead of 1 (which is the
smallest allowed bit width) it returns an APSInt with a bit width of 5.
The reason is that the constructor checks that it never truncates the result to
the invalid bit width of 0, so when it calculates that storing a "0" doesn't
require any bits it just keeps the original overestimated bit width (which
happens to be 5).
This patch just sets the bit width of the result to 1 if the required bit width
is 0.
Reviewers: arphaman, dexonsmith
Reviewed By: dexonsmith
Subscribers: hiraditya, dexonsmith, JDevlieghere, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D81329
More information about the All-commits
mailing list