annotate examples/widgets/calculator/calculator.d @ 211:7ea67ec3cf29

another fixes in examples
author SokoL_SD
date Tue, 14 Jul 2009 12:50:04 +0000
parents 3ea0efe4d31e
children 8aaa84d48451
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
e78566595089 initial import
mandel
parents:
diff changeset
1 /****************************************************************************
e78566595089 initial import
mandel
parents:
diff changeset
2 **
e78566595089 initial import
mandel
parents:
diff changeset
3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
e78566595089 initial import
mandel
parents:
diff changeset
4 ** Contact: Qt Software Information (qt-info@nokia.com)
e78566595089 initial import
mandel
parents:
diff changeset
5 **
e78566595089 initial import
mandel
parents:
diff changeset
6 ** This file is part of the example classes of the Qt Toolkit.
e78566595089 initial import
mandel
parents:
diff changeset
7 **
e78566595089 initial import
mandel
parents:
diff changeset
8 ** $QT_BEGIN_LICENSE:LGPL$
e78566595089 initial import
mandel
parents:
diff changeset
9 ** Commercial Usage
e78566595089 initial import
mandel
parents:
diff changeset
10 ** Licensees holding valid Qt Commercial licenses may use this file in
e78566595089 initial import
mandel
parents:
diff changeset
11 ** accordance with the Qt Commercial License Agreement provided with the
e78566595089 initial import
mandel
parents:
diff changeset
12 ** Software or, alternatively, in accordance with the terms contained in
e78566595089 initial import
mandel
parents:
diff changeset
13 ** a written agreement between you and Nokia.
e78566595089 initial import
mandel
parents:
diff changeset
14 **
e78566595089 initial import
mandel
parents:
diff changeset
15 ** GNU Lesser General Public License Usage
e78566595089 initial import
mandel
parents:
diff changeset
16 ** Alternatively, this file may be used under the terms of the GNU Lesser
e78566595089 initial import
mandel
parents:
diff changeset
17 ** General Public License version 2.1 as published by the Free Software
e78566595089 initial import
mandel
parents:
diff changeset
18 ** Foundation and appearing in the file LICENSE.LGPL included in the
e78566595089 initial import
mandel
parents:
diff changeset
19 ** packaging of this file. Please review the following information to
e78566595089 initial import
mandel
parents:
diff changeset
20 ** ensure the GNU Lesser General Public License version 2.1 requirements
e78566595089 initial import
mandel
parents:
diff changeset
21 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
e78566595089 initial import
mandel
parents:
diff changeset
22 **
e78566595089 initial import
mandel
parents:
diff changeset
23 ** In addition, as a special exception, Nokia gives you certain
e78566595089 initial import
mandel
parents:
diff changeset
24 ** additional rights. These rights are described in the Nokia Qt LGPL
e78566595089 initial import
mandel
parents:
diff changeset
25 ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
e78566595089 initial import
mandel
parents:
diff changeset
26 ** package.
e78566595089 initial import
mandel
parents:
diff changeset
27 **
e78566595089 initial import
mandel
parents:
diff changeset
28 ** GNU General Public License Usage
e78566595089 initial import
mandel
parents:
diff changeset
29 ** Alternatively, this file may be used under the terms of the GNU
e78566595089 initial import
mandel
parents:
diff changeset
30 ** General Public License version 3.0 as published by the Free Software
e78566595089 initial import
mandel
parents:
diff changeset
31 ** Foundation and appearing in the file LICENSE.GPL included in the
e78566595089 initial import
mandel
parents:
diff changeset
32 ** packaging of this file. Please review the following information to
e78566595089 initial import
mandel
parents:
diff changeset
33 ** ensure the GNU General Public License version 3.0 requirements will be
e78566595089 initial import
mandel
parents:
diff changeset
34 ** met: http://www.gnu.org/copyleft/gpl.html.
e78566595089 initial import
mandel
parents:
diff changeset
35 **
e78566595089 initial import
mandel
parents:
diff changeset
36 ** If you are unsure which license is appropriate for your use, please
e78566595089 initial import
mandel
parents:
diff changeset
37 ** contact the sales department at qt-sales@nokia.com.
e78566595089 initial import
mandel
parents:
diff changeset
38 ** $QT_END_LICENSE$
e78566595089 initial import
mandel
parents:
diff changeset
39 **
e78566595089 initial import
mandel
parents:
diff changeset
40 ****************************************************************************/
e78566595089 initial import
mandel
parents:
diff changeset
41
e78566595089 initial import
mandel
parents:
diff changeset
42 module calculator;
e78566595089 initial import
mandel
parents:
diff changeset
43
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
44 import button;
1
e78566595089 initial import
mandel
parents:
diff changeset
45 import qt.gui.QDialog;
e78566595089 initial import
mandel
parents:
diff changeset
46 import qt.gui.QGridLayout;
e78566595089 initial import
mandel
parents:
diff changeset
47 import qt.gui.QLineEdit;
e78566595089 initial import
mandel
parents:
diff changeset
48 import qt.gui.QFont;
e78566595089 initial import
mandel
parents:
diff changeset
49
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
50 version(Tango)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
51 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
52 import tango.math.Math;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
53 import tango.math.Math : pow, sqrt;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
54 import Float = tango.text.convert.Float;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
55 import Integer = tango.text.convert.Integer;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
56 import tango.core.Array;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
57 string ToString(int x)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
58 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
59 return Integer.toString(x);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
60 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
61 string ToString(double x, int c = 0)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
62 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
63 return Float.toString(x, c);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
64 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
65 int ToInt(string s)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
66 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
67 return Integer.toInt(s);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
68 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
69 float ToFloat(string s)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
70 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
71 return Float.toFloat(s);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
72 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
73 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
74 else
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
75 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
76 import std.math;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
77 import std.conv;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
78 import std.string;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
79 string ToString(int x)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
80 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
81 return std.string.format("%d", x);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
82 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
83 string ToString(double x, int c = 0)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
84 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
85 return std.string.format("%g", x);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
86 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
87 int ToInt(string s)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
88 {
211
7ea67ec3cf29 another fixes in examples
SokoL_SD
parents: 210
diff changeset
89 return to!(int)(s);
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
90 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
91 float ToFloat(string s)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
92 {
211
7ea67ec3cf29 another fixes in examples
SokoL_SD
parents: 210
diff changeset
93 return to!(float)(s);
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
94 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
95 int find(string s, dchar c)
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
96 {
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
97 return indexOf(s,c);
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
98 }
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
99 }
1
e78566595089 initial import
mandel
parents:
diff changeset
100
e78566595089 initial import
mandel
parents:
diff changeset
101 class Calculator : public QDialog
e78566595089 initial import
mandel
parents:
diff changeset
102 {
e78566595089 initial import
mandel
parents:
diff changeset
103
e78566595089 initial import
mandel
parents:
diff changeset
104 public:
e78566595089 initial import
mandel
parents:
diff changeset
105
e78566595089 initial import
mandel
parents:
diff changeset
106 this(QWidget parent = null)
e78566595089 initial import
mandel
parents:
diff changeset
107 {
e78566595089 initial import
mandel
parents:
diff changeset
108 super(parent);
e78566595089 initial import
mandel
parents:
diff changeset
109
e78566595089 initial import
mandel
parents:
diff changeset
110 sumInMemory = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
111 sumSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
112 factorSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
113 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
114
e78566595089 initial import
mandel
parents:
diff changeset
115 display = new QLineEdit("0");
e78566595089 initial import
mandel
parents:
diff changeset
116 display.setReadOnly(true);
e78566595089 initial import
mandel
parents:
diff changeset
117 display.setAlignment(Qt.AlignRight);
e78566595089 initial import
mandel
parents:
diff changeset
118 display.setMaxLength(15);
e78566595089 initial import
mandel
parents:
diff changeset
119
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
120 auto font = new QFont(display.font());
1
e78566595089 initial import
mandel
parents:
diff changeset
121 font.setPointSize(font.pointSize() + 8);
e78566595089 initial import
mandel
parents:
diff changeset
122 display.setFont(font);
e78566595089 initial import
mandel
parents:
diff changeset
123
e78566595089 initial import
mandel
parents:
diff changeset
124 for (int i = 0; i < NumDigitButtons; ++i) {
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
125 digitButtons[i] = createButton(ToString(i), &digitClicked);
1
e78566595089 initial import
mandel
parents:
diff changeset
126 }
e78566595089 initial import
mandel
parents:
diff changeset
127
e78566595089 initial import
mandel
parents:
diff changeset
128 Button pointButton = createButton(tr("."), &pointClicked);
e78566595089 initial import
mandel
parents:
diff changeset
129 Button changeSignButton = createButton(tr("+/-"), &changeSignClicked);
e78566595089 initial import
mandel
parents:
diff changeset
130
e78566595089 initial import
mandel
parents:
diff changeset
131 Button backspaceButton = createButton(tr("Backspace"), &backspaceClicked);
e78566595089 initial import
mandel
parents:
diff changeset
132 Button clearButton = createButton(tr("Clear"), &clear);
e78566595089 initial import
mandel
parents:
diff changeset
133 Button clearAllButton = createButton(tr("Clear All"), &clearAll);
e78566595089 initial import
mandel
parents:
diff changeset
134
e78566595089 initial import
mandel
parents:
diff changeset
135 Button clearMemoryButton = createButton(tr("MC"), &clearMemory);
e78566595089 initial import
mandel
parents:
diff changeset
136 Button readMemoryButton = createButton(tr("MR"), &readMemory);
e78566595089 initial import
mandel
parents:
diff changeset
137 Button setMemoryButton = createButton(tr("MS"), &setMemory);
e78566595089 initial import
mandel
parents:
diff changeset
138 Button addToMemoryButton = createButton(tr("M+"), &addToMemory);
e78566595089 initial import
mandel
parents:
diff changeset
139
e78566595089 initial import
mandel
parents:
diff changeset
140 Button divisionButton = createButton(tr("/"), &multiplicativeOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
141 Button timesButton = createButton(tr("*"), &multiplicativeOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
142 Button minusButton = createButton(tr("-"), &additiveOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
143 Button plusButton = createButton(tr("+"), &additiveOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
144
e78566595089 initial import
mandel
parents:
diff changeset
145 Button squareRootButton = createButton(tr("Sqrt"), &unaryOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
146 Button powerButton = createButton(tr("x^2"), &unaryOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
147 Button reciprocalButton = createButton(tr("1/x"), &unaryOperatorClicked);
e78566595089 initial import
mandel
parents:
diff changeset
148 Button equalButton = createButton(tr("="), &equalClicked);
e78566595089 initial import
mandel
parents:
diff changeset
149
e78566595089 initial import
mandel
parents:
diff changeset
150 QGridLayout mainLayout = new QGridLayout();
e78566595089 initial import
mandel
parents:
diff changeset
151
e78566595089 initial import
mandel
parents:
diff changeset
152 mainLayout.setSizeConstraint(QLayout.SetFixedSize);
e78566595089 initial import
mandel
parents:
diff changeset
153
e78566595089 initial import
mandel
parents:
diff changeset
154 mainLayout.addWidget(display, 0, 0, 1, 6);
e78566595089 initial import
mandel
parents:
diff changeset
155 mainLayout.addWidget(backspaceButton, 1, 0, 1, 2);
e78566595089 initial import
mandel
parents:
diff changeset
156 mainLayout.addWidget(clearButton, 1, 2, 1, 2);
e78566595089 initial import
mandel
parents:
diff changeset
157 mainLayout.addWidget(clearAllButton, 1, 4, 1, 2);
e78566595089 initial import
mandel
parents:
diff changeset
158
e78566595089 initial import
mandel
parents:
diff changeset
159 mainLayout.addWidget(clearMemoryButton, 2, 0);
e78566595089 initial import
mandel
parents:
diff changeset
160 mainLayout.addWidget(readMemoryButton, 3, 0);
e78566595089 initial import
mandel
parents:
diff changeset
161 mainLayout.addWidget(setMemoryButton, 4, 0);
e78566595089 initial import
mandel
parents:
diff changeset
162 mainLayout.addWidget(addToMemoryButton, 5, 0);
e78566595089 initial import
mandel
parents:
diff changeset
163
e78566595089 initial import
mandel
parents:
diff changeset
164 for (int i = 1; i < NumDigitButtons; ++i) {
e78566595089 initial import
mandel
parents:
diff changeset
165 int row = ((9 - i) / 3) + 2;
e78566595089 initial import
mandel
parents:
diff changeset
166 int column = ((i - 1) % 3) + 1;
e78566595089 initial import
mandel
parents:
diff changeset
167 mainLayout.addWidget(digitButtons[i], row, column);
e78566595089 initial import
mandel
parents:
diff changeset
168 }
e78566595089 initial import
mandel
parents:
diff changeset
169
e78566595089 initial import
mandel
parents:
diff changeset
170 mainLayout.addWidget(digitButtons[0], 5, 1);
e78566595089 initial import
mandel
parents:
diff changeset
171 mainLayout.addWidget(pointButton, 5, 2);
e78566595089 initial import
mandel
parents:
diff changeset
172 mainLayout.addWidget(changeSignButton, 5, 3);
e78566595089 initial import
mandel
parents:
diff changeset
173
e78566595089 initial import
mandel
parents:
diff changeset
174 mainLayout.addWidget(divisionButton, 2, 4);
e78566595089 initial import
mandel
parents:
diff changeset
175 mainLayout.addWidget(timesButton, 3, 4);
e78566595089 initial import
mandel
parents:
diff changeset
176 mainLayout.addWidget(minusButton, 4, 4);
e78566595089 initial import
mandel
parents:
diff changeset
177 mainLayout.addWidget(plusButton, 5, 4);
e78566595089 initial import
mandel
parents:
diff changeset
178
e78566595089 initial import
mandel
parents:
diff changeset
179 mainLayout.addWidget(squareRootButton, 2, 5);
e78566595089 initial import
mandel
parents:
diff changeset
180 mainLayout.addWidget(powerButton, 3, 5);
e78566595089 initial import
mandel
parents:
diff changeset
181 mainLayout.addWidget(reciprocalButton, 4, 5);
e78566595089 initial import
mandel
parents:
diff changeset
182 mainLayout.addWidget(equalButton, 5, 5);
e78566595089 initial import
mandel
parents:
diff changeset
183 setLayout(mainLayout);
e78566595089 initial import
mandel
parents:
diff changeset
184
e78566595089 initial import
mandel
parents:
diff changeset
185 setWindowTitle(tr("Calculator"));
e78566595089 initial import
mandel
parents:
diff changeset
186 }
e78566595089 initial import
mandel
parents:
diff changeset
187
e78566595089 initial import
mandel
parents:
diff changeset
188 //private slots:
e78566595089 initial import
mandel
parents:
diff changeset
189 void digitClicked()
e78566595089 initial import
mandel
parents:
diff changeset
190 {
e78566595089 initial import
mandel
parents:
diff changeset
191 Button clickedButton = cast(Button) signalSender();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
192 int digitValue = ToInt(clickedButton.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
193 if (display.text() == "0" && digitValue == 0.0)
e78566595089 initial import
mandel
parents:
diff changeset
194 return;
e78566595089 initial import
mandel
parents:
diff changeset
195
e78566595089 initial import
mandel
parents:
diff changeset
196 if (waitingForOperand) {
e78566595089 initial import
mandel
parents:
diff changeset
197 display.clear();
e78566595089 initial import
mandel
parents:
diff changeset
198 waitingForOperand = false;
e78566595089 initial import
mandel
parents:
diff changeset
199 }
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
200 display.setText(display.text() ~ ToString(digitValue));
1
e78566595089 initial import
mandel
parents:
diff changeset
201 }
e78566595089 initial import
mandel
parents:
diff changeset
202
e78566595089 initial import
mandel
parents:
diff changeset
203 void unaryOperatorClicked()
e78566595089 initial import
mandel
parents:
diff changeset
204 {
e78566595089 initial import
mandel
parents:
diff changeset
205 Button clickedButton = cast(Button) signalSender();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
206 string clickedOperator = clickedButton.text();
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
207 double operand = ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
208 double result = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
209
e78566595089 initial import
mandel
parents:
diff changeset
210 if (clickedOperator == tr("Sqrt")) {
e78566595089 initial import
mandel
parents:
diff changeset
211 if (operand < 0.0) {
e78566595089 initial import
mandel
parents:
diff changeset
212 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
213 return;
e78566595089 initial import
mandel
parents:
diff changeset
214 }
e78566595089 initial import
mandel
parents:
diff changeset
215 result = sqrt(operand);
e78566595089 initial import
mandel
parents:
diff changeset
216 } else if (clickedOperator == tr("x^2")) {
e78566595089 initial import
mandel
parents:
diff changeset
217 result = pow(operand, 2.0);
e78566595089 initial import
mandel
parents:
diff changeset
218 } else if (clickedOperator == tr("1/x")) {
e78566595089 initial import
mandel
parents:
diff changeset
219 if (operand == 0.0) {
e78566595089 initial import
mandel
parents:
diff changeset
220 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
221 return;
e78566595089 initial import
mandel
parents:
diff changeset
222 }
e78566595089 initial import
mandel
parents:
diff changeset
223 result = 1.0 / operand;
e78566595089 initial import
mandel
parents:
diff changeset
224 }
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
225 display.setText(ToString(result, 4));
1
e78566595089 initial import
mandel
parents:
diff changeset
226 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
227 }
e78566595089 initial import
mandel
parents:
diff changeset
228
e78566595089 initial import
mandel
parents:
diff changeset
229 void additiveOperatorClicked()
e78566595089 initial import
mandel
parents:
diff changeset
230 {
e78566595089 initial import
mandel
parents:
diff changeset
231 Button clickedButton = cast(Button) signalSender();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
232 string clickedOperator = clickedButton.text();
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
233 double operand = ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
234
e78566595089 initial import
mandel
parents:
diff changeset
235 if (pendingMultiplicativeOperator.length) {
e78566595089 initial import
mandel
parents:
diff changeset
236 if (!calculate(operand, pendingMultiplicativeOperator)) {
e78566595089 initial import
mandel
parents:
diff changeset
237 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
238 return;
e78566595089 initial import
mandel
parents:
diff changeset
239 }
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
240 display.setText(ToString(factorSoFar, 4));
1
e78566595089 initial import
mandel
parents:
diff changeset
241 operand = factorSoFar;
e78566595089 initial import
mandel
parents:
diff changeset
242 factorSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
243 pendingMultiplicativeOperator = null;
e78566595089 initial import
mandel
parents:
diff changeset
244 }
e78566595089 initial import
mandel
parents:
diff changeset
245
e78566595089 initial import
mandel
parents:
diff changeset
246 if (pendingAdditiveOperator.length) {
e78566595089 initial import
mandel
parents:
diff changeset
247 if (!calculate(operand, pendingAdditiveOperator)) {
e78566595089 initial import
mandel
parents:
diff changeset
248 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
249 return;
e78566595089 initial import
mandel
parents:
diff changeset
250 }
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
251 display.setText(ToString(sumSoFar, 4));
1
e78566595089 initial import
mandel
parents:
diff changeset
252 } else {
e78566595089 initial import
mandel
parents:
diff changeset
253 sumSoFar = operand;
e78566595089 initial import
mandel
parents:
diff changeset
254 }
e78566595089 initial import
mandel
parents:
diff changeset
255
e78566595089 initial import
mandel
parents:
diff changeset
256 pendingAdditiveOperator = clickedOperator;
e78566595089 initial import
mandel
parents:
diff changeset
257 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
258 }
e78566595089 initial import
mandel
parents:
diff changeset
259
e78566595089 initial import
mandel
parents:
diff changeset
260 void multiplicativeOperatorClicked()
e78566595089 initial import
mandel
parents:
diff changeset
261 {
e78566595089 initial import
mandel
parents:
diff changeset
262 Button clickedButton = cast(Button) signalSender();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
263 string clickedOperator = clickedButton.text();
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
264 double operand = ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
265
e78566595089 initial import
mandel
parents:
diff changeset
266 if (pendingMultiplicativeOperator.length) {
e78566595089 initial import
mandel
parents:
diff changeset
267 if (!calculate(operand, pendingMultiplicativeOperator)) {
e78566595089 initial import
mandel
parents:
diff changeset
268 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
269 return;
e78566595089 initial import
mandel
parents:
diff changeset
270 }
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
271 display.setText(ToString(factorSoFar/*, 4*/));
1
e78566595089 initial import
mandel
parents:
diff changeset
272 } else {
e78566595089 initial import
mandel
parents:
diff changeset
273 factorSoFar = operand;
e78566595089 initial import
mandel
parents:
diff changeset
274 }
e78566595089 initial import
mandel
parents:
diff changeset
275
e78566595089 initial import
mandel
parents:
diff changeset
276 pendingMultiplicativeOperator = clickedOperator;
e78566595089 initial import
mandel
parents:
diff changeset
277 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
278 }
e78566595089 initial import
mandel
parents:
diff changeset
279
e78566595089 initial import
mandel
parents:
diff changeset
280 void equalClicked()
e78566595089 initial import
mandel
parents:
diff changeset
281 {
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
282 double operand = ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
283
e78566595089 initial import
mandel
parents:
diff changeset
284 if (pendingMultiplicativeOperator.length) {
e78566595089 initial import
mandel
parents:
diff changeset
285 if (!calculate(operand, pendingMultiplicativeOperator)) {
e78566595089 initial import
mandel
parents:
diff changeset
286 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
287 return;
e78566595089 initial import
mandel
parents:
diff changeset
288 }
e78566595089 initial import
mandel
parents:
diff changeset
289 operand = factorSoFar;
e78566595089 initial import
mandel
parents:
diff changeset
290 factorSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
291 pendingMultiplicativeOperator = null;
e78566595089 initial import
mandel
parents:
diff changeset
292 }
e78566595089 initial import
mandel
parents:
diff changeset
293 if (pendingAdditiveOperator.length) {
e78566595089 initial import
mandel
parents:
diff changeset
294 if (!calculate(operand, pendingAdditiveOperator)) {
e78566595089 initial import
mandel
parents:
diff changeset
295 abortOperation();
e78566595089 initial import
mandel
parents:
diff changeset
296 return;
e78566595089 initial import
mandel
parents:
diff changeset
297 }
e78566595089 initial import
mandel
parents:
diff changeset
298 pendingAdditiveOperator = null;
e78566595089 initial import
mandel
parents:
diff changeset
299 } else {
e78566595089 initial import
mandel
parents:
diff changeset
300 sumSoFar = operand;
e78566595089 initial import
mandel
parents:
diff changeset
301 }
e78566595089 initial import
mandel
parents:
diff changeset
302
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
303 display.setText(ToString(sumSoFar, 4));
1
e78566595089 initial import
mandel
parents:
diff changeset
304 sumSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
305 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
306 }
e78566595089 initial import
mandel
parents:
diff changeset
307
e78566595089 initial import
mandel
parents:
diff changeset
308 void pointClicked()
e78566595089 initial import
mandel
parents:
diff changeset
309 {
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
310 string text = display.text;
1
e78566595089 initial import
mandel
parents:
diff changeset
311
e78566595089 initial import
mandel
parents:
diff changeset
312 if (waitingForOperand)
e78566595089 initial import
mandel
parents:
diff changeset
313 display.setText("0");
e78566595089 initial import
mandel
parents:
diff changeset
314
e78566595089 initial import
mandel
parents:
diff changeset
315 if (find(text, '.') >= text.length)
e78566595089 initial import
mandel
parents:
diff changeset
316 display.setText(text ~ tr("."));
e78566595089 initial import
mandel
parents:
diff changeset
317
e78566595089 initial import
mandel
parents:
diff changeset
318 waitingForOperand = false;
e78566595089 initial import
mandel
parents:
diff changeset
319 }
e78566595089 initial import
mandel
parents:
diff changeset
320
e78566595089 initial import
mandel
parents:
diff changeset
321 void changeSignClicked()
e78566595089 initial import
mandel
parents:
diff changeset
322 {
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
323 string text = display.text();
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
324 double value = ToFloat(text);
1
e78566595089 initial import
mandel
parents:
diff changeset
325
e78566595089 initial import
mandel
parents:
diff changeset
326 if (value > 0.0) {
e78566595089 initial import
mandel
parents:
diff changeset
327 text = "-" ~ text;
e78566595089 initial import
mandel
parents:
diff changeset
328 } else if (value < 0.0) {
e78566595089 initial import
mandel
parents:
diff changeset
329 text = text[1..$];
e78566595089 initial import
mandel
parents:
diff changeset
330 }
e78566595089 initial import
mandel
parents:
diff changeset
331 display.setText(text);
e78566595089 initial import
mandel
parents:
diff changeset
332 }
e78566595089 initial import
mandel
parents:
diff changeset
333
e78566595089 initial import
mandel
parents:
diff changeset
334 void backspaceClicked()
e78566595089 initial import
mandel
parents:
diff changeset
335 {
e78566595089 initial import
mandel
parents:
diff changeset
336 if (waitingForOperand)
e78566595089 initial import
mandel
parents:
diff changeset
337 return;
e78566595089 initial import
mandel
parents:
diff changeset
338
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
339 string text = display.text();
1
e78566595089 initial import
mandel
parents:
diff changeset
340 text = text[0..$-1];
e78566595089 initial import
mandel
parents:
diff changeset
341 if (text.length == 0) {
e78566595089 initial import
mandel
parents:
diff changeset
342 text = "0";
e78566595089 initial import
mandel
parents:
diff changeset
343 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
344 }
e78566595089 initial import
mandel
parents:
diff changeset
345 display.setText(text);
e78566595089 initial import
mandel
parents:
diff changeset
346 }
e78566595089 initial import
mandel
parents:
diff changeset
347
e78566595089 initial import
mandel
parents:
diff changeset
348
e78566595089 initial import
mandel
parents:
diff changeset
349 void clear()
e78566595089 initial import
mandel
parents:
diff changeset
350 {
e78566595089 initial import
mandel
parents:
diff changeset
351 if (waitingForOperand)
e78566595089 initial import
mandel
parents:
diff changeset
352 return;
e78566595089 initial import
mandel
parents:
diff changeset
353
e78566595089 initial import
mandel
parents:
diff changeset
354 display.setText("0");
e78566595089 initial import
mandel
parents:
diff changeset
355 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
356 }
e78566595089 initial import
mandel
parents:
diff changeset
357
e78566595089 initial import
mandel
parents:
diff changeset
358 void clearAll()
e78566595089 initial import
mandel
parents:
diff changeset
359 {
e78566595089 initial import
mandel
parents:
diff changeset
360 sumSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
361 factorSoFar = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
362 pendingAdditiveOperator = null;
e78566595089 initial import
mandel
parents:
diff changeset
363 pendingMultiplicativeOperator = null;
e78566595089 initial import
mandel
parents:
diff changeset
364 display.setText("0");
e78566595089 initial import
mandel
parents:
diff changeset
365 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
366 }
e78566595089 initial import
mandel
parents:
diff changeset
367
e78566595089 initial import
mandel
parents:
diff changeset
368 void clearMemory()
e78566595089 initial import
mandel
parents:
diff changeset
369 {
e78566595089 initial import
mandel
parents:
diff changeset
370 sumInMemory = 0.0;
e78566595089 initial import
mandel
parents:
diff changeset
371 }
e78566595089 initial import
mandel
parents:
diff changeset
372
e78566595089 initial import
mandel
parents:
diff changeset
373 void readMemory()
e78566595089 initial import
mandel
parents:
diff changeset
374 {
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
375 display.setText(ToString(sumInMemory, 4));
1
e78566595089 initial import
mandel
parents:
diff changeset
376 waitingForOperand = true;
e78566595089 initial import
mandel
parents:
diff changeset
377 }
e78566595089 initial import
mandel
parents:
diff changeset
378
e78566595089 initial import
mandel
parents:
diff changeset
379 void setMemory()
e78566595089 initial import
mandel
parents:
diff changeset
380 {
e78566595089 initial import
mandel
parents:
diff changeset
381 equalClicked();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
382 sumInMemory = ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
383 }
e78566595089 initial import
mandel
parents:
diff changeset
384
e78566595089 initial import
mandel
parents:
diff changeset
385 void addToMemory()
e78566595089 initial import
mandel
parents:
diff changeset
386 {
e78566595089 initial import
mandel
parents:
diff changeset
387 equalClicked();
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
388 sumInMemory += ToFloat(display.text);
1
e78566595089 initial import
mandel
parents:
diff changeset
389 }
e78566595089 initial import
mandel
parents:
diff changeset
390
e78566595089 initial import
mandel
parents:
diff changeset
391 private:
e78566595089 initial import
mandel
parents:
diff changeset
392
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
393 Button createButton(string text, void delegate() member)
1
e78566595089 initial import
mandel
parents:
diff changeset
394 {
e78566595089 initial import
mandel
parents:
diff changeset
395 Button button = new Button(text);
e78566595089 initial import
mandel
parents:
diff changeset
396 button.clicked.connect(member);
e78566595089 initial import
mandel
parents:
diff changeset
397 return button;
e78566595089 initial import
mandel
parents:
diff changeset
398 }
e78566595089 initial import
mandel
parents:
diff changeset
399
e78566595089 initial import
mandel
parents:
diff changeset
400 void abortOperation()
e78566595089 initial import
mandel
parents:
diff changeset
401 {
e78566595089 initial import
mandel
parents:
diff changeset
402 clearAll();
e78566595089 initial import
mandel
parents:
diff changeset
403 display.setText(tr("####"));
e78566595089 initial import
mandel
parents:
diff changeset
404 }
e78566595089 initial import
mandel
parents:
diff changeset
405
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
406 bool calculate(double rightOperand, string pendingOperator)
1
e78566595089 initial import
mandel
parents:
diff changeset
407 {
e78566595089 initial import
mandel
parents:
diff changeset
408 if (pendingOperator == tr("+")) {
e78566595089 initial import
mandel
parents:
diff changeset
409 sumSoFar += rightOperand;
e78566595089 initial import
mandel
parents:
diff changeset
410 } else if (pendingOperator == tr("-")) {
e78566595089 initial import
mandel
parents:
diff changeset
411 sumSoFar -= rightOperand;
e78566595089 initial import
mandel
parents:
diff changeset
412 } else if (pendingOperator == tr("*")) {
e78566595089 initial import
mandel
parents:
diff changeset
413 factorSoFar *= rightOperand;
e78566595089 initial import
mandel
parents:
diff changeset
414 } else if (pendingOperator == tr("/")) {
e78566595089 initial import
mandel
parents:
diff changeset
415 if (rightOperand == 0.0)
e78566595089 initial import
mandel
parents:
diff changeset
416 return false;
e78566595089 initial import
mandel
parents:
diff changeset
417 factorSoFar /= rightOperand;
e78566595089 initial import
mandel
parents:
diff changeset
418 }
e78566595089 initial import
mandel
parents:
diff changeset
419 return true;
e78566595089 initial import
mandel
parents:
diff changeset
420 }
e78566595089 initial import
mandel
parents:
diff changeset
421
e78566595089 initial import
mandel
parents:
diff changeset
422 double sumInMemory;
e78566595089 initial import
mandel
parents:
diff changeset
423 double sumSoFar;
e78566595089 initial import
mandel
parents:
diff changeset
424 double factorSoFar;
210
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
425 string pendingAdditiveOperator;
3ea0efe4d31e fixes for d2.
SokoL_SD
parents: 1
diff changeset
426 string pendingMultiplicativeOperator;
1
e78566595089 initial import
mandel
parents:
diff changeset
427 bool waitingForOperand;
e78566595089 initial import
mandel
parents:
diff changeset
428
e78566595089 initial import
mandel
parents:
diff changeset
429 QLineEdit display;
e78566595089 initial import
mandel
parents:
diff changeset
430
e78566595089 initial import
mandel
parents:
diff changeset
431 enum { NumDigitButtons = 10 };
e78566595089 initial import
mandel
parents:
diff changeset
432 Button[NumDigitButtons] digitButtons;
e78566595089 initial import
mandel
parents:
diff changeset
433 }