This is an automated email from the git hooks/post-receive script.
git pushed a commit to reference refs/pull/49/head
in repository enlightenment.
View the commit online.
commit f34460bf9679c6f5121c15962a0f3cc7e1000386
Author: rafspiny <rafsp...@gmail.com>
AuthorDate: Tue Jan 23 22:11:24 2024 +0100
Introduce version for config
---
src/modules/convertible/e_mod_config.c | 35 +++++++++++++++++++++++-----------
src/modules/convertible/e_mod_config.h | 7 +++++++
2 files changed, 31 insertions(+), 11 deletions(-)
diff --git a/src/modules/convertible/e_mod_config.c b/src/modules/convertible/e_mod_config.c
index 8b18a2122..4e3b868ef 100644
--- a/src/modules/convertible/e_mod_config.c
+++ b/src/modules/convertible/e_mod_config.c
@@ -5,7 +5,7 @@
#include "e.h"
#include "e_mod_config.h"
-static Convertible_Config *_config = NULL;
+static Convertible_Config *conv_config = NULL;
E_Config_DD *config_edd = NULL;
EINTERN Convertible_Config *convertible_config;
@@ -22,19 +22,20 @@ _econvertible_config_dd_new(void)
// TODO Not sure what his line does. Apparently, it is needed to specify the type of the configuration data structure
config_edd = E_CONFIG_DD_NEW("Convertible_Config", Convertible_Config);
+ E_CONFIG_VAL(config_edd, Convertible_Config, version, INT);
E_CONFIG_VAL(config_edd, Convertible_Config, disable_keyboard_on_rotation, INT);
// E_CONFIG_LIST(config_edd, Convertible_Config, rotatable_screen_configuration, c_zone);
}
/**
- * Update the *_config data structure based on the settings coming from the dialog panel
+ * Update the *conv_config data structure based on the settings coming from the dialog panel
* @param config The config coming from the Dialog Panel (E_Config_Dialog_data)
*/
static void
_config_set(Convertible_Config *config)
{
DBG("config_set disable_keyboard_on_rotation %d", config->disable_keyboard_on_rotation);
- _config->disable_keyboard_on_rotation = config->disable_keyboard_on_rotation;
+ conv_config->disable_keyboard_on_rotation = config->disable_keyboard_on_rotation;
e_config_domain_save("module.convertible", config_edd, config);
}
@@ -51,8 +52,8 @@ _create_data(E_Config_Dialog *cfg EINA_UNUSED)
dialog_data = E_NEW(E_Config_Dialog_Data, 1);
dialog_data->config = malloc(sizeof(Convertible_Config));
- dialog_data->config->disable_keyboard_on_rotation = _config->disable_keyboard_on_rotation;
-// dialog_data->config->rotatable_screen_configuration = _config->rotatable_screen_configuration;
+ dialog_data->config->disable_keyboard_on_rotation = conv_config->disable_keyboard_on_rotation;
+// dialog_data->config->rotatable_screen_configuration = conv_config->rotatable_screen_configuration;
DBG("disable_keyboard_on_rotation %d", dialog_data->config->disable_keyboard_on_rotation);
return dialog_data;
@@ -72,7 +73,7 @@ _free_data(E_Config_Dialog *c EINA_UNUSED, E_Config_Dialog_Data *dialog_data)
}
/**
- * This function should store the modified settings into the data structure referred by the pointer _config
+ * This function should store the modified settings into the data structure referred by the pointer conv_config
* @param cfd
* @param cfdata
* @return
@@ -142,14 +143,26 @@ void
econvertible_config_init(void)
{
_econvertible_config_dd_new();
- _config = e_config_domain_load("module.econvertible", config_edd);
- if (!_config)
+ conv_config = e_config_domain_load("module.econvertible", config_edd);
+
+ // Check version
+ if (conv_config && !e_util_module_config_check(_("Convertible Module"),
+ conv_config->version,
+ MOD_CONFIG_FILE_VERSION))
{
- _config = E_NEW(Convertible_Config, 1);
- _config->disable_keyboard_on_rotation = 1;
-// _config->rotatable_screen_configuration = NULL;
+ free(conv_config);
+ return;
}
+
+ if (!conv_config)
+ {
+ conv_config = E_NEW(Convertible_Config, 1);
+ conv_config->disable_keyboard_on_rotation = 1;
+// conv_config->rotatable_screen_configuration = NULL;
+ }
+
+ conv_config->version = MOD_CONFIG_FILE_VERSION;
DBG("Config loaded");
}
diff --git a/src/modules/convertible/e_mod_config.h b/src/modules/convertible/e_mod_config.h
index 0af443795..2e0b98ea9 100644
--- a/src/modules/convertible/e_mod_config.h
+++ b/src/modules/convertible/e_mod_config.h
@@ -7,10 +7,17 @@
#ifndef E_GADGET_CONVERTIBLE_E_MOD_CONFIG_H
#define E_GADGET_CONVERTIBLE_E_MOD_CONFIG_H
+/* Increment for Major Changes */
+#define MOD_CONFIG_FILE_EPOCH 1
+/* Increment for Minor Changes (ie: user doesn't need a new config) */
+#define MOD_CONFIG_FILE_GENERATION 0
+#define MOD_CONFIG_FILE_VERSION ((MOD_CONFIG_FILE_EPOCH * 1000000) + MOD_CONFIG_FILE_GENERATION)
+
// Definition of the data structure to hold the gadget configuration
typedef struct _Convertible_Config Convertible_Config;
struct _Convertible_Config
{
+ int version;
E_Module *module;
int disable_keyboard_on_rotation;
};
--
To stop receiving notification emails like this one, please contact
the administrator of this repository.