diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2013-12-22 00:04:03 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2013-12-22 00:04:03 +0000 | 
| commit | f8af5cf600354830d4ccf59732403f0f073eccb9 (patch) | |
| tree | 2ba0398b4c42ad4f55561327538044fd2c925a8b /lib/Bitcode/Reader/BitstreamReader.cpp | |
| parent | 59d6cff90eecf31cb3dd860c4e786674cfdd42eb (diff) | |
Notes
Diffstat (limited to 'lib/Bitcode/Reader/BitstreamReader.cpp')
| -rw-r--r-- | lib/Bitcode/Reader/BitstreamReader.cpp | 13 | 
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/Bitcode/Reader/BitstreamReader.cpp b/lib/Bitcode/Reader/BitstreamReader.cpp index 9dafe2a03670..1fd9abd8b180 100644 --- a/lib/Bitcode/Reader/BitstreamReader.cpp +++ b/lib/Bitcode/Reader/BitstreamReader.cpp @@ -204,7 +204,16 @@ unsigned BitstreamCursor::readRecord(unsigned AbbrevID,    const BitCodeAbbrev *Abbv = getAbbrev(AbbrevID); -  for (unsigned i = 0, e = Abbv->getNumOperandInfos(); i != e; ++i) { +  // Read the record code first. +  assert(Abbv->getNumOperandInfos() != 0 && "no record code in abbreviation?"); +  const BitCodeAbbrevOp &CodeOp = Abbv->getOperandInfo(0); +  if (CodeOp.isLiteral()) +    readAbbreviatedLiteral(CodeOp, Vals); +  else +    readAbbreviatedField(CodeOp, Vals); +  unsigned Code = (unsigned)Vals.pop_back_val(); + +  for (unsigned i = 1, e = Abbv->getNumOperandInfos(); i != e; ++i) {      const BitCodeAbbrevOp &Op = Abbv->getOperandInfo(i);      if (Op.isLiteral()) {        readAbbreviatedLiteral(Op, Vals); @@ -264,8 +273,6 @@ unsigned BitstreamCursor::readRecord(unsigned AbbrevID,      JumpToBit(NewEnd);    } -  unsigned Code = (unsigned)Vals[0]; -  Vals.erase(Vals.begin());    return Code;  }  | 
