Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Calculator App #375

Open
wants to merge 48 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
e20eb85
Hacking around at the calculator
Raupinger Feb 23, 2021
195af10
housekeeping. Removed some leftovers from rebasing on current develop…
Raupinger May 20, 2021
70fd0db
fixed some errors in the Shunting-yard implementation
Raupinger May 22, 2021
b25baea
Added alternative operator row to calculator
Raupinger May 22, 2021
df074b8
added haptic feedback for calculator errors, improved display of floats
Raupinger May 22, 2021
b17a56e
improved calculator back button
Raupinger May 22, 2021
7bc5db4
style improvements
Raupinger May 22, 2021
b21bb9d
decreased .text size by not using std::strtod and setting #pragma GCC…
Raupinger May 23, 2021
a88b5e8
removed some leftover code that was commented out
Raupinger May 26, 2021
397a5ec
Calculator: handling errors during calculation
Jun 2, 2021
4cec9f1
Calculator: use default initializers for stacks
Jun 7, 2021
9a67d86
Calculator: fixed memory leak by using smart pointers and fixed signs
Jun 18, 2021
3635a92
Calculator: handling literals like ".5" as "0.5" and checking bounds …
Jun 18, 2021
48c3941
cleaned up after rebase
Dec 9, 2021
05adc37
added calculator icon, moved motion app to the third settings screen …
Dec 9, 2021
7e0550e
Fixed calculator bug: a+b(c) was interpreted as b+c, not a+b*c.
Dec 9, 2021
de7faa8
added calculator documentation
Dec 9, 2021
ae0782b
Calculator: increased button size
Dec 9, 2021
559aa3d
Calculator: added overflow detection and fixed crash when trying to e…
Dec 10, 2021
0090f59
Calculator: fixed compiler warnings and formatting, reduced fond diff…
Dec 10, 2021
f1fe8f4
Calculator: code cleanup
Dec 10, 2021
8532337
Calculator: code cleanup
Dec 10, 2021
3c5d799
Calculator: Removed points above overflows from doc
Raupinger Dec 16, 2021
2915dcb
Hacking around at the calculator
Raupinger Feb 23, 2021
e9765f1
housekeeping. Removed some leftovers from rebasing on current develop…
Raupinger May 20, 2021
2c78dd0
fixed some errors in the Shunting-yard implementation
Raupinger May 22, 2021
f80684c
Added alternative operator row to calculator
Raupinger May 22, 2021
cfe618f
added haptic feedback for calculator errors, improved display of floats
Raupinger May 22, 2021
aa84c0b
improved calculator back button
Raupinger May 22, 2021
69c3ec9
style improvements
Raupinger May 22, 2021
ebfa399
decreased .text size by not using std::strtod and setting #pragma GCC…
Raupinger May 23, 2021
cb7310a
removed some leftover code that was commented out
Raupinger May 26, 2021
d5871ad
Calculator: handling errors during calculation
Jun 2, 2021
2d41e4f
Calculator: use default initializers for stacks
Jun 7, 2021
0385f1e
Calculator: fixed memory leak by using smart pointers and fixed signs
Jun 18, 2021
05d8e8f
Calculator: handling literals like ".5" as "0.5" and checking bounds …
Jun 18, 2021
1d0d58f
cleaned up after rebase
Dec 9, 2021
c2f4efa
added calculator icon, moved motion app to the third settings screen …
Dec 9, 2021
839d83f
Fixed calculator bug: a+b(c) was interpreted as b+c, not a+b*c.
Dec 9, 2021
c5b7e8a
added calculator documentation
Dec 9, 2021
1045528
Calculator: increased button size
Dec 9, 2021
f2c9484
Calculator: added overflow detection and fixed crash when trying to e…
Dec 10, 2021
2a12cdd
Calculator: fixed compiler warnings and formatting, reduced fond diff…
Dec 10, 2021
d55af65
Calculator: code cleanup
Dec 10, 2021
0782bd8
Calculator: code cleanup
Dec 10, 2021
65f9fa9
Calculator: Removed points above overflows from doc
Raupinger Dec 16, 2021
ff1ea0e
fonts/README: add calculator symbol to font generation documentation
NeroBurner Feb 26, 2022
6ff0f94
Merge remote-tracking branch 'NeroBurner/Calc_rebase' into Calc
Raupinger Feb 26, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
decreased .text size by not using std::strtod and setting #pragma GCC…
… optimize ("Os")
  • Loading branch information
Raupinger authored and NeroBurner committed Feb 26, 2022
commit ebfa399b879bc5eef2d78f3e4ccf9648ae8c2a59
34 changes: 30 additions & 4 deletions src/displayapp/screens/Calculator.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#pragma GCC push_options
#pragma GCC optimize ("Os")
Raupinger marked this conversation as resolved.
Show resolved Hide resolved
#include "Calculator.h"
#include <string>
#include <stack>
Expand Down Expand Up @@ -136,14 +138,36 @@ void Calculator::eval() {
while (!input.empty()) {

if (isdigit(input.top())) {
Raupinger marked this conversation as resolved.
Show resolved Hide resolved
std::string numberStr = "";

char numberStr[31];
uint8_t strln = 0;
uint8_t pointpos = 0;
while (!input.empty() && (isdigit(input.top()) || input.top() == '.')) {
numberStr.push_back(input.top());
if (input.top() == '.') {
if (pointpos != 0) {
motorController.SetDuration(10);
return;
}
pointpos = strln;
} else {
numberStr[strln] = input.top();
strln++;
}
input.pop();
}
//replacement for strtod() since using that increased .txt by 76858 bzt
if (pointpos == 0) {
pointpos = strln;
}
double num = 0;
for (uint8_t i = 0; i < pointpos; i++) {
num += (numberStr[i] - '0') * pow(10, pointpos - i - 1 );
}
for (uint8_t i = 0; i < strln - pointpos; i++) {
num += (numberStr[i + pointpos] - '0') / pow(10,i+1);
}

NumNode* number = new NumNode();
Raupinger marked this conversation as resolved.
Show resolved Hide resolved
number->value = std::strtod(numberStr.c_str(), nullptr) * sign;
number->value = num; //std::strtod(numberStr.c_str(), nullptr) * sign;
output.push(number);

sign = +1;
Expand Down Expand Up @@ -321,3 +345,5 @@ bool Calculator::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
bool Calculator::Refresh() {
return running;
}

#pragma GCC pop_options