diff options
Diffstat (limited to 'lib/Frontend/TextDiagnostic.cpp')
| -rw-r--r-- | lib/Frontend/TextDiagnostic.cpp | 24 | 
1 files changed, 13 insertions, 11 deletions
| diff --git a/lib/Frontend/TextDiagnostic.cpp b/lib/Frontend/TextDiagnostic.cpp index 6e6f3dd1bfee..bbc99141f072 100644 --- a/lib/Frontend/TextDiagnostic.cpp +++ b/lib/Frontend/TextDiagnostic.cpp @@ -176,7 +176,7 @@ static void expandTabs(std::string &SourceLine, unsigned TabStop) {  ///  of the printable representation of the line to the columns those printable  ///  characters will appear at (numbering the first column as 0).  /// -/// If a byte 'i' corresponds to muliple columns (e.g. the byte contains a tab +/// If a byte 'i' corresponds to multiple columns (e.g. the byte contains a tab  ///  character) then the array will map that byte to the first column the  ///  tab appears at and the next value in the map will have been incremented  ///  more than once. @@ -293,14 +293,14 @@ struct SourceColumnMap {    /// \brief Map from a byte index to the next byte which starts a column.    int startOfNextColumn(int N) const { -    assert(0 <= N && N < static_cast<int>(m_columnToByte.size() - 1)); +    assert(0 <= N && N < static_cast<int>(m_byteToColumn.size() - 1));      while (byteToColumn(++N) == -1) {}      return N;    }    /// \brief Map from a byte index to the previous byte which starts a column.    int startOfPreviousColumn(int N) const { -    assert(0 < N && N < static_cast<int>(m_columnToByte.size())); +    assert(0 < N && N < static_cast<int>(m_byteToColumn.size()));      while (byteToColumn(--N) == -1) {}      return N;    } @@ -323,9 +323,10 @@ static void selectInterestingSourceRegion(std::string &SourceLine,                                            std::string &FixItInsertionLine,                                            unsigned Columns,                                            const SourceColumnMap &map) { -  unsigned MaxColumns = std::max<unsigned>(map.columns(), -                                           std::max(CaretLine.size(), -                                                    FixItInsertionLine.size())); +  unsigned CaretColumns = CaretLine.size(); +  unsigned FixItColumns = llvm::sys::locale::columnWidth(FixItInsertionLine); +  unsigned MaxColumns = std::max(static_cast<unsigned>(map.columns()), +                                 std::max(CaretColumns, FixItColumns));    // if the number of columns is less than the desired number we're done    if (MaxColumns <= Columns)      return; @@ -487,7 +488,7 @@ static void selectInterestingSourceRegion(std::string &SourceLine,    // We checked up front that the line needed truncation    assert(FrontColumnsRemoved+ColumnsKept+BackColumnsRemoved > Columns); -  // The line needs some trunctiona, and we'd prefer to keep the front +  // The line needs some truncation, and we'd prefer to keep the front    //  if possible, so remove the back    if (BackColumnsRemoved > strlen(back_ellipse))      SourceLine.replace(SourceEnd, std::string::npos, back_ellipse); @@ -1110,12 +1111,13 @@ void TextDiagnostic::emitSnippetAndCaret(    // Copy the line of code into an std::string for ease of manipulation.    std::string SourceLine(LineStart, LineEnd); -  // Create a line for the caret that is filled with spaces that is the same -  // length as the line of source code. -  std::string CaretLine(LineEnd-LineStart, ' '); - +  // Build the byte to column map.    const SourceColumnMap sourceColMap(SourceLine, DiagOpts->TabStop); +  // Create a line for the caret that is filled with spaces that is the same +  // number of columns as the line of source code. +  std::string CaretLine(sourceColMap.columns(), ' '); +    // Highlight all of the characters covered by Ranges with ~ characters.    for (SmallVectorImpl<CharSourceRange>::iterator I = Ranges.begin(),                                                    E = Ranges.end(); | 
