-
-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
settings.json and everything else overwritten without permission mysteriously #208
Comments
Did anything precede this occurring (manual edit, changing settings to a specific value, deleting or renaming a file)? The files are stored in %AppData%\Supercell Wx. |
Nope nothing. |
Is the program set to overwrite anything if any kind of conditions are met? |
I chose JSON over a binary format like a SQLite database, because it's human readable. The only time the application should overwrite the JSON files is if the files have syntax errors (e.g., missing/extra commas). Invalid or missing values are corrected, and should not impact the rest of the file. I do not expect outside of hand-editing that this should occur. It seems I may have missed a case. I'm thinking it'd be good that if there is a syntax error, I at least create a backup of the file prior to saving updated settings to give the opportunity for a correction. If you open an older version of Supercell Wx, newer settings values could be removed/reset. I'm trying to think of other scenarios, some hypothetical:
Multiple instances of Supercell Wx being open should not impact this significantly, as they both use the same set of configuration files. They only write on settings change or exit (or startup if there is something invalid), not without user interaction. Ultimately though, one of these instances could overwrite settings made by another instance. It's strange that both settings and placefiles were nuked, as these are stored in separate files. |
One way to make sure that a user knows that something fishy is going on is to ask whether they want to allow it to overwrite the existing file or notify the user that the file doesn't exist and then ask if the user wants to create a new settings file. An empty placefile list index file should pre-exist before any placefile references are ever created so that if the settings and the placefile list file doesn't exist when it should then flags can be thrown and errors declared and logs checked. |
I edited and added two more potential items with the previous post after you started to quote:
With the settings and placefile list being stored in the user directory rather than the application directory, there has to be an initial "create if it doesn't exist", if this is the first time a user is running, or upgrades to a version that supports the JSON file. That's not an error condition. I did start to add the setup dialog if certain conditions were not met in the settings file. Did you happen to note if there was anything in the terminal that displayed? I have a handful of warnings and errors with the following prefixes:
|
Nope I didn't realize that I needed to check that. There needs to be a flag somewhere that determines when the "First Run" occurred. So that it can compare time and dates. If the settings is missing and there is something that has the original first run date and time and dates don't match then it should log everything to an error.log file. and run Notepad.exe on it. |
might be a good idea to set read-only attributes on those files. |
This may or may not be the case here, but there's also an instance where Restore Defaults was the default button when pressing Enter from the settings dialog. This is now fixed in the latest development snapshot (#298). I still would like to implement a settings import/export before closing this issue however. |
So here's what happened:
I click on the icon shortcut for supercell-wx on my taskbar.
It loads up but the popup Introduction dialog for getting started shows up.
Nothing has been touched altered or anything.
My placefile definitions are gone and settings.json was overwritten by supercell-wx for some mysterious reason.
The MapTiler API key is gone too.
The text was updated successfully, but these errors were encountered: