src/basics.cpp

Thu, 29 Mar 2018 10:18:18 +0300

author
Teemu Piippo <teemu@hecknology.net>
date
Thu, 29 Mar 2018 10:18:18 +0300
changeset 1351
b2994da4b852
parent 1350
eb2d3bc4fc73
child 1352
55fbbd4bdf86
permissions
-rw-r--r--

use 3 significant figures in file size representation

655
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
1 /*
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
2 * LDForge: LDraw parts authoring CAD
1326
69a90bd2dba2 Happy new year 2018
Teemu Piippo <teemu@hecknology.net>
parents: 1325
diff changeset
3 * Copyright (C) 2013 - 2018 Teemu Piippo
655
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
4 *
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
5 * This program is free software: you can redistribute it and/or modify
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
6 * it under the terms of the GNU General Public License as published by
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
7 * the Free Software Foundation, either version 3 of the License, or
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
8 * (at your option) any later version.
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
9 *
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
10 * This program is distributed in the hope that it will be useful,
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
13 * GNU General Public License for more details.
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
14 *
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
17 */
b376645315ab - renamed files to camelCase
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
18
1323
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
19 #include <QApplication>
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
20 #include <QSettings>
1318
568fcfc6da71 removed unnecessary files and includes
Teemu Piippo <teemu@hecknology.net>
parents: 1315
diff changeset
21 #include <QLineF>
568fcfc6da71 removed unnecessary files and includes
Teemu Piippo <teemu@hecknology.net>
parents: 1315
diff changeset
22 #include "basics.h"
568fcfc6da71 removed unnecessary files and includes
Teemu Piippo <teemu@hecknology.net>
parents: 1315
diff changeset
23 #include "types/vertex.h"
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
24 #include "format.h"
1323
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
25 #include "version.h"
1036
993c46d7eb75 Replaced the ugly for_enum macro with a generator class
Teemu Piippo <teemu@compsta2.com>
parents: 1031
diff changeset
26
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
27 int gcd(int a, int b)
1036
993c46d7eb75 Replaced the ugly for_enum macro with a generator class
Teemu Piippo <teemu@compsta2.com>
parents: 1031
diff changeset
28 {
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
29 while (b != 0)
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
30 {
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
31 int temp = a;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
32 a = b;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
33 b = temp % b;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
34 }
1036
993c46d7eb75 Replaced the ugly for_enum macro with a generator class
Teemu Piippo <teemu@compsta2.com>
parents: 1031
diff changeset
35
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
36 return a;
1031
55c0d3beea0d removed removeDuplicates in favor of QSet, and the unused ObjectList class
Teemu Piippo <crimsondusk64@gmail.com>
parents: 1014
diff changeset
37 }
1053
2a48c0fff107 Refactor primitives
Teemu Piippo <teemu@hecknology.net>
parents: 1037
diff changeset
38
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
39 void simplify(int& numerator, int& denominator)
1053
2a48c0fff107 Refactor primitives
Teemu Piippo <teemu@hecknology.net>
parents: 1037
diff changeset
40 {
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
41 int factor = gcd(numerator, denominator);
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
42 numerator /= factor;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
43 denominator /= factor;
1053
2a48c0fff107 Refactor primitives
Teemu Piippo <teemu@hecknology.net>
parents: 1037
diff changeset
44 }
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
45
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
46
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
47 QString joinStrings(const QList<StringFormatArg>& values, QString delimeter)
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
48 {
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
49 QStringList list;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
50
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
51 for (const StringFormatArg& arg : values)
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
52 list << arg.text();
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
53
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
54 return list.join(delimeter);
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
55 }
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
56
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
57
1324
563a9b65777b roundToDecimals no longer needs an lvalue. applyToMatrix removed.
Teemu Piippo <teemu@hecknology.net>
parents: 1323
diff changeset
58 double roundToDecimals(double value, int decimals)
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
59 {
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
60 if (decimals == 0)
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
61 {
1324
563a9b65777b roundToDecimals no longer needs an lvalue. applyToMatrix removed.
Teemu Piippo <teemu@hecknology.net>
parents: 1323
diff changeset
62 return round(value);
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
63 }
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
64 else if (decimals > 0)
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
65 {
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
66 qreal coefficient = pow(10, decimals);
1324
563a9b65777b roundToDecimals no longer needs an lvalue. applyToMatrix removed.
Teemu Piippo <teemu@hecknology.net>
parents: 1323
diff changeset
67 return round(value * coefficient) / coefficient;
1181
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
68 }
ca6d0ef9aadb Added polar grid rendering (which is disabled for now).
Teemu Piippo <teemu@hecknology.net>
parents: 1177
diff changeset
69 }
1305
31627acdd4b5 Bfc red/green view almost completely fixed
Teemu Piippo <teemu@hecknology.net>
parents: 1181
diff changeset
70
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
71 QString formatFileSize(qint64 size)
1308
dcc8c02530c2 Begin rework to add support for multiple libraries
Teemu Piippo <teemu@hecknology.net>
parents: 1305
diff changeset
72 {
1319
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
73 static const QString suffixes[] = {" bytes", "kB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"};
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
74 int magnitude = (size > 0) ? floor(log10(size) / 3.0 + 1e-10) : 0;
39d7a9642eea reorganized headers
Teemu Piippo <teemu@hecknology.net>
parents: 1318
diff changeset
75 magnitude = qBound(0, magnitude, countof(suffixes) - 1);
1351
b2994da4b852 use 3 significant figures in file size representation
Teemu Piippo <teemu@hecknology.net>
parents: 1350
diff changeset
76 return QString::number(size / pow(1000, magnitude), 'f', 3) + suffixes[magnitude];
1308
dcc8c02530c2 Begin rework to add support for multiple libraries
Teemu Piippo <teemu@hecknology.net>
parents: 1305
diff changeset
77 }
1323
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
78
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
79 /*
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
80 * Returns a settings object that interfaces the ini file.
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
81 */
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
82 QSettings& settingsObject()
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
83 {
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
84 static QSettings settings {
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
85 qApp->applicationDirPath() + "/" UNIXNAME ".ini",
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
86 QSettings::IniFormat
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
87 };
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
88 return settings;
05b3e173c900 Config is now a namespace
Teemu Piippo <teemu@hecknology.net>
parents: 1319
diff changeset
89 }
1350
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
90
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
91 QString largeNumberRep(int number)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
92 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
93 if (number < 0)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
94 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
95 return "-" + largeNumberRep(-number);
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
96 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
97 else
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
98 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
99 QString rep;
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
100
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
101 while (number >= 1000)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
102 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
103 rep = " " + QString::number(number % 1000);
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
104 number /= 1000;
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
105 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
106
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
107 return QString::number(number) + rep;
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
108 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
109 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
110
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
111 static const QString superscripts = "⁰¹²³⁴⁵⁶⁷⁸⁹";
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
112 static const QString subscripts = "₀₁₂₃₄₅₆₇₈₉";
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
113
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
114 static QString customNumberRep(int number, const QString& script, const QString& minus)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
115 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
116 if (number < 0)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
117 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
118 return minus + customNumberRep(-number, script, minus);
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
119 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
120 else
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
121 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
122 QString rep = "";
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
123 for (QChar character : QString::number(number))
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
124 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
125 if (character >= '0' and character <= '9')
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
126 rep += script[character.unicode() - '0'];
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
127 else
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
128 rep += character;
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
129 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
130 return rep;
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
131 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
132 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
133
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
134 QString superscript(int number)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
135 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
136 return customNumberRep(number, superscripts, "⁻");
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
137 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
138
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
139 QString subscript(int number)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
140 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
141 return customNumberRep(number, subscripts, "₋");
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
142 }
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
143
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
144 QString fractionRep(int numerator, int denominator)
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
145 {
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
146 return superscript(numerator) + "⁄" + subscript(denominator);
eb2d3bc4fc73 better representation of fractions and large numbers
Teemu Piippo <teemu@hecknology.net>
parents: 1326
diff changeset
147 }

mercurial