2008-12-02 12:01:29 +01:00
|
|
|
/***************************************************************************
|
|
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2009-01-13 19:21:51 +01:00
|
|
|
** Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** Contact: Qt Software Information (qt-info@nokia.com)
|
|
|
|
|
**
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
|
|
|
|
** Non-Open Source Usage
|
|
|
|
|
**
|
2008-12-02 12:01:29 +01:00
|
|
|
** Licensees may use this file in accordance with the Qt Beta Version
|
|
|
|
|
** License Agreement, Agreement version 2.2 provided with the Software or,
|
|
|
|
|
** alternatively, in accordance with the terms contained in a written
|
2008-12-02 14:17:16 +01:00
|
|
|
** agreement between you and Nokia.
|
|
|
|
|
**
|
|
|
|
|
** GNU General Public License Usage
|
|
|
|
|
**
|
2008-12-02 12:01:29 +01:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU General
|
|
|
|
|
** Public License versions 2.0 or 3.0 as published by the Free Software
|
|
|
|
|
** Foundation and appearing in the file LICENSE.GPL included in the packaging
|
|
|
|
|
** of this file. Please review the following information to ensure GNU
|
|
|
|
|
** General Public Licensing requirements will be met:
|
|
|
|
|
**
|
|
|
|
|
** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
|
|
|
|
|
** http://www.gnu.org/copyleft/gpl.html.
|
|
|
|
|
**
|
|
|
|
|
** In addition, as a special exception, Nokia gives you certain additional
|
2008-12-02 14:17:16 +01:00
|
|
|
** rights. These rights are described in the Nokia Qt GPL Exception
|
2008-12-16 17:20:00 +01:00
|
|
|
** version 1.3, included in the file GPL_EXCEPTION.txt in this package.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
|
|
|
|
***************************************************************************/
|
2008-12-02 12:57:59 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef INDENTER_H
|
|
|
|
|
#define INDENTER_H
|
|
|
|
|
|
|
|
|
|
#include <QtCore/QString>
|
|
|
|
|
#include <QtCore/QStringList>
|
|
|
|
|
|
|
|
|
|
namespace SharedTools {
|
|
|
|
|
namespace IndenterInternal {
|
|
|
|
|
/* String constants and regexps required by the indenter. Separate for code cleanliness*/
|
|
|
|
|
struct Constants {
|
|
|
|
|
Constants();
|
|
|
|
|
const QString m_slashAster;
|
|
|
|
|
const QString m_asterSlash;
|
|
|
|
|
const QString m_slashSlash;
|
|
|
|
|
const QString m_else;
|
|
|
|
|
const QString m_qobject;
|
|
|
|
|
const QString m_operators;
|
|
|
|
|
const QString m_bracesSemicolon;
|
|
|
|
|
const QString m_3dots;
|
|
|
|
|
|
|
|
|
|
QRegExp m_literal;
|
|
|
|
|
QRegExp m_label;
|
|
|
|
|
QRegExp m_inlineCComment;
|
|
|
|
|
QRegExp m_braceX;
|
|
|
|
|
QRegExp m_iflikeKeyword;
|
|
|
|
|
QRegExp m_caseLabel;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* The "linizer" is a group of functions and variables to iterate
|
|
|
|
|
* through the source code of the program to indent. The program is
|
|
|
|
|
* given as a list of strings, with the bottom line being the line to
|
|
|
|
|
* indent. The actual program might contain extra lines, but those are
|
|
|
|
|
* uninteresting and not passed over to us. */
|
|
|
|
|
template <class Iterator>
|
|
|
|
|
struct LinizerState {
|
|
|
|
|
|
|
|
|
|
QString line;
|
|
|
|
|
int braceDepth;
|
|
|
|
|
bool leftBraceFollows;
|
|
|
|
|
|
|
|
|
|
Iterator iter;
|
|
|
|
|
bool inCComment;
|
|
|
|
|
bool pendingRightBrace;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Indenter singleton as a template of a bidirectional input iterator
|
|
|
|
|
* of a sequence of code lines represented as QString.
|
|
|
|
|
* When setting the parameters, be careful to
|
|
|
|
|
* specify the correct template parameters (best use a typedef). */
|
|
|
|
|
template <class Iterator>
|
|
|
|
|
class Indenter {
|
|
|
|
|
Indenter(const Indenter&);
|
|
|
|
|
Indenter &operator=(const Indenter&);
|
|
|
|
|
Indenter();
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
~Indenter();
|
|
|
|
|
|
|
|
|
|
static Indenter &instance();
|
|
|
|
|
|
|
|
|
|
void setIndentSize(int size);
|
|
|
|
|
void setTabSize(int size );
|
|
|
|
|
|
|
|
|
|
/* Return indentation for the last line of the sequence
|
|
|
|
|
* based on the previous lines. */
|
|
|
|
|
int indentForBottomLine(const Iterator ¤t,
|
|
|
|
|
const Iterator &programBegin,
|
|
|
|
|
const Iterator &programEnd,
|
|
|
|
|
QChar typedIn);
|
|
|
|
|
|
|
|
|
|
// Helpers.
|
|
|
|
|
static bool isOnlyWhiteSpace( const QString& t);
|
|
|
|
|
static QChar firstNonWhiteSpace( const QString& t );
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
int columnForIndex( const QString& t, int index ) const;
|
|
|
|
|
int indentOfLine( const QString& t ) const;
|
|
|
|
|
QString trimmedCodeLine( const QString& t );
|
|
|
|
|
bool readLine();
|
|
|
|
|
void startLinizer();
|
|
|
|
|
bool bottomLineStartsInCComment();
|
|
|
|
|
int indentWhenBottomLineStartsInCComment() const;
|
|
|
|
|
bool matchBracelessControlStatement();
|
|
|
|
|
bool isUnfinishedLine();
|
|
|
|
|
bool isContinuationLine();
|
|
|
|
|
int indentForContinuationLine();
|
|
|
|
|
int indentForStandaloneLine();
|
|
|
|
|
|
|
|
|
|
IndenterInternal::Constants m_constants;
|
|
|
|
|
int ppHardwareTabSize;
|
|
|
|
|
int ppIndentSize;
|
|
|
|
|
int ppContinuationIndentSize;
|
|
|
|
|
|
|
|
|
|
Iterator yyProgramBegin;
|
|
|
|
|
Iterator yyProgramEnd;
|
|
|
|
|
|
|
|
|
|
typedef typename IndenterInternal::LinizerState<Iterator> LinizerState;
|
|
|
|
|
|
|
|
|
|
LinizerState *yyLinizerState ;
|
|
|
|
|
|
|
|
|
|
// shorthands
|
|
|
|
|
const QString *yyLine;
|
|
|
|
|
const int *yyBraceDepth;
|
|
|
|
|
const bool *yyLeftBraceFollows;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#include "indenter_impl.h"
|
|
|
|
|
|
2008-12-02 12:57:59 +01:00
|
|
|
#endif // INDENTER_H
|