mirror of
https://github.com/MrUnknownDE/VRCX.git
synced 2026-04-17 13:53:52 +02:00
add removing config by key
This commit is contained in:
@@ -5,18 +5,22 @@ var dirtyKeySet = new Set();
|
||||
|
||||
class ConfigRepository extends SharedRepository {
|
||||
async init() {
|
||||
try {
|
||||
await sqliteService.executeNonQuery('CREATE TABLE IF NOT EXISTS configs (`key` TEXT PRIMARY KEY, `value` TEXT)');
|
||||
await sqliteService.execute(
|
||||
(key, value) => sharedRepository.setString(key, value),
|
||||
'SELECT `key`, `value` FROM configs'
|
||||
);
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
}
|
||||
await sqliteService.executeNonQuery(
|
||||
'CREATE TABLE IF NOT EXISTS configs (`key` TEXT PRIMARY KEY, `value` TEXT)'
|
||||
);
|
||||
await sqliteService.execute(
|
||||
(key, value) => sharedRepository.setString(key, value),
|
||||
'SELECT `key`, `value` FROM configs'
|
||||
);
|
||||
syncLoop();
|
||||
}
|
||||
|
||||
remove(key) {
|
||||
key = transformKey(key);
|
||||
sharedRepository.remove(key);
|
||||
dirtyKeySet.add(key);
|
||||
}
|
||||
|
||||
getString(key, defaultValue = null) {
|
||||
key = transformKey(key);
|
||||
return sharedRepository.getString(key, defaultValue);
|
||||
@@ -40,13 +44,23 @@ async function syncLoop() {
|
||||
await sqliteService.executeNonQuery('BEGIN');
|
||||
try {
|
||||
for (var key of dirtyKeySet) {
|
||||
await sqliteService.executeNonQuery(
|
||||
'INSERT OR REPLACE INTO configs (`key`, `value`) VALUES (@key, @value)',
|
||||
{
|
||||
'@key': key,
|
||||
'@value': sharedRepository.getString(key)
|
||||
}
|
||||
);
|
||||
var value = sharedRepository.getString(key);
|
||||
if (value === null) {
|
||||
await sqliteService.executeNonQuery(
|
||||
'DELETE FROM configs WHERE `key` = @key',
|
||||
{
|
||||
'@key': key,
|
||||
}
|
||||
);
|
||||
} else {
|
||||
await sqliteService.executeNonQuery(
|
||||
'INSERT OR REPLACE INTO configs (`key`, `value`) VALUES (@key, @value)',
|
||||
{
|
||||
'@key': key,
|
||||
'@value': value
|
||||
}
|
||||
);
|
||||
}
|
||||
}
|
||||
dirtyKeySet.clear();
|
||||
} finally {
|
||||
|
||||
@@ -1,6 +1,10 @@
|
||||
// requires binding of SharedVariable
|
||||
|
||||
class SharedRepository {
|
||||
remove(key) {
|
||||
key = transformKey(key);
|
||||
return SharedVariable.Remove(key);
|
||||
}
|
||||
getString(key, defaultValue = null) {
|
||||
key = transformKey(key);
|
||||
var value = SharedVariable.Get(key);
|
||||
|
||||
Reference in New Issue
Block a user