snippetscollection.h 4.41 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
/**************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
**
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** Commercial Usage
**
** Licensees holding valid Qt Commercial licenses may use this file in
** accordance with the Qt Commercial License Agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Nokia.
**
** GNU Lesser General Public License Usage
**
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file.  Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** If you are unsure which license is appropriate for your use, please
** contact the sales department at http://qt.nokia.com/contact.
**
**************************************************************************/

#ifndef SNIPPETSCOLLECTION_H
#define SNIPPETSCOLLECTION_H

#include "snippet.h"

#include <QtCore/QVector>
#include <QtCore/QList>

38 39
QT_FORWARD_DECLARE_CLASS(QXmlStreamWriter)

40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
namespace TextEditor {
namespace Internal {

// Characteristics of this collection:
// - Store snippets by group.
// - Keep groups of snippets sorted.
// - Allow snippet insertion/replacement based on a hint.
// - Allow modification of snippet members that are not sorting keys.
// - Track removed/modified built-in snippets.
// - Provide fast index access.
// - Not thread-safe.

class SnippetsCollection
{
public:
    SnippetsCollection();
    ~SnippetsCollection();

    class Hint
    {
        friend class SnippetsCollection;
    public:
        int index() const;
    private:
        Hint(int index);
        Hint(int index, QList<Snippet>::iterator it);
        int m_index;
        QList<Snippet>::iterator m_it;
    };

    void insertSnippet(const Snippet &snippet, Snippet::Group group);
    void insertSnippet(const Snippet &snippet, Snippet::Group group, const Hint &hint);
    Hint computeInsertionHint(const Snippet &snippet, Snippet::Group group);

    void replaceSnippet(int index, const Snippet &snippet, Snippet::Group group);
    void replaceSnippet(int index, const Snippet &snippet, Snippet::Group group, const Hint &hint);
    Hint computeReplacementHint(int index, const Snippet &snippet, Snippet::Group group);

    void removeSnippet(int index, Snippet::Group group);
Leandro Melo's avatar
Leandro Melo committed
79
    void restoreRemovedSnippets(Snippet::Group group);
80 81 82 83

    void setSnippetContent(int index, Snippet::Group group, const QString &content);

    const Snippet &snippet(int index, Snippet::Group group) const;
Leandro Melo's avatar
Leandro Melo committed
84 85 86
    Snippet revertedSnippet(int index, Snippet::Group group) const;

    void reset(Snippet::Group group);
87 88 89 90

    int totalActiveSnippets(Snippet::Group group) const;
    int totalSnippets(Snippet::Group group) const;

91 92
    void reload();
    void synchronize();
93 94

private:
95
    void clear();
Leandro Melo's avatar
Leandro Melo committed
96
    void clear(Snippet::Group group);
97 98
    void updateActiveSnippetsEnd(Snippet::Group group);

Leandro Melo's avatar
Leandro Melo committed
99
    static QList<Snippet> readXML(const QString &fileName, const QString &snippetId = QString());
100 101 102 103 104 105 106 107 108 109 110
    static void writeSnippetXML(const Snippet &snippet, QXmlStreamWriter *writer);

    static const QLatin1String kSnippet;
    static const QLatin1String kSnippets;
    static const QLatin1String kTrigger;
    static const QLatin1String kId;
    static const QLatin1String kComplement;
    static const QLatin1String kGroup;
    static const QLatin1String kRemoved;
    static const QLatin1String kModified;

Leandro Melo's avatar
Leandro Melo committed
111 112 113
    // Snippets for each group are kept in a list. However, not all of them are necessarily
    // active. Specifically, removed built-in snippets are kept as the last ones (for each
    // group there is a iterator that marks the logical end).
114 115
    QVector<QList<Snippet> > m_snippets;
    QVector<QList<Snippet>::iterator> m_activeSnippetsEnd;
116

Leandro Melo's avatar
Leandro Melo committed
117 118 119
    // Built-in snippets are specified in an XML embedded as a resource. Snippets created/
    // modified/removed by the user are stored in another XML created dynamically in the
    // user's folder.
120 121 122
    QString m_builtInSnippetsPath;
    QString m_userSnippetsPath;
    QString m_snippetsFileName;
123 124 125 126 127 128
};

} // Internal
} // TextEditor

#endif // SNIPPETSCOLLECTION_H