1 /****************************************************************************
2 **
3 ** Copyright (C) 2016 The Qt Company Ltd.
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the documentation of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:BSD$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** BSD License Usage
18 ** Alternatively, you may use this file under the terms of the BSD license
19 ** as follows:
20 **
21 ** "Redistribution and use in source and binary forms, with or without
22 ** modification, are permitted provided that the following conditions are
23 ** met:
24 **   * Redistributions of source code must retain the above copyright
25 **     notice, this list of conditions and the following disclaimer.
26 **   * Redistributions in binary form must reproduce the above copyright
27 **     notice, this list of conditions and the following disclaimer in
28 **     the documentation and/or other materials provided with the
29 **     distribution.
30 **   * Neither the name of The Qt Company Ltd nor the names of its
31 **     contributors may be used to endorse or promote products derived
32 **     from this software without specific prior written permission.
33 **
34 **
35 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
36 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
37 ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
38 ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
39 ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
42 ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
43 ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
44 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
45 ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
46 **
47 ** $QT_END_LICENSE$
48 **
49 ****************************************************************************/
50 
51 //! [0]
52 class AppendText : public QUndoCommand
53 {
54 public:
AppendText(QString * doc,const QString & text)55     AppendText(QString *doc, const QString &text)
56         : m_document(doc), m_text(text) { setText("append text"); }
undo()57     void undo() override
58         { m_document->chop(m_text.length()); }
redo()59     void redo() override
60         { m_document->append(m_text); }
61 private:
62     QString *m_document;
63     QString m_text;
64 };
65 //! [0]
66 
67 
68 //! [1]
69 MyCommand *command1 = new MyCommand();
70 stack->push(command1);
71 MyCommand *command2 = new MyCommand();
72 stack->push(command2);
73 
74 stack->undo();
75 
76 MyCommand *command3 = new MyCommand();
77 stack->push(command3); // command2 gets deleted
78 //! [1]
79 
80 
81 //! [2]
82 QUndoCommand *insertRed = new QUndoCommand(); // an empty command
83 insertRed->setText("insert red text");
84 
85 new InsertText(document, idx, text, insertRed); // becomes child of insertRed
86 new SetColor(document, idx, text.length(), Qt::red, insertRed);
87 
88 stack.push(insertRed);
89 //! [2]
90 
91 
92 //! [3]
mergeWith(const QUndoCommand * other)93 bool AppendText::mergeWith(const QUndoCommand *other)
94 {
95     if (other->id() != id()) // make sure other is also an AppendText command
96         return false;
97     m_text += static_cast<const AppendText*>(other)->m_text;
98     return true;
99 }
100 //! [3]
101 
102 
103 //! [4]
104 stack.beginMacro("insert red text");
105 stack.push(new InsertText(document, idx, text));
106 stack.push(new SetColor(document, idx, text.length(), Qt::red));
107 stack.endMacro(); // indexChanged() is emitted
108 //! [4]
109 
110 
111 //! [5]
112 QUndoCommand *insertRed = new QUndoCommand(); // an empty command
113 insertRed->setText("insert red text");
114 
115 new InsertText(document, idx, text, insertRed); // becomes child of insertRed
116 new SetColor(document, idx, text.length(), Qt::red, insertRed);
117 
118 stack.push(insertRed);
119 //! [5]
120