forked from qt-creator/qt-creator
Merge remote-tracking branch 'origin/3.3'
Conflicts: src/plugins/debugger/watchhandler.cpp src/plugins/projectexplorer/kitmodel.cpp src/plugins/qbsprojectmanager/qbsprojectmanager.cpp src/shared/qbs Change-Id: I6a68090993a264e93ac7850858cc24ba6bdb5602
This commit is contained in:
@@ -140,6 +140,12 @@ static bool isQtReservedWord(const char *name, int size)
|
||||
return false;
|
||||
}
|
||||
|
||||
static void nestingTooDeep()
|
||||
{
|
||||
#ifndef NO_DEBUG
|
||||
std::cerr << "*** WARNING #if / #ifdef nesting exceeded the max level " << MAX_LEVEL << std::endl;
|
||||
#endif
|
||||
}
|
||||
|
||||
} // anonymous namespace
|
||||
|
||||
@@ -1824,6 +1830,12 @@ void Preprocessor::handleIfDirective(PPToken *tk)
|
||||
lex(tk); // consume "if" token
|
||||
Value result;
|
||||
const PPToken lastExpressionToken = evalExpression(tk, result);
|
||||
|
||||
if (m_state.m_ifLevel >= MAX_LEVEL - 1) {
|
||||
nestingTooDeep();
|
||||
return;
|
||||
}
|
||||
|
||||
const bool value = !result.is_zero();
|
||||
|
||||
const bool wasSkipping = m_state.m_skipping[m_state.m_ifLevel];
|
||||
@@ -1950,12 +1962,17 @@ void Preprocessor::handleIfDefDirective(bool checkUndefined, PPToken *tk)
|
||||
value = !value;
|
||||
|
||||
const bool wasSkipping = m_state.m_skipping[m_state.m_ifLevel];
|
||||
++m_state.m_ifLevel;
|
||||
m_state.m_trueTest[m_state.m_ifLevel] = value;
|
||||
m_state.m_skipping[m_state.m_ifLevel] = wasSkipping ? wasSkipping : !value;
|
||||
|
||||
if (m_client && !wasSkipping && !value)
|
||||
startSkippingBlocks(*tk);
|
||||
if (m_state.m_ifLevel < MAX_LEVEL - 1) {
|
||||
++m_state.m_ifLevel;
|
||||
m_state.m_trueTest[m_state.m_ifLevel] = value;
|
||||
m_state.m_skipping[m_state.m_ifLevel] = wasSkipping ? wasSkipping : !value;
|
||||
|
||||
if (m_client && !wasSkipping && !value)
|
||||
startSkippingBlocks(*tk);
|
||||
} else {
|
||||
nestingTooDeep();
|
||||
}
|
||||
|
||||
lex(tk); // consume the identifier
|
||||
#ifndef NO_DEBUG
|
||||
|
||||
Reference in New Issue
Block a user