Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1 | /* |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 2 | Copyright 2012 to 2016 bigbiff/Dees_Troy TeamWin |
Dees Troy | 3be70a8 | 2013-10-22 14:25:12 +0000 | [diff] [blame] | 3 | This file is part of TWRP/TeamWin Recovery Project. |
| 4 | |
| 5 | TWRP is free software: you can redistribute it and/or modify |
| 6 | it under the terms of the GNU General Public License as published by |
| 7 | the Free Software Foundation, either version 3 of the License, or |
| 8 | (at your option) any later version. |
| 9 | |
| 10 | TWRP is distributed in the hope that it will be useful, |
| 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | GNU General Public License for more details. |
| 14 | |
| 15 | You should have received a copy of the GNU General Public License |
| 16 | along with TWRP. If not, see <http://www.gnu.org/licenses/>. |
| 17 | */ |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 18 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 19 | #include <pthread.h> |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 20 | #include <time.h> |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 21 | #include <string> |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 22 | #include <sstream> |
Ethan Yonker | 3fdcda4 | 2016-11-30 12:29:37 -0600 | [diff] [blame] | 23 | #include <fstream> |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 24 | #include <cctype> |
| 25 | #include <cutils/properties.h> |
Ethan Yonker | 34ae483 | 2016-08-24 15:32:18 -0500 | [diff] [blame] | 26 | #include <unistd.h> |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 27 | |
| 28 | #include "variables.h" |
| 29 | #include "data.hpp" |
| 30 | #include "partitions.hpp" |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 31 | #include "twrp-functions.hpp" |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 32 | #ifndef TW_NO_SCREEN_TIMEOUT |
Dees_Troy | 2f9117a | 2013-02-17 19:52:09 -0600 | [diff] [blame] | 33 | #include "gui/blanktimer.hpp" |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 34 | #endif |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 35 | #include "find_file.hpp" |
Ethan Yonker | 4b94cfd | 2014-12-11 10:00:45 -0600 | [diff] [blame] | 36 | #include "set_metadata.h" |
Ethan Yonker | 74db157 | 2015-10-28 12:44:49 -0500 | [diff] [blame] | 37 | #include "gui/gui.hpp" |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 38 | #include "infomanager.hpp" |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 39 | |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 40 | #define DEVID_MAX 64 |
| 41 | #define HWID_MAX 32 |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 42 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 43 | extern "C" |
| 44 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 45 | #include "twcommon.h" |
Dees_Troy | 7d15c25 | 2012-09-05 20:47:21 -0400 | [diff] [blame] | 46 | #include "gui/pages.h" |
Dees_Troy | 7d15c25 | 2012-09-05 20:47:21 -0400 | [diff] [blame] | 47 | void gui_notifyVarChange(const char *name, const char* value); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 48 | } |
Ethan Yonker | fbb4353 | 2015-12-28 21:54:50 +0100 | [diff] [blame] | 49 | #include "minuitwrp/minui.h" |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 50 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 51 | #define FILE_VERSION 0x00010010 // Do not set to 0 |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 52 | |
| 53 | using namespace std; |
| 54 | |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 55 | string DataManager::mBackingFile; |
| 56 | int DataManager::mInitialized = 0; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 57 | InfoManager DataManager::mPersist; // Data that that is not constant and will be saved to the settings file |
| 58 | InfoManager DataManager::mData; // Data that is not constant and will not be saved to settings file |
| 59 | InfoManager DataManager::mConst; // Data that is constant and will not be saved to settings file |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 60 | |
Ethan Yonker | 6277c79 | 2014-09-15 14:54:30 -0500 | [diff] [blame] | 61 | extern bool datamedia; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 62 | |
Ethan Yonker | c798c9c | 2015-10-09 11:15:26 -0500 | [diff] [blame] | 63 | #ifndef PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 64 | pthread_mutex_t DataManager::m_valuesLock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER; |
Ethan Yonker | c798c9c | 2015-10-09 11:15:26 -0500 | [diff] [blame] | 65 | #else |
| 66 | pthread_mutex_t DataManager::m_valuesLock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP; |
| 67 | #endif |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 68 | |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 69 | // Device ID functions |
| 70 | void DataManager::sanitize_device_id(char* device_id) { |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 71 | const char* whitelist ="-._"; |
| 72 | char str[DEVID_MAX]; |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 73 | char* c = str; |
| 74 | |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 75 | snprintf(str, DEVID_MAX, "%s", device_id); |
| 76 | memset(device_id, 0, strlen(device_id)); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 77 | while (*c) { |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 78 | if (isalnum(*c) || strchr(whitelist, *c)) |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 79 | strncat(device_id, c, 1); |
| 80 | c++; |
| 81 | } |
| 82 | return; |
| 83 | } |
| 84 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 85 | #define CMDLINE_SERIALNO "androidboot.serialno=" |
| 86 | #define CMDLINE_SERIALNO_LEN (strlen(CMDLINE_SERIALNO)) |
| 87 | #define CPUINFO_SERIALNO "Serial" |
| 88 | #define CPUINFO_SERIALNO_LEN (strlen(CPUINFO_SERIALNO)) |
| 89 | #define CPUINFO_HARDWARE "Hardware" |
| 90 | #define CPUINFO_HARDWARE_LEN (strlen(CPUINFO_HARDWARE)) |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 91 | |
| 92 | void DataManager::get_device_id(void) { |
| 93 | FILE *fp; |
| 94 | char line[2048]; |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 95 | char hardware_id[HWID_MAX] = { 0 }; |
| 96 | char device_id[DEVID_MAX] = { 0 }; |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 97 | char* token; |
| 98 | |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 99 | #ifdef TW_USE_MODEL_HARDWARE_ID_FOR_DEVICE_ID |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 100 | // Use (product_model)_(hardware_id) as device id |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 101 | char model_id[PROPERTY_VALUE_MAX]; |
| 102 | property_get("ro.product.model", model_id, "error"); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 103 | if (strcmp(model_id, "error") != 0) { |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 104 | LOGINFO("=> product model: '%s'\n", model_id); |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 105 | // Replace spaces with underscores |
Matt Mower | 23d8aae | 2017-01-06 14:30:33 -0600 | [diff] [blame] | 106 | for (size_t i = 0; i < strlen(model_id); i++) { |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 107 | if (model_id[i] == ' ') |
| 108 | model_id[i] = '_'; |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 109 | } |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 110 | snprintf(device_id, DEVID_MAX, "%s", model_id); |
| 111 | |
| 112 | if (strlen(device_id) < DEVID_MAX) { |
| 113 | fp = fopen("proc_cpuinfo.txt", "rt"); |
| 114 | if (fp != NULL) { |
| 115 | while (fgets(line, sizeof(line), fp) != NULL) { |
| 116 | if (memcmp(line, CPUINFO_HARDWARE, |
| 117 | CPUINFO_HARDWARE_LEN) == 0) { |
| 118 | // skip past "Hardware", spaces, and colon |
| 119 | token = line + CPUINFO_HARDWARE_LEN; |
| 120 | while (*token && (!isgraph(*token) || *token == ':')) |
| 121 | token++; |
| 122 | |
| 123 | if (*token && *token != '\n' |
| 124 | && strcmp("UNKNOWN\n", token)) { |
| 125 | snprintf(hardware_id, HWID_MAX, "%s", token); |
| 126 | if (hardware_id[strlen(hardware_id)-1] == '\n') |
| 127 | hardware_id[strlen(hardware_id)-1] = 0; |
| 128 | LOGINFO("=> hardware id from cpuinfo: '%s'\n", |
| 129 | hardware_id); |
| 130 | } |
| 131 | break; |
| 132 | } |
| 133 | } |
| 134 | fclose(fp); |
| 135 | } |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 136 | } |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 137 | |
| 138 | if (hardware_id[0] != 0) |
| 139 | snprintf(device_id, DEVID_MAX, "%s_%s", model_id, hardware_id); |
| 140 | |
| 141 | sanitize_device_id(device_id); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 142 | mConst.SetValue("device_id", device_id); |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 143 | LOGINFO("=> using device id: '%s'\n", device_id); |
Anatoly Smaznov | 10c11f6 | 2013-02-12 13:33:40 +0700 | [diff] [blame] | 144 | return; |
| 145 | } |
| 146 | #endif |
| 147 | |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 148 | #ifndef TW_FORCE_CPUINFO_FOR_DEVICE_ID |
lambdadroid | fc0b16d | 2017-08-04 17:16:53 +0200 | [diff] [blame] | 149 | #ifdef TW_USE_SERIALNO_PROPERTY_FOR_DEVICE_ID |
| 150 | // Check serial number system property |
| 151 | if (property_get("ro.serialno", line, "")) { |
| 152 | snprintf(device_id, DEVID_MAX, "%s", line); |
| 153 | sanitize_device_id(device_id); |
| 154 | mConst.SetValue("device_id", device_id); |
| 155 | return; |
| 156 | } |
| 157 | #endif |
| 158 | |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 159 | // Check the cmdline to see if the serial number was supplied |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 160 | fp = fopen("/proc/cmdline", "rt"); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 161 | if (fp != NULL) { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 162 | fgets(line, sizeof(line), fp); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 163 | fclose(fp); // cmdline is only one line long |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 164 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 165 | token = strtok(line, " "); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 166 | while (token) { |
| 167 | if (memcmp(token, CMDLINE_SERIALNO, CMDLINE_SERIALNO_LEN) == 0) { |
| 168 | token += CMDLINE_SERIALNO_LEN; |
| 169 | snprintf(device_id, DEVID_MAX, "%s", token); |
| 170 | sanitize_device_id(device_id); // also removes newlines |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 171 | mConst.SetValue("device_id", device_id); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 172 | return; |
| 173 | } |
| 174 | token = strtok(NULL, " "); |
| 175 | } |
| 176 | } |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 177 | #endif |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 178 | // Check cpuinfo for serial number; if found, use as device_id |
| 179 | // If serial number is not found, fallback to hardware_id for the device_id |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 180 | fp = fopen("/proc/cpuinfo", "rt"); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 181 | if (fp != NULL) { |
| 182 | while (fgets(line, sizeof(line), fp) != NULL) { |
| 183 | if (memcmp(line, CPUINFO_SERIALNO, CPUINFO_SERIALNO_LEN) == 0) { |
| 184 | // skip past "Serial", spaces, and colon |
| 185 | token = line + CPUINFO_SERIALNO_LEN; |
| 186 | while (*token && (!isgraph(*token) || *token == ':')) |
| 187 | token++; |
| 188 | |
| 189 | if (*token && *token != '\n') { |
| 190 | snprintf(device_id, DEVID_MAX, "%s", token); |
| 191 | sanitize_device_id(device_id); // also removes newlines |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 192 | LOGINFO("=> serial from cpuinfo: '%s'\n", device_id); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 193 | mConst.SetValue("device_id", device_id); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 194 | fclose(fp); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 195 | return; |
| 196 | } |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 197 | } else if (memcmp(line, CPUINFO_HARDWARE, |
| 198 | CPUINFO_HARDWARE_LEN) == 0) { |
| 199 | // skip past "Hardware", spaces, and colon |
| 200 | token = line + CPUINFO_HARDWARE_LEN; |
| 201 | while (*token && (!isgraph(*token) || *token == ':')) |
| 202 | token++; |
| 203 | |
| 204 | if (*token && *token != '\n') { |
| 205 | snprintf(hardware_id, HWID_MAX, "%s", token); |
| 206 | if (hardware_id[strlen(hardware_id)-1] == '\n') |
| 207 | hardware_id[strlen(hardware_id)-1] = 0; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 208 | LOGINFO("=> hardware id from cpuinfo: '%s'\n", hardware_id); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 209 | } |
| 210 | } |
| 211 | } |
| 212 | fclose(fp); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 213 | } |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 214 | |
| 215 | if (hardware_id[0] != 0) { |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 216 | LOGINFO("\nusing hardware id for device id: '%s'\n", hardware_id); |
Matt Mower | e926074 | 2015-02-22 20:20:18 -0600 | [diff] [blame] | 217 | snprintf(device_id, DEVID_MAX, "%s", hardware_id); |
| 218 | sanitize_device_id(device_id); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 219 | mConst.SetValue("device_id", device_id); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 220 | return; |
| 221 | } |
| 222 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 223 | strcpy(device_id, "serialno"); |
Ethan Yonker | 74db157 | 2015-10-28 12:44:49 -0500 | [diff] [blame] | 224 | LOGINFO("=> device id not found, using '%s'\n", device_id); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 225 | mConst.SetValue("device_id", device_id); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 226 | return; |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 227 | } |
| 228 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 229 | int DataManager::ResetDefaults() |
| 230 | { |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 231 | pthread_mutex_lock(&m_valuesLock); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 232 | mPersist.Clear(); |
| 233 | mData.Clear(); |
| 234 | mConst.Clear(); |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 235 | pthread_mutex_unlock(&m_valuesLock); |
| 236 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 237 | SetDefaultValues(); |
| 238 | return 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 239 | } |
| 240 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 241 | int DataManager::LoadValues(const string& filename) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 242 | { |
nkk71 | 98fc399 | 2017-12-16 16:26:42 +0200 | [diff] [blame] | 243 | string dev_id; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 244 | |
| 245 | if (!mInitialized) |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 246 | SetDefaultValues(); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 247 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 248 | GetValue("device_id", dev_id); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 249 | // Save off the backing file for set operations |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 250 | mBackingFile = filename; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 251 | mPersist.SetFile(filename); |
| 252 | mPersist.SetFileVersion(FILE_VERSION); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 253 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 254 | // Read in the file, if possible |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 255 | pthread_mutex_lock(&m_valuesLock); |
| 256 | mPersist.LoadValues(); |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 257 | |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 258 | #ifndef TW_NO_SCREEN_TIMEOUT |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 259 | blankTimer.setTime(mPersist.GetIntValue("tw_screen_timeout_secs")); |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 260 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 261 | |
| 262 | pthread_mutex_unlock(&m_valuesLock); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 263 | string current = GetCurrentStoragePath(); |
Ethan Yonker | eeed3c5 | 2014-04-16 11:49:02 -0500 | [diff] [blame] | 264 | TWPartition* Part = PartitionManager.Find_Partition_By_Path(current); |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 265 | if (!Part) |
Vojtech Bocek | 93cb1ef | 2014-05-12 15:41:52 +0200 | [diff] [blame] | 266 | Part = PartitionManager.Get_Default_Storage_Partition(); |
| 267 | if (Part && current != Part->Storage_Path && Part->Mount(false)) { |
Ethan Yonker | eeed3c5 | 2014-04-16 11:49:02 -0500 | [diff] [blame] | 268 | LOGINFO("LoadValues setting storage path to '%s'\n", Part->Storage_Path.c_str()); |
| 269 | SetValue("tw_storage_path", Part->Storage_Path); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 270 | } else { |
| 271 | SetBackupFolder(); |
| 272 | } |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 273 | return 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 274 | } |
| 275 | |
| 276 | int DataManager::Flush() |
| 277 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 278 | return SaveValues(); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 279 | } |
| 280 | |
| 281 | int DataManager::SaveValues() |
| 282 | { |
Ethan Yonker | 83e8257 | 2014-04-04 10:59:28 -0500 | [diff] [blame] | 283 | #ifndef TW_OEM_BUILD |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 284 | if (mBackingFile.empty()) |
| 285 | return -1; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 286 | |
| 287 | string mount_path = GetSettingsStoragePath(); |
Dees_Troy | 5bf4392 | 2012-09-07 16:07:55 -0400 | [diff] [blame] | 288 | PartitionManager.Mount_By_Path(mount_path.c_str(), 1); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 289 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 290 | mPersist.SetFile(mBackingFile); |
| 291 | mPersist.SetFileVersion(FILE_VERSION); |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 292 | pthread_mutex_lock(&m_valuesLock); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 293 | mPersist.SaveValues(); |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 294 | pthread_mutex_unlock(&m_valuesLock); |
| 295 | |
Ethan Yonker | 4b94cfd | 2014-12-11 10:00:45 -0600 | [diff] [blame] | 296 | tw_set_default_metadata(mBackingFile.c_str()); |
nkk71 | 98fc399 | 2017-12-16 16:26:42 +0200 | [diff] [blame] | 297 | LOGINFO("Saved settings file values to '%s'\n", mBackingFile.c_str()); |
Ethan Yonker | 83e8257 | 2014-04-04 10:59:28 -0500 | [diff] [blame] | 298 | #endif // ifdef TW_OEM_BUILD |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 299 | return 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 300 | } |
| 301 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 302 | int DataManager::GetValue(const string& varName, string& value) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 303 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 304 | string localStr = varName; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 305 | int ret = 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 306 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 307 | if (!mInitialized) |
| 308 | SetDefaultValues(); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 309 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 310 | // Strip off leading and trailing '%' if provided |
| 311 | if (localStr.length() > 2 && localStr[0] == '%' && localStr[localStr.length()-1] == '%') |
| 312 | { |
| 313 | localStr.erase(0, 1); |
| 314 | localStr.erase(localStr.length() - 1, 1); |
| 315 | } |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 316 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 317 | // Handle magic values |
| 318 | if (GetMagicValue(localStr, value) == 0) |
| 319 | return 0; |
Xuefer | a163f15 | 2015-03-26 22:45:04 +0800 | [diff] [blame] | 320 | |
| 321 | // Handle property |
| 322 | if (localStr.length() > 9 && localStr.substr(0, 9) == "property.") { |
| 323 | char property_value[PROPERTY_VALUE_MAX]; |
| 324 | property_get(localStr.substr(9).c_str(), property_value, ""); |
| 325 | value = property_value; |
| 326 | return 0; |
| 327 | } |
| 328 | |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 329 | pthread_mutex_lock(&m_valuesLock); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 330 | ret = mConst.GetValue(localStr, value); |
| 331 | if (ret == 0) |
| 332 | goto exit; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 333 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 334 | ret = mPersist.GetValue(localStr, value); |
| 335 | if (ret == 0) |
| 336 | goto exit; |
| 337 | |
| 338 | ret = mData.GetValue(localStr, value); |
| 339 | exit: |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 340 | pthread_mutex_unlock(&m_valuesLock); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 341 | return ret; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 342 | } |
| 343 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 344 | int DataManager::GetValue(const string& varName, int& value) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 345 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 346 | string data; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 347 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 348 | if (GetValue(varName,data) != 0) |
| 349 | return -1; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 350 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 351 | value = atoi(data.c_str()); |
| 352 | return 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 353 | } |
| 354 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 355 | int DataManager::GetValue(const string& varName, float& value) |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 356 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 357 | string data; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 358 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 359 | if (GetValue(varName,data) != 0) |
| 360 | return -1; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 361 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 362 | value = atof(data.c_str()); |
| 363 | return 0; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 364 | } |
| 365 | |
nkk71 | 98fc399 | 2017-12-16 16:26:42 +0200 | [diff] [blame] | 366 | int DataManager::GetValue(const string& varName, unsigned long long& value) |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 367 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 368 | string data; |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 369 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 370 | if (GetValue(varName,data) != 0) |
| 371 | return -1; |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 372 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 373 | value = strtoull(data.c_str(), NULL, 10); |
| 374 | return 0; |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 375 | } |
| 376 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 377 | // This function will return an empty string if the value doesn't exist |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 378 | string DataManager::GetStrValue(const string& varName) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 379 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 380 | string retVal; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 381 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 382 | GetValue(varName, retVal); |
| 383 | return retVal; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 384 | } |
| 385 | |
| 386 | // This function will return 0 if the value doesn't exist |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 387 | int DataManager::GetIntValue(const string& varName) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 388 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 389 | string retVal; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 390 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 391 | GetValue(varName, retVal); |
| 392 | return atoi(retVal.c_str()); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 393 | } |
| 394 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 395 | int DataManager::SetValue(const string& varName, const string& value, const int persist /* = 0 */) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 396 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 397 | if (!mInitialized) |
| 398 | SetDefaultValues(); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 399 | |
Xuefer | a163f15 | 2015-03-26 22:45:04 +0800 | [diff] [blame] | 400 | // Handle property |
| 401 | if (varName.length() > 9 && varName.substr(0, 9) == "property.") { |
| 402 | int ret = property_set(varName.substr(9).c_str(), value.c_str()); |
| 403 | if (ret) |
| 404 | LOGERR("Error setting property '%s' to '%s'\n", varName.substr(9).c_str(), value.c_str()); |
| 405 | return ret; |
| 406 | } |
| 407 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 408 | // Don't allow empty values or numerical starting values |
| 409 | if (varName.empty() || (varName[0] >= '0' && varName[0] <= '9')) |
| 410 | return -1; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 411 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 412 | string test; |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 413 | pthread_mutex_lock(&m_valuesLock); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 414 | int constChk = mConst.GetValue(varName, test); |
| 415 | if (constChk == 0) { |
| 416 | pthread_mutex_unlock(&m_valuesLock); |
| 417 | return -1; |
| 418 | } |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 419 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 420 | if (persist) { |
| 421 | mPersist.SetValue(varName, value); |
| 422 | } else { |
| 423 | int persistChk = mPersist.GetValue(varName, test); |
| 424 | if (persistChk == 0) { |
| 425 | mPersist.SetValue(varName, value); |
| 426 | } else { |
| 427 | mData.SetValue(varName, value); |
| 428 | } |
| 429 | } |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 430 | |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 431 | pthread_mutex_unlock(&m_valuesLock); |
| 432 | |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 433 | #ifndef TW_NO_SCREEN_TIMEOUT |
bigbiff bigbiff | f8e2f37 | 2013-02-27 20:50:43 -0500 | [diff] [blame] | 434 | if (varName == "tw_screen_timeout_secs") { |
Dees_Troy | 2f9117a | 2013-02-17 19:52:09 -0600 | [diff] [blame] | 435 | blankTimer.setTime(atoi(value.c_str())); |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 436 | } else |
| 437 | #endif |
| 438 | if (varName == "tw_storage_path") { |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 439 | SetBackupFolder(); |
bigbiff bigbiff | f8e2f37 | 2013-02-27 20:50:43 -0500 | [diff] [blame] | 440 | } |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 441 | gui_notifyVarChange(varName.c_str(), value.c_str()); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 442 | return 0; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 443 | } |
| 444 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 445 | int DataManager::SetValue(const string& varName, const int value, const int persist /* = 0 */) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 446 | { |
| 447 | ostringstream valStr; |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 448 | valStr << value; |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 449 | return SetValue(varName, valStr.str(), persist); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 450 | } |
| 451 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 452 | int DataManager::SetValue(const string& varName, const float value, const int persist /* = 0 */) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 453 | { |
| 454 | ostringstream valStr; |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 455 | valStr << value; |
| 456 | return SetValue(varName, valStr.str(), persist);; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 457 | } |
| 458 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 459 | int DataManager::SetValue(const string& varName, const unsigned long long& value, const int persist /* = 0 */) |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 460 | { |
| 461 | ostringstream valStr; |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 462 | valStr << value; |
| 463 | return SetValue(varName, valStr.str(), persist); |
bigbiff bigbiff | 2c57d78 | 2013-02-19 10:09:21 -0500 | [diff] [blame] | 464 | } |
| 465 | |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 466 | // For legacy code that doesn't set a scope |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 467 | int DataManager::SetProgress(const float Fraction) { |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 468 | if (SetValue("ui_portion_size", 0) != 0) |
| 469 | return -1; |
| 470 | if (SetValue("ui_portion_start", 0) != 0) |
| 471 | return -1; |
| 472 | ShowProgress(1, 0); |
| 473 | int res = _SetProgress(Fraction); |
| 474 | if (SetValue("ui_portion_size", 0) != 0) |
| 475 | return -1; |
| 476 | if (SetValue("ui_portion_start", 0) != 0) |
| 477 | return -1; |
| 478 | return res; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 479 | } |
| 480 | |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 481 | int DataManager::_SetProgress(float Fraction) { |
| 482 | float Portion_Start, Portion_Size; |
| 483 | GetValue("ui_portion_size", Portion_Size); |
| 484 | GetValue("ui_portion_start", Portion_Start); |
| 485 | //LOGINFO("SetProgress(%.2lf): Portion_Size: %.2lf Portion_Start: %.2lf\n", Fraction, Portion_Size, Portion_Start); |
| 486 | if (Fraction < 0.0) |
| 487 | Fraction = 0; |
| 488 | if (Fraction > 1.0) |
| 489 | Fraction = 1; |
| 490 | if (SetValue("ui_progress", (float) ((Portion_Start + (Portion_Size * Fraction)) * 100.0)) != 0) |
| 491 | return -1; |
| 492 | return (SetValue("ui_progress_portion", 0) != 0); |
| 493 | } |
| 494 | |
| 495 | int DataManager::ShowProgress(float Portion, const float Seconds) |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 496 | { |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 497 | float Portion_Start, Portion_Size; |
| 498 | GetValue("ui_portion_size", Portion_Size); |
| 499 | GetValue("ui_portion_start", Portion_Start); |
| 500 | Portion_Start += Portion_Size; |
| 501 | if(Portion + Portion_Start > 1.0) |
| 502 | Portion = 1.0 - Portion_Start; |
| 503 | //LOGINFO("ShowProgress(%.2lf, %.2lf): Portion_Start: %.2lf\n", Portion, Seconds, Portion_Start); |
| 504 | if (SetValue("ui_portion_start", Portion_Start) != 0) |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 505 | return -1; |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 506 | if (SetValue("ui_portion_size", Portion) != 0) |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 507 | return -1; |
Chaosmaster | d5364a0 | 2020-02-03 15:38:02 +0100 | [diff] [blame] | 508 | if (SetValue("ui_progress", (float)(Portion_Start * 100.0)) != 0) |
| 509 | return -1; |
| 510 | if(Seconds) { |
| 511 | if (SetValue("ui_progress_portion", (float)((Portion * 100.0) + Portion_Start)) != 0) |
| 512 | return -1; |
| 513 | if (SetValue("ui_progress_frames", Seconds * 48) != 0) |
| 514 | return -1; |
| 515 | } |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 516 | return 0; |
| 517 | } |
| 518 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 519 | void DataManager::update_tz_environment_variables(void) |
| 520 | { |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 521 | setenv("TZ", GetStrValue(TW_TIME_ZONE_VAR).c_str(), 1); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 522 | tzset(); |
Dees_Troy | 8170a92 | 2012-09-18 15:40:25 -0400 | [diff] [blame] | 523 | } |
| 524 | |
Dees_Troy | 16b7435 | 2012-11-14 22:27:31 +0000 | [diff] [blame] | 525 | void DataManager::SetBackupFolder() |
| 526 | { |
| 527 | string str = GetCurrentStoragePath(); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 528 | TWPartition* partition = PartitionManager.Find_Partition_By_Path(str); |
epicX | a721f95 | 2021-01-04 13:01:31 +0530 | [diff] [blame] | 529 | str += TWFunc::Check_For_TwrpFolder() + "/BACKUPS/"; |
Dees_Troy | 16b7435 | 2012-11-14 22:27:31 +0000 | [diff] [blame] | 530 | |
| 531 | string dev_id; |
| 532 | GetValue("device_id", dev_id); |
| 533 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 534 | str += dev_id; |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 535 | LOGINFO("Backup folder set to '%s'\n", str.c_str()); |
Dees_Troy | 16b7435 | 2012-11-14 22:27:31 +0000 | [diff] [blame] | 536 | SetValue(TW_BACKUPS_FOLDER_VAR, str, 0); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 537 | if (partition != NULL) { |
| 538 | SetValue("tw_storage_display_name", partition->Storage_Name); |
| 539 | char free_space[255]; |
| 540 | sprintf(free_space, "%llu", partition->Free / 1024 / 1024); |
| 541 | SetValue("tw_storage_free_size", free_space); |
| 542 | string zip_path, zip_root, storage_path; |
| 543 | GetValue(TW_ZIP_LOCATION_VAR, zip_path); |
Ethan Yonker | eadfd2e | 2016-02-18 22:04:18 -0600 | [diff] [blame] | 544 | if (partition->Has_Data_Media && !partition->Symlink_Mount_Point.empty()) |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 545 | storage_path = partition->Symlink_Mount_Point; |
| 546 | else |
| 547 | storage_path = partition->Storage_Path; |
| 548 | if (zip_path.size() < storage_path.size()) { |
| 549 | SetValue(TW_ZIP_LOCATION_VAR, storage_path); |
| 550 | } else { |
Dees Troy | c2e9bc7 | 2013-09-10 00:16:24 +0000 | [diff] [blame] | 551 | zip_root = TWFunc::Get_Root_Path(zip_path); |
Dees_Troy | 1872795 | 2013-06-20 15:24:48 -0500 | [diff] [blame] | 552 | if (zip_root != storage_path) { |
| 553 | LOGINFO("DataManager::SetBackupFolder zip path was %s changing to %s, %s\n", zip_path.c_str(), storage_path.c_str(), zip_root.c_str()); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 554 | SetValue(TW_ZIP_LOCATION_VAR, storage_path); |
Dees_Troy | 1872795 | 2013-06-20 15:24:48 -0500 | [diff] [blame] | 555 | } |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 556 | } |
| 557 | } else { |
Ethan Yonker | 74db157 | 2015-10-28 12:44:49 -0500 | [diff] [blame] | 558 | if (PartitionManager.Fstab_Processed() != 0) { |
| 559 | LOGINFO("Storage partition '%s' not found\n", str.c_str()); |
| 560 | gui_err("unable_locate_storage=Unable to locate storage device."); |
| 561 | } |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 562 | } |
Dees_Troy | 16b7435 | 2012-11-14 22:27:31 +0000 | [diff] [blame] | 563 | } |
| 564 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 565 | void DataManager::SetDefaultValues() |
| 566 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 567 | string str, path; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 568 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 569 | mConst.SetConst(); |
| 570 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 571 | get_device_id(); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 572 | |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 573 | pthread_mutex_lock(&m_valuesLock); |
| 574 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 575 | mInitialized = 1; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 576 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 577 | mConst.SetValue("true", "1"); |
| 578 | mConst.SetValue("false", "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 579 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 580 | mConst.SetValue(TW_VERSION_VAR, TW_VERSION_STR); |
bigbiff bigbiff | 3ed778a | 2019-03-12 19:28:31 -0400 | [diff] [blame] | 581 | |
| 582 | #ifndef TW_NO_HAPTICS |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 583 | mPersist.SetValue("tw_button_vibrate", "80"); |
| 584 | mPersist.SetValue("tw_keyboard_vibrate", "40"); |
| 585 | mPersist.SetValue("tw_action_vibrate", "160"); |
bigbiff bigbiff | 3ed778a | 2019-03-12 19:28:31 -0400 | [diff] [blame] | 586 | mConst.SetValue("tw_disable_haptics", "0"); |
| 587 | #else |
| 588 | LOGINFO("TW_NO_HAPTICS := true\n"); |
| 589 | mConst.SetValue("tw_disable_haptics", "1"); |
| 590 | #endif |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 591 | |
Vojtech Bocek | 93cb1ef | 2014-05-12 15:41:52 +0200 | [diff] [blame] | 592 | TWPartition *store = PartitionManager.Get_Default_Storage_Partition(); |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 593 | if (store) |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 594 | mPersist.SetValue("tw_storage_path", store->Storage_Path); |
Vojtech Bocek | 93cb1ef | 2014-05-12 15:41:52 +0200 | [diff] [blame] | 595 | else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 596 | mPersist.SetValue("tw_storage_path", "/"); |
Vojtech Bocek | 93cb1ef | 2014-05-12 15:41:52 +0200 | [diff] [blame] | 597 | |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 598 | #ifdef TW_FORCE_CPUINFO_FOR_DEVICE_ID |
| 599 | printf("TW_FORCE_CPUINFO_FOR_DEVICE_ID := true\n"); |
| 600 | #endif |
| 601 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 602 | #ifdef BOARD_HAS_NO_REAL_SDCARD |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 603 | printf("BOARD_HAS_NO_REAL_SDCARD := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 604 | mConst.SetValue(TW_ALLOW_PARTITION_SDCARD, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 605 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 606 | mConst.SetValue(TW_ALLOW_PARTITION_SDCARD, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 607 | #endif |
| 608 | |
| 609 | #ifdef TW_INCLUDE_DUMLOCK |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 610 | printf("TW_INCLUDE_DUMLOCK := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 611 | mConst.SetValue(TW_SHOW_DUMLOCK, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 612 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 613 | mConst.SetValue(TW_SHOW_DUMLOCK, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 614 | #endif |
| 615 | |
epicX | a721f95 | 2021-01-04 13:01:31 +0530 | [diff] [blame] | 616 | mData.SetValue(TW_RECOVERY_FOLDER_VAR, TW_DEFAULT_RECOVERY_FOLDER); |
| 617 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 618 | str = GetCurrentStoragePath(); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 619 | mPersist.SetValue(TW_ZIP_LOCATION_VAR, str); |
epicX | a721f95 | 2021-01-04 13:01:31 +0530 | [diff] [blame] | 620 | str += DataManager::GetStrValue(TW_RECOVERY_FOLDER_VAR) + "/BACKUPS/"; |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 621 | |
| 622 | string dev_id; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 623 | mConst.GetValue("device_id", dev_id); |
Dees_Troy | fdf5fcc | 2012-09-11 10:27:01 -0400 | [diff] [blame] | 624 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 625 | str += dev_id; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 626 | mData.SetValue(TW_BACKUPS_FOLDER_VAR, str); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 627 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 628 | mConst.SetValue(TW_REBOOT_SYSTEM, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 629 | #ifdef TW_NO_REBOOT_RECOVERY |
Talustus | 33ebf93 | 2013-02-02 14:11:14 +0100 | [diff] [blame] | 630 | printf("TW_NO_REBOOT_RECOVERY := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 631 | mConst.SetValue(TW_REBOOT_RECOVERY, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 632 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 633 | mConst.SetValue(TW_REBOOT_RECOVERY, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 634 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 635 | mConst.SetValue(TW_REBOOT_POWEROFF, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 636 | #ifdef TW_NO_REBOOT_BOOTLOADER |
Talustus | 33ebf93 | 2013-02-02 14:11:14 +0100 | [diff] [blame] | 637 | printf("TW_NO_REBOOT_BOOTLOADER := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 638 | mConst.SetValue(TW_REBOOT_BOOTLOADER, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 639 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 640 | mConst.SetValue(TW_REBOOT_BOOTLOADER, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 641 | #endif |
| 642 | #ifdef RECOVERY_SDCARD_ON_DATA |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 643 | printf("RECOVERY_SDCARD_ON_DATA := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 644 | mConst.SetValue(TW_HAS_DATA_MEDIA, "1"); |
Ethan Yonker | 6277c79 | 2014-09-15 14:54:30 -0500 | [diff] [blame] | 645 | datamedia = true; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 646 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 647 | mData.SetValue(TW_HAS_DATA_MEDIA, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 648 | #endif |
| 649 | #ifdef TW_NO_BATT_PERCENT |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 650 | printf("TW_NO_BATT_PERCENT := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 651 | mConst.SetValue(TW_NO_BATTERY_PERCENT, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 652 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 653 | mConst.SetValue(TW_NO_BATTERY_PERCENT, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 654 | #endif |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 655 | #ifdef TW_NO_CPU_TEMP |
| 656 | printf("TW_NO_CPU_TEMP := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 657 | mConst.SetValue("tw_no_cpu_temp", "1"); |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 658 | #else |
| 659 | string cpu_temp_file; |
| 660 | #ifdef TW_CUSTOM_CPU_TEMP_PATH |
| 661 | cpu_temp_file = EXPAND(TW_CUSTOM_CPU_TEMP_PATH); |
| 662 | #else |
| 663 | cpu_temp_file = "/sys/class/thermal/thermal_zone0/temp"; |
| 664 | #endif |
| 665 | if (TWFunc::Path_Exists(cpu_temp_file)) { |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 666 | mConst.SetValue("tw_no_cpu_temp", "0"); |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 667 | } else { |
| 668 | LOGINFO("CPU temperature file '%s' not found, disabling CPU temp.\n", cpu_temp_file.c_str()); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 669 | mConst.SetValue("tw_no_cpu_temp", "1"); |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 670 | } |
| 671 | #endif |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 672 | #ifdef TW_CUSTOM_POWER_BUTTON |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 673 | printf("TW_POWER_BUTTON := %s\n", EXPAND(TW_CUSTOM_POWER_BUTTON)); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 674 | mConst.SetValue(TW_POWER_BUTTON, EXPAND(TW_CUSTOM_POWER_BUTTON)); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 675 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 676 | mConst.SetValue(TW_POWER_BUTTON, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 677 | #endif |
| 678 | #ifdef TW_ALWAYS_RMRF |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 679 | printf("TW_ALWAYS_RMRF := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 680 | mConst.SetValue(TW_RM_RF_VAR, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 681 | #endif |
| 682 | #ifdef TW_NEVER_UNMOUNT_SYSTEM |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 683 | printf("TW_NEVER_UNMOUNT_SYSTEM := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 684 | mConst.SetValue(TW_DONT_UNMOUNT_SYSTEM, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 685 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 686 | mConst.SetValue(TW_DONT_UNMOUNT_SYSTEM, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 687 | #endif |
| 688 | #ifdef TW_NO_USB_STORAGE |
Dees_Troy | 6a042c8 | 2013-01-23 18:50:52 +0000 | [diff] [blame] | 689 | printf("TW_NO_USB_STORAGE := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 690 | mConst.SetValue(TW_HAS_USB_STORAGE, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 691 | #else |
Dees_Troy | 6a042c8 | 2013-01-23 18:50:52 +0000 | [diff] [blame] | 692 | char lun_file[255]; |
| 693 | string Lun_File_str = CUSTOM_LUN_FILE; |
| 694 | size_t found = Lun_File_str.find("%"); |
| 695 | if (found != string::npos) { |
| 696 | sprintf(lun_file, CUSTOM_LUN_FILE, 0); |
| 697 | Lun_File_str = lun_file; |
| 698 | } |
| 699 | if (!TWFunc::Path_Exists(Lun_File_str)) { |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 700 | LOGINFO("Lun file '%s' does not exist, USB storage mode disabled\n", Lun_File_str.c_str()); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 701 | mConst.SetValue(TW_HAS_USB_STORAGE, "0"); |
Dees_Troy | 6a042c8 | 2013-01-23 18:50:52 +0000 | [diff] [blame] | 702 | } else { |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 703 | LOGINFO("Lun file '%s'\n", Lun_File_str.c_str()); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 704 | mData.SetValue(TW_HAS_USB_STORAGE, "1"); |
Dees_Troy | 6a042c8 | 2013-01-23 18:50:52 +0000 | [diff] [blame] | 705 | } |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 706 | #endif |
| 707 | #ifdef TW_INCLUDE_INJECTTWRP |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 708 | printf("TW_INCLUDE_INJECTTWRP := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 709 | mConst.SetValue(TW_HAS_INJECTTWRP, "1"); |
| 710 | mPersist(TW_INJECT_AFTER_ZIP, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 711 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 712 | mConst.SetValue(TW_HAS_INJECTTWRP, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 713 | #endif |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 714 | #ifdef TW_HAS_DOWNLOAD_MODE |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 715 | printf("TW_HAS_DOWNLOAD_MODE := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 716 | mConst.SetValue(TW_DOWNLOAD_MODE, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 717 | #endif |
mauronofrio | e9a49ef | 2018-10-03 13:38:16 +0200 | [diff] [blame] | 718 | #ifdef TW_HAS_EDL_MODE |
| 719 | printf("TW_HAS_EDL_MODE := true\n"); |
| 720 | mConst.SetValue(TW_EDL_MODE, "1"); |
| 721 | #endif |
bigbiff | df8436b | 2020-08-30 16:22:34 -0400 | [diff] [blame] | 722 | #ifdef PRODUCT_USE_DYNAMIC_PARTITIONS |
| 723 | printf("PRODUCT_USE_DYNAMIC_PARTITIONS := true\n"); |
| 724 | mConst.SetValue(TW_FASTBOOT_MODE, "1"); |
| 725 | #endif |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 726 | #ifdef TW_INCLUDE_CRYPTO |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 727 | mConst.SetValue(TW_HAS_CRYPTO, "1"); |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 728 | printf("TW_INCLUDE_CRYPTO := true\n"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 729 | #endif |
| 730 | #ifdef TW_SDEXT_NO_EXT4 |
Dees_Troy | f449981 | 2013-01-23 19:07:38 +0000 | [diff] [blame] | 731 | printf("TW_SDEXT_NO_EXT4 := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 732 | mConst.SetValue(TW_SDEXT_DISABLE_EXT4, "1"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 733 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 734 | mConst.SetValue(TW_SDEXT_DISABLE_EXT4, "0"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 735 | #endif |
| 736 | |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 737 | #ifdef TW_HAS_NO_BOOT_PARTITION |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 738 | mPersist.SetValue("tw_backup_list", "/system;/data;"); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 739 | #else |
bigbiff | ee7b7ff | 2020-03-23 15:08:27 -0400 | [diff] [blame] | 740 | #ifdef PRODUCT_USE_DYNAMIC_PARTITIONS |
| 741 | mPersist.SetValue("tw_backup_list", "/data;"); |
| 742 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 743 | mPersist.SetValue("tw_backup_list", "/system;/data;/boot;"); |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 744 | #endif |
bigbiff | ee7b7ff | 2020-03-23 15:08:27 -0400 | [diff] [blame] | 745 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 746 | mConst.SetValue(TW_MIN_SYSTEM_VAR, TW_MIN_SYSTEM_SIZE); |
| 747 | mData.SetValue(TW_BACKUP_NAME, "(Auto Generate)"); |
bigbiff bigbiff | 7ce7f0c | 2013-01-25 09:54:04 -0500 | [diff] [blame] | 748 | |
Matt Mower | 8dc25b7 | 2016-04-25 23:06:53 -0500 | [diff] [blame] | 749 | mPersist.SetValue(TW_INSTALL_REBOOT_VAR, "0"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 750 | mPersist.SetValue(TW_SIGNED_ZIP_VERIFY_VAR, "0"); |
Matt Mower | bfccfb8 | 2016-04-25 23:22:31 -0500 | [diff] [blame] | 751 | mPersist.SetValue(TW_DISABLE_FREE_SPACE_VAR, "0"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 752 | mPersist.SetValue(TW_FORCE_DIGEST_CHECK_VAR, "0"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 753 | mPersist.SetValue(TW_USE_COMPRESSION_VAR, "0"); |
| 754 | mPersist.SetValue(TW_TIME_ZONE_VAR, "CST6CDT,M3.2.0,M11.1.0"); |
| 755 | mPersist.SetValue(TW_GUI_SORT_ORDER, "1"); |
| 756 | mPersist.SetValue(TW_RM_RF_VAR, "0"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 757 | mPersist.SetValue(TW_SKIP_DIGEST_CHECK_VAR, "0"); |
epicX | 9597b84 | 2021-03-20 21:58:17 +0530 | [diff] [blame] | 758 | mPersist.SetValue(TW_SKIP_DIGEST_CHECK_ZIP_VAR, "1"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 759 | mPersist.SetValue(TW_SKIP_DIGEST_GENERATE_VAR, "0"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 760 | mPersist.SetValue(TW_SDEXT_SIZE, "0"); |
| 761 | mPersist.SetValue(TW_SWAP_SIZE, "0"); |
| 762 | mPersist.SetValue(TW_SDPART_FILE_SYSTEM, "ext3"); |
| 763 | mPersist.SetValue(TW_TIME_ZONE_GUISEL, "CST6;CDT,M3.2.0,M11.1.0"); |
| 764 | mPersist.SetValue(TW_TIME_ZONE_GUIOFFSET, "0"); |
| 765 | mPersist.SetValue(TW_TIME_ZONE_GUIDST, "1"); |
nebrassy | ac29e69 | 2021-05-20 13:03:30 +0200 | [diff] [blame] | 766 | mPersist.SetValue(TW_AUTO_REFLASHTWRP_VAR, "0"); |
| 767 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 768 | mData.SetValue(TW_ACTION_BUSY, "0"); |
| 769 | mData.SetValue("tw_wipe_cache", "0"); |
| 770 | mData.SetValue("tw_wipe_dalvik", "0"); |
| 771 | mData.SetValue(TW_ZIP_INDEX, "0"); |
| 772 | mData.SetValue(TW_ZIP_QUEUE_COUNT, "0"); |
| 773 | mData.SetValue(TW_FILENAME, "/sdcard"); |
| 774 | mData.SetValue(TW_SIMULATE_ACTIONS, "0"); |
| 775 | mData.SetValue(TW_SIMULATE_FAIL, "0"); |
| 776 | mData.SetValue(TW_IS_ENCRYPTED, "0"); |
| 777 | mData.SetValue(TW_IS_DECRYPTED, "0"); |
| 778 | mData.SetValue(TW_CRYPTO_PASSWORD, "0"); |
| 779 | mData.SetValue("tw_terminal_state", "0"); |
| 780 | mData.SetValue("tw_background_thread_running", "0"); |
| 781 | mData.SetValue(TW_RESTORE_FILE_DATE, "0"); |
| 782 | mPersist.SetValue("tw_military_time", "0"); |
bigbiff | ee7b7ff | 2020-03-23 15:08:27 -0400 | [diff] [blame] | 783 | mData.SetValue(TW_IS_SUPER, "0"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 784 | |
| 785 | #ifdef TW_INCLUDE_CRYPTO |
bigbiff bigbiff | 9ee4a85 | 2018-09-19 19:13:19 -0400 | [diff] [blame] | 786 | mPersist.SetValue(TW_USE_SHA2, "1"); |
| 787 | mPersist.SetValue(TW_NO_SHA2, "0"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 788 | #else |
bigbiff bigbiff | 9ee4a85 | 2018-09-19 19:13:19 -0400 | [diff] [blame] | 789 | mPersist.SetValue(TW_NO_SHA2, "1"); |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 790 | #endif |
bigbiff | cfa875c | 2021-06-20 16:20:27 -0400 | [diff] [blame] | 791 | #ifdef AB_OTA_UPDATER |
| 792 | mPersist.SetValue(TW_UNMOUNT_SYSTEM, "0"); |
| 793 | #else |
Chaosmaster | ff4f958 | 2020-01-26 15:38:11 +0100 | [diff] [blame] | 794 | mPersist.SetValue(TW_UNMOUNT_SYSTEM, "1"); |
bigbiff | cfa875c | 2021-06-20 16:20:27 -0400 | [diff] [blame] | 795 | #endif |
bigbiff bigbiff | 56cf564 | 2016-08-19 17:43:45 -0400 | [diff] [blame] | 796 | |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 797 | #ifdef TW_NO_SCREEN_TIMEOUT |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 798 | mConst.SetValue("tw_screen_timeout_secs", "0"); |
| 799 | mConst.SetValue("tw_no_screen_timeout", "1"); |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 800 | #else |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 801 | mPersist.SetValue("tw_screen_timeout_secs", "60"); |
| 802 | mPersist.SetValue("tw_no_screen_timeout", "0"); |
Ricardo Gomez | c9ecd44 | 2013-07-05 16:13:52 -0700 | [diff] [blame] | 803 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 804 | mData.SetValue("tw_gui_done", "0"); |
| 805 | mData.SetValue("tw_encrypt_backup", "0"); |
Matt Mower | 9a2a205 | 2016-05-31 21:31:22 -0500 | [diff] [blame] | 806 | mData.SetValue("tw_sleep_total", "5"); |
| 807 | mData.SetValue("tw_sleep", "5"); |
bigbiff | df8436b | 2020-08-30 16:22:34 -0400 | [diff] [blame] | 808 | mData.SetValue("tw_enable_fastboot", "0"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 809 | |
| 810 | // Brightness handling |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 811 | string findbright; |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 812 | #ifdef TW_BRIGHTNESS_PATH |
| 813 | findbright = EXPAND(TW_BRIGHTNESS_PATH); |
| 814 | LOGINFO("TW_BRIGHTNESS_PATH := %s\n", findbright.c_str()); |
| 815 | if (!TWFunc::Path_Exists(findbright)) { |
| 816 | LOGINFO("Specified brightness file '%s' not found.\n", findbright.c_str()); |
| 817 | findbright = ""; |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 818 | } |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 819 | #endif |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 820 | if (findbright.empty()) { |
| 821 | // Attempt to locate the brightness file |
| 822 | findbright = Find_File::Find("brightness", "/sys/class/backlight"); |
Ethan Yonker | 9c102b5 | 2014-04-15 11:06:18 -0500 | [diff] [blame] | 823 | if (findbright.empty()) findbright = Find_File::Find("brightness", "/sys/class/leds/lcd-backlight"); |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 824 | } |
| 825 | if (findbright.empty()) { |
| 826 | LOGINFO("Unable to locate brightness file\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 827 | mConst.SetValue("tw_has_brightnesss_file", "0"); |
Ethan Yonker | 00028b4 | 2014-04-09 14:29:02 -0500 | [diff] [blame] | 828 | } else { |
| 829 | LOGINFO("Found brightness file at '%s'\n", findbright.c_str()); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 830 | mConst.SetValue("tw_has_brightnesss_file", "1"); |
| 831 | mConst.SetValue("tw_brightness_file", findbright); |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 832 | string maxBrightness; |
| 833 | #ifdef TW_MAX_BRIGHTNESS |
Vojtech Bocek | 8593234 | 2013-04-01 22:11:33 +0200 | [diff] [blame] | 834 | ostringstream maxVal; |
| 835 | maxVal << TW_MAX_BRIGHTNESS; |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 836 | maxBrightness = maxVal.str(); |
| 837 | #else |
| 838 | // Attempt to locate the max_brightness file |
| 839 | string maxbrightpath = findbright.insert(findbright.rfind('/') + 1, "max_"); |
| 840 | if (TWFunc::Path_Exists(maxbrightpath)) { |
Ethan Yonker | 72a8520 | 2016-01-22 11:45:06 -0600 | [diff] [blame] | 841 | ifstream maxVal(maxbrightpath.c_str()); |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 842 | if (maxVal >> maxBrightness) { |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 843 | LOGINFO("Got max brightness %s from '%s'\n", maxBrightness.c_str(), maxbrightpath.c_str()); |
| 844 | } else { |
| 845 | // Something went wrong, set that to indicate error |
| 846 | maxBrightness = "-1"; |
| 847 | } |
| 848 | } |
Ethan Yonker | 72a8520 | 2016-01-22 11:45:06 -0600 | [diff] [blame] | 849 | if (atoi(maxBrightness.c_str()) <= 0) |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 850 | { |
| 851 | // Fallback into default |
| 852 | ostringstream maxVal; |
| 853 | maxVal << 255; |
| 854 | maxBrightness = maxVal.str(); |
| 855 | } |
| 856 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 857 | mConst.SetValue("tw_brightness_max", maxBrightness); |
| 858 | mPersist.SetValue("tw_brightness", maxBrightness); |
| 859 | mPersist.SetValue("tw_brightness_pct", "100"); |
xNUTx | e85f02d | 2014-07-18 01:30:58 +0200 | [diff] [blame] | 860 | #ifdef TW_SECONDARY_BRIGHTNESS_PATH |
| 861 | string secondfindbright = EXPAND(TW_SECONDARY_BRIGHTNESS_PATH); |
| 862 | if (secondfindbright != "" && TWFunc::Path_Exists(secondfindbright)) { |
| 863 | LOGINFO("Will use a second brightness file at '%s'\n", secondfindbright.c_str()); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 864 | mConst.SetValue("tw_secondary_brightness_file", secondfindbright); |
xNUTx | e85f02d | 2014-07-18 01:30:58 +0200 | [diff] [blame] | 865 | } else { |
| 866 | LOGINFO("Specified secondary brightness file '%s' not found.\n", secondfindbright.c_str()); |
| 867 | } |
| 868 | #endif |
Greg Wallace | 36ade45 | 2015-11-08 13:54:25 -0500 | [diff] [blame] | 869 | #ifdef TW_DEFAULT_BRIGHTNESS |
| 870 | int defValInt = TW_DEFAULT_BRIGHTNESS; |
Ethan Yonker | 72a8520 | 2016-01-22 11:45:06 -0600 | [diff] [blame] | 871 | int maxValInt = atoi(maxBrightness.c_str()); |
Greg Wallace | 36ade45 | 2015-11-08 13:54:25 -0500 | [diff] [blame] | 872 | // Deliberately int so the % is always a whole number |
| 873 | int defPctInt = ( ( (double)defValInt / maxValInt ) * 100 ); |
| 874 | ostringstream defPct; |
| 875 | defPct << defPctInt; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 876 | mPersist.SetValue("tw_brightness_pct", defPct.str()); |
Greg Wallace | 36ade45 | 2015-11-08 13:54:25 -0500 | [diff] [blame] | 877 | |
| 878 | ostringstream defVal; |
| 879 | defVal << TW_DEFAULT_BRIGHTNESS; |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 880 | mPersist.SetValue("tw_brightness", defVal.str()); |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 881 | TWFunc::Set_Brightness(defVal.str()); |
Greg Wallace | 36ade45 | 2015-11-08 13:54:25 -0500 | [diff] [blame] | 882 | #else |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 883 | TWFunc::Set_Brightness(maxBrightness); |
Greg Wallace | 36ade45 | 2015-11-08 13:54:25 -0500 | [diff] [blame] | 884 | #endif |
Dees_Troy | 2f9117a | 2013-02-17 19:52:09 -0600 | [diff] [blame] | 885 | } |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 886 | |
Dees_Troy | 83bd483 | 2013-05-04 12:39:56 +0000 | [diff] [blame] | 887 | #ifndef TW_EXCLUDE_ENCRYPTED_BACKUPS |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 888 | mConst.SetValue("tw_include_encrypted_backup", "1"); |
Dees_Troy | 83bd483 | 2013-05-04 12:39:56 +0000 | [diff] [blame] | 889 | #else |
| 890 | LOGINFO("TW_EXCLUDE_ENCRYPTED_BACKUPS := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 891 | mConst.SetValue("tw_include_encrypted_backup", "0"); |
Dees_Troy | 83bd483 | 2013-05-04 12:39:56 +0000 | [diff] [blame] | 892 | #endif |
bigbiff bigbiff | c7eee6f | 2014-09-02 18:59:01 -0400 | [diff] [blame] | 893 | #ifdef TW_HAS_MTP |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 894 | mConst.SetValue("tw_has_mtp", "1"); |
| 895 | mPersist.SetValue("tw_mtp_enabled", "1"); |
| 896 | mPersist.SetValue("tw_mtp_debug", "0"); |
bigbiff bigbiff | c7eee6f | 2014-09-02 18:59:01 -0400 | [diff] [blame] | 897 | #else |
| 898 | LOGINFO("TW_EXCLUDE_MTP := true\n"); |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 899 | mConst.SetValue("tw_has_mtp", "0"); |
| 900 | mConst.SetValue("tw_mtp_enabled", "0"); |
bigbiff bigbiff | c7eee6f | 2014-09-02 18:59:01 -0400 | [diff] [blame] | 901 | #endif |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 902 | mPersist.SetValue("tw_mount_system_ro", "2"); |
| 903 | mPersist.SetValue("tw_never_show_system_ro_page", "0"); |
| 904 | mPersist.SetValue("tw_language", EXPAND(TW_DEFAULT_LANGUAGE)); |
Ethan Yonker | 74db157 | 2015-10-28 12:44:49 -0500 | [diff] [blame] | 905 | LOGINFO("LANG: %s\n", EXPAND(TW_DEFAULT_LANGUAGE)); |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 906 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 907 | mData.SetValue("tw_has_adopted_storage", "0"); |
Ethan Yonker | 66a1949 | 2015-12-10 10:19:45 -0600 | [diff] [blame] | 908 | |
Ethan Yonker | 1b19016 | 2016-12-05 15:25:19 -0600 | [diff] [blame] | 909 | #ifdef AB_OTA_UPDATER |
| 910 | LOGINFO("AB_OTA_UPDATER := true\n"); |
| 911 | mConst.SetValue("tw_has_boot_slots", "1"); |
| 912 | #else |
| 913 | mConst.SetValue("tw_has_boot_slots", "0"); |
| 914 | #endif |
nkk71 | b4c3591 | 2017-10-11 23:39:10 +0300 | [diff] [blame] | 915 | |
Ethan Yonker | 75aa615 | 2017-09-08 12:17:03 -0500 | [diff] [blame] | 916 | #ifdef TW_NO_LEGACY_PROPS |
| 917 | LOGINFO("TW_NO_LEGACY_PROPS := true\n"); |
Ethan Yonker | 75aa615 | 2017-09-08 12:17:03 -0500 | [diff] [blame] | 918 | #endif |
nkk71 | b4c3591 | 2017-10-11 23:39:10 +0300 | [diff] [blame] | 919 | |
Ethan Yonker | b4bff5e | 2016-12-16 07:47:58 -0600 | [diff] [blame] | 920 | #ifdef TW_OEM_BUILD |
| 921 | LOGINFO("TW_OEM_BUILD := true\n"); |
| 922 | mConst.SetValue("tw_oem_build", "1"); |
Ethan Yonker | 76bbd3a | 2019-05-10 10:50:04 -0500 | [diff] [blame] | 923 | mConst.SetValue("tw_app_installed_in_system", "0"); |
Ethan Yonker | b4bff5e | 2016-12-16 07:47:58 -0600 | [diff] [blame] | 924 | #else |
| 925 | mConst.SetValue("tw_oem_build", "0"); |
| 926 | mPersist.SetValue("tw_app_prompt", "1"); |
| 927 | mPersist.SetValue("tw_app_install_system", "1"); |
| 928 | mData.SetValue("tw_app_install_status", "0"); // 0 = no status, 1 = not installed, 2 = already installed |
Ethan Yonker | 76bbd3a | 2019-05-10 10:50:04 -0500 | [diff] [blame] | 929 | mData.SetValue("tw_app_installed_in_system", "0"); |
Ethan Yonker | b4bff5e | 2016-12-16 07:47:58 -0600 | [diff] [blame] | 930 | #endif |
Captain Throwback | 16dd81b | 2021-02-12 19:32:36 -0500 | [diff] [blame] | 931 | #ifndef TW_EXCLUDE_NANO |
| 932 | mConst.SetValue("tw_include_nano", "1"); |
| 933 | #else |
| 934 | LOGINFO("TW_EXCLUDE_NANO := true\n"); |
| 935 | mConst.SetValue("tw_include_nano", "0"); |
| 936 | #endif |
Ethan Yonker | b4bff5e | 2016-12-16 07:47:58 -0600 | [diff] [blame] | 937 | |
epicX | 8f52c0a | 2021-02-24 23:12:08 +0530 | [diff] [blame] | 938 | mData.SetValue("tw_flash_both_slots", "0"); |
| 939 | mData.SetValue("tw_is_slot_part", "0"); |
| 940 | |
Ethan Yonker | 53796e7 | 2019-01-11 22:49:52 -0600 | [diff] [blame] | 941 | mData.SetValue("tw_enable_adb_backup", "0"); |
| 942 | |
bigbiff | ad58e1b | 2020-07-06 20:24:34 -0400 | [diff] [blame] | 943 | if (TWFunc::Path_Exists("/system/bin/magiskboot")) |
Ethan Yonker | 53796e7 | 2019-01-11 22:49:52 -0600 | [diff] [blame] | 944 | mConst.SetValue("tw_has_repack_tools", "1"); |
| 945 | else |
| 946 | mConst.SetValue("tw_has_repack_tools", "0"); |
jason972000 | adae336 | 2017-12-08 09:08:45 -0600 | [diff] [blame] | 947 | |
Vojtech Bocek | fda239b | 2015-01-07 22:55:13 +0100 | [diff] [blame] | 948 | pthread_mutex_unlock(&m_valuesLock); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 949 | } |
| 950 | |
| 951 | // Magic Values |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 952 | int DataManager::GetMagicValue(const string& varName, string& value) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 953 | { |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 954 | // Handle special dynamic cases |
| 955 | if (varName == "tw_time") |
| 956 | { |
| 957 | char tmp[32]; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 958 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 959 | struct tm *current; |
| 960 | time_t now; |
| 961 | int tw_military_time; |
| 962 | now = time(0); |
| 963 | current = localtime(&now); |
Matt Mower | fb1c4ff | 2014-04-16 13:43:36 -0500 | [diff] [blame] | 964 | GetValue(TW_MILITARY_TIME, tw_military_time); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 965 | if (current->tm_hour >= 12) |
| 966 | { |
| 967 | if (tw_military_time == 1) |
| 968 | sprintf(tmp, "%d:%02d", current->tm_hour, current->tm_min); |
| 969 | else |
| 970 | sprintf(tmp, "%d:%02d PM", current->tm_hour == 12 ? 12 : current->tm_hour - 12, current->tm_min); |
bigbiff bigbiff | 4efe9c3 | 2013-02-20 18:58:11 -0500 | [diff] [blame] | 971 | } |
bigbiff bigbiff | 4efe9c3 | 2013-02-20 18:58:11 -0500 | [diff] [blame] | 972 | else |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 973 | { |
Matt Mower | fb1c4ff | 2014-04-16 13:43:36 -0500 | [diff] [blame] | 974 | if (tw_military_time == 1) |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 975 | sprintf(tmp, "%d:%02d", current->tm_hour, current->tm_min); |
| 976 | else |
| 977 | sprintf(tmp, "%d:%02d AM", current->tm_hour == 0 ? 12 : current->tm_hour, current->tm_min); |
| 978 | } |
| 979 | value = tmp; |
| 980 | return 0; |
bigbiff bigbiff | 4efe9c3 | 2013-02-20 18:58:11 -0500 | [diff] [blame] | 981 | } |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 982 | else if (varName == "tw_cpu_temp") |
| 983 | { |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 984 | int tw_no_cpu_temp; |
| 985 | GetValue("tw_no_cpu_temp", tw_no_cpu_temp); |
| 986 | if (tw_no_cpu_temp == 1) return -1; |
Agontuk | a29361a | 2015-04-22 14:42:59 +0600 | [diff] [blame] | 987 | |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 988 | string cpu_temp_file; |
| 989 | static unsigned long convert_temp = 0; |
| 990 | static time_t cpuSecCheck = 0; |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 991 | struct timeval curTime; |
| 992 | string results; |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 993 | |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 994 | gettimeofday(&curTime, NULL); |
| 995 | if (curTime.tv_sec > cpuSecCheck) |
| 996 | { |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 997 | #ifdef TW_CUSTOM_CPU_TEMP_PATH |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 998 | cpu_temp_file = EXPAND(TW_CUSTOM_CPU_TEMP_PATH); |
| 999 | if (TWFunc::read_file(cpu_temp_file, results) != 0) |
| 1000 | return -1; |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 1001 | #else |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 1002 | cpu_temp_file = "/sys/class/thermal/thermal_zone0/temp"; |
| 1003 | if (TWFunc::read_file(cpu_temp_file, results) != 0) |
| 1004 | return -1; |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 1005 | #endif |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 1006 | convert_temp = strtoul(results.c_str(), NULL, 0) / 1000; |
| 1007 | if (convert_temp <= 0) |
| 1008 | convert_temp = strtoul(results.c_str(), NULL, 0); |
| 1009 | if (convert_temp >= 150) |
| 1010 | convert_temp = strtoul(results.c_str(), NULL, 0) / 10; |
| 1011 | cpuSecCheck = curTime.tv_sec + 5; |
| 1012 | } |
| 1013 | value = TWFunc::to_string(convert_temp); |
| 1014 | return 0; |
Jenkins | 1710bf2 | 2014-10-02 20:22:21 -0400 | [diff] [blame] | 1015 | } |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 1016 | else if (varName == "tw_battery") |
| 1017 | { |
| 1018 | char tmp[16]; |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1019 | static char charging = ' '; |
| 1020 | static int lastVal = -1; |
| 1021 | static time_t nextSecCheck = 0; |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1022 | struct timeval curTime; |
| 1023 | gettimeofday(&curTime, NULL); |
| 1024 | if (curTime.tv_sec > nextSecCheck) |
| 1025 | { |
| 1026 | char cap_s[4]; |
Dees_Troy | f33b490 | 2013-03-01 00:51:39 +0000 | [diff] [blame] | 1027 | #ifdef TW_CUSTOM_BATTERY_PATH |
| 1028 | string capacity_file = EXPAND(TW_CUSTOM_BATTERY_PATH); |
| 1029 | capacity_file += "/capacity"; |
| 1030 | FILE * cap = fopen(capacity_file.c_str(),"rt"); |
| 1031 | #else |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1032 | FILE * cap = fopen("/sys/class/power_supply/battery/capacity","rt"); |
Dees_Troy | f33b490 | 2013-03-01 00:51:39 +0000 | [diff] [blame] | 1033 | #endif |
Matt Mower | a8a89d1 | 2016-12-30 18:10:37 -0600 | [diff] [blame] | 1034 | if (cap) { |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1035 | fgets(cap_s, 4, cap); |
| 1036 | fclose(cap); |
| 1037 | lastVal = atoi(cap_s); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 1038 | if (lastVal > 100) lastVal = 101; |
| 1039 | if (lastVal < 0) lastVal = 0; |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1040 | } |
Dees_Troy | f33b490 | 2013-03-01 00:51:39 +0000 | [diff] [blame] | 1041 | #ifdef TW_CUSTOM_BATTERY_PATH |
| 1042 | string status_file = EXPAND(TW_CUSTOM_BATTERY_PATH); |
| 1043 | status_file += "/status"; |
| 1044 | cap = fopen(status_file.c_str(),"rt"); |
| 1045 | #else |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1046 | cap = fopen("/sys/class/power_supply/battery/status","rt"); |
Dees_Troy | f33b490 | 2013-03-01 00:51:39 +0000 | [diff] [blame] | 1047 | #endif |
Dees_Troy | 38bd760 | 2012-09-14 13:33:53 -0400 | [diff] [blame] | 1048 | if (cap) { |
| 1049 | fgets(cap_s, 2, cap); |
| 1050 | fclose(cap); |
| 1051 | if (cap_s[0] == 'C') |
| 1052 | charging = '+'; |
| 1053 | else |
| 1054 | charging = ' '; |
| 1055 | } |
| 1056 | nextSecCheck = curTime.tv_sec + 60; |
| 1057 | } |
| 1058 | |
| 1059 | sprintf(tmp, "%i%%%c", lastVal, charging); |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 1060 | value = tmp; |
| 1061 | return 0; |
| 1062 | } |
| 1063 | return -1; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1064 | } |
| 1065 | |
Vojtech Bocek | fafb0c5 | 2013-07-25 22:53:02 +0200 | [diff] [blame] | 1066 | void DataManager::Output_Version(void) |
| 1067 | { |
Ethan Yonker | 89583ef | 2015-08-26 09:01:59 -0500 | [diff] [blame] | 1068 | #ifndef TW_OEM_BUILD |
Dees_Troy | 1c1ac44 | 2013-01-17 21:42:14 +0000 | [diff] [blame] | 1069 | string Path; |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1070 | char version[255]; |
| 1071 | |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1072 | std::string logDir = TWFunc::get_log_dir(); |
| 1073 | if (logDir.empty()) { |
bigbiff bigbiff | e4bdb15 | 2019-03-23 18:33:17 -0400 | [diff] [blame] | 1074 | LOGINFO("Unable to find cache directory\n"); |
| 1075 | return; |
| 1076 | } |
| 1077 | |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1078 | std::string recoveryLogDir = logDir + "recovery/"; |
bigbiff bigbiff | 19874f1 | 2019-01-08 20:06:57 -0500 | [diff] [blame] | 1079 | |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1080 | if (logDir == CACHE_LOGS_DIR) { |
| 1081 | if (!PartitionManager.Mount_By_Path(CACHE_LOGS_DIR, false)) { |
bigbiff bigbiff | 19874f1 | 2019-01-08 20:06:57 -0500 | [diff] [blame] | 1082 | LOGINFO("Unable to mount '%s' to write version number.\n", Path.c_str()); |
Dees_Troy | 1c1ac44 | 2013-01-17 21:42:14 +0000 | [diff] [blame] | 1083 | return; |
| 1084 | } |
Mohd Faraz | f9ded06 | 2020-06-06 20:50:57 +0530 | [diff] [blame] | 1085 | |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1086 | if (!TWFunc::Path_Exists(recoveryLogDir)) { |
| 1087 | LOGINFO("Recreating %s folder.\n", recoveryLogDir.c_str()); |
| 1088 | if (!TWFunc::Create_Dir_Recursive(recoveryLogDir.c_str(), S_IRWXU | S_IRWXG | S_IWGRP | S_IXGRP, 0, 0)) { |
| 1089 | LOGERR("DataManager::Output_Version -- Unable to make %s: %s\n", recoveryLogDir.c_str(), strerror(errno)); |
Mohd Faraz | f9ded06 | 2020-06-06 20:50:57 +0530 | [diff] [blame] | 1090 | return; |
| 1091 | } |
| 1092 | } |
Dees_Troy | 1c1ac44 | 2013-01-17 21:42:14 +0000 | [diff] [blame] | 1093 | } |
bigbiff | 7ba7500 | 2020-04-11 20:47:09 -0400 | [diff] [blame] | 1094 | |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1095 | std::string verPath = recoveryLogDir + ".version"; |
bigbiff bigbiff | 19874f1 | 2019-01-08 20:06:57 -0500 | [diff] [blame] | 1096 | if (TWFunc::Path_Exists(verPath)) { |
| 1097 | unlink(verPath.c_str()); |
| 1098 | } |
| 1099 | FILE *fp = fopen(verPath.c_str(), "w"); |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1100 | if (fp == NULL) { |
bigbiff bigbiff | 19874f1 | 2019-01-08 20:06:57 -0500 | [diff] [blame] | 1101 | gui_msg(Msg(msg::kError, "error_opening_strerr=Error opening: '{1}' ({2})")(verPath)(strerror(errno))); |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1102 | return; |
| 1103 | } |
| 1104 | strcpy(version, TW_VERSION_STR); |
| 1105 | fwrite(version, sizeof(version[0]), strlen(version) / sizeof(version[0]), fp); |
| 1106 | fclose(fp); |
bigbiff | 25d25b9 | 2020-06-19 16:07:38 -0400 | [diff] [blame] | 1107 | TWFunc::copy_file("/etc/recovery.fstab", recoveryLogDir + "recovery.fstab", 0644); |
Dees_Troy | d93bda5 | 2013-07-03 19:55:19 +0000 | [diff] [blame] | 1108 | PartitionManager.Output_Storage_Fstab(); |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1109 | sync(); |
bigbiff bigbiff | 19874f1 | 2019-01-08 20:06:57 -0500 | [diff] [blame] | 1110 | LOGINFO("Version number saved to '%s'\n", verPath.c_str()); |
Ethan Yonker | 89583ef | 2015-08-26 09:01:59 -0500 | [diff] [blame] | 1111 | #endif |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1112 | } |
| 1113 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1114 | void DataManager::ReadSettingsFile(void) |
| 1115 | { |
Ethan Yonker | 83e8257 | 2014-04-04 10:59:28 -0500 | [diff] [blame] | 1116 | #ifndef TW_OEM_BUILD |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1117 | // Load up the values for TWRP - Sleep to let the card be ready |
| 1118 | char mkdir_path[255], settings_file[255]; |
Matt Mower | 23d8aae | 2017-01-06 14:30:33 -0600 | [diff] [blame] | 1119 | int is_enc, has_data_media; |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1120 | |
| 1121 | GetValue(TW_IS_ENCRYPTED, is_enc); |
| 1122 | GetValue(TW_HAS_DATA_MEDIA, has_data_media); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1123 | |
| 1124 | memset(mkdir_path, 0, sizeof(mkdir_path)); |
| 1125 | memset(settings_file, 0, sizeof(settings_file)); |
epicX | a721f95 | 2021-01-04 13:01:31 +0530 | [diff] [blame] | 1126 | sprintf(mkdir_path, "%s%s", GetSettingsStoragePath().c_str(), GetStrValue(TW_RECOVERY_FOLDER_VAR).c_str()); |
| 1127 | sprintf(settings_file, "%s/%s", mkdir_path, TW_SETTINGS_FILE); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1128 | |
Dees_Troy | 5bf4392 | 2012-09-07 16:07:55 -0400 | [diff] [blame] | 1129 | if (!PartitionManager.Mount_Settings_Storage(false)) |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1130 | { |
| 1131 | usleep(500000); |
Dees_Troy | 5bf4392 | 2012-09-07 16:07:55 -0400 | [diff] [blame] | 1132 | if (!PartitionManager.Mount_Settings_Storage(false)) |
Ethan Yonker | 74db157 | 2015-10-28 12:44:49 -0500 | [diff] [blame] | 1133 | gui_msg(Msg(msg::kError, "unable_to_mount=Unable to mount {1}")(settings_file)); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1134 | } |
| 1135 | |
| 1136 | mkdir(mkdir_path, 0777); |
| 1137 | |
Dees_Troy | 2673cec | 2013-04-02 20:22:16 +0000 | [diff] [blame] | 1138 | LOGINFO("Attempt to load settings from settings file...\n"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1139 | LoadValues(settings_file); |
Dees_Troy | 01a9b7a | 2012-10-01 09:01:03 -0400 | [diff] [blame] | 1140 | Output_Version(); |
Ethan Yonker | 83e8257 | 2014-04-04 10:59:28 -0500 | [diff] [blame] | 1141 | #endif // ifdef TW_OEM_BUILD |
Ethan Yonker | 7af51ce | 2014-04-04 13:33:30 -0500 | [diff] [blame] | 1142 | PartitionManager.Mount_All_Storage(); |
Dees_Troy | 8170a92 | 2012-09-18 15:40:25 -0400 | [diff] [blame] | 1143 | update_tz_environment_variables(); |
Tatsuyuki Ishi | 548a175 | 2015-12-28 10:08:58 +0900 | [diff] [blame] | 1144 | TWFunc::Set_Brightness(GetStrValue("tw_brightness")); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1145 | } |
| 1146 | |
| 1147 | string DataManager::GetCurrentStoragePath(void) |
| 1148 | { |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 1149 | return GetStrValue("tw_storage_path"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1150 | } |
| 1151 | |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1152 | string DataManager::GetSettingsStoragePath(void) |
| 1153 | { |
Dees_Troy | a13d74f | 2013-03-24 08:54:55 -0500 | [diff] [blame] | 1154 | return GetStrValue("tw_settings_path"); |
Dees_Troy | 51a0e82 | 2012-09-05 15:24:24 -0400 | [diff] [blame] | 1155 | } |
| 1156 | |
Ethan Yonker | fe91611 | 2016-03-14 14:54:37 -0500 | [diff] [blame] | 1157 | void DataManager::Vibrate(const string& varName) |
Samer Diab (S.a.M.e.R_d) | 71e9b04 | 2014-01-07 20:18:47 +0000 | [diff] [blame] | 1158 | { |
bigbiff bigbiff | 3ed778a | 2019-03-12 19:28:31 -0400 | [diff] [blame] | 1159 | #ifndef TW_NO_HAPTICS |
Samer Diab (S.a.M.e.R_d) | 71e9b04 | 2014-01-07 20:18:47 +0000 | [diff] [blame] | 1160 | int vib_value = 0; |
| 1161 | GetValue(varName, vib_value); |
| 1162 | if (vib_value) { |
| 1163 | vibrate(vib_value); |
| 1164 | } |
bigbiff bigbiff | 3ed778a | 2019-03-12 19:28:31 -0400 | [diff] [blame] | 1165 | #endif |
Samer Diab (S.a.M.e.R_d) | 71e9b04 | 2014-01-07 20:18:47 +0000 | [diff] [blame] | 1166 | } |
epicX | a721f95 | 2021-01-04 13:01:31 +0530 | [diff] [blame] | 1167 | |
| 1168 | |
| 1169 | void DataManager::LoadTWRPFolderInfo(void) |
| 1170 | { |
| 1171 | string mainPath = GetCurrentStoragePath(); |
| 1172 | SetValue(TW_RECOVERY_FOLDER_VAR, TWFunc::Check_For_TwrpFolder()); |
| 1173 | mBackingFile = mainPath + GetStrValue(TW_RECOVERY_FOLDER_VAR) + '/' + TW_SETTINGS_FILE; |
nebrassy | ac29e69 | 2021-05-20 13:03:30 +0200 | [diff] [blame] | 1174 | } |