aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-config-upgrade.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/e-config-upgrade.c')
-rw-r--r--shell/e-config-upgrade.c29
1 files changed, 27 insertions, 2 deletions
diff --git a/shell/e-config-upgrade.c b/shell/e-config-upgrade.c
index 4d574cc28e..e096b74c6b 100644
--- a/shell/e-config-upgrade.c
+++ b/shell/e-config-upgrade.c
@@ -1601,7 +1601,30 @@ static int load_accounts_1_0(xmlDocPtr doc)
*
* The tracked version is upgraded to the latest even if no
* configuration upgrades are required for that version.
+ *
+ * Further information about how this is intended to work:
+ *
+ * There are 3 basic steps, numbered in the comments below.
+ * 1. Determine the current config verison
+ * 2. Upgrade to the current source version
+ * 3. Save the version number, as defined by CONF_MAJOR, CONF_MINOR,
+ * CONF_REVISION. These are all treated as integers, so 10 is
+ * greater than 9.
+ *
+ * 1 and 3 should not need changing. After an upgrade to 1.3.x and
+ * until the config system changes again (!), step one becomes
+ * trivial. Any changes to part 2 should be added to the end of the
+ * section, or as required. This allows for very fine-grained version
+ * upgrades, including pre-release and patch-level changes to fix
+ * config problems which may have lasted for a single version or
+ * patch, in which case CONF_REVISION can be bumped.
*
+ * At any time, the CONF_VERSION/MAJOR/REVISION can be increased to
+ * match the source release, even if no new configuration changes will
+ * be required from the previous version. This should be done at each
+ * release in case bugs in that configuration version are required to
+ * be fixed at any time in the future.
+ *
* Return value: -1 on an error.
**/
int
@@ -1617,7 +1640,7 @@ e_config_upgrade(const char *edir)
evolution_dir = edir;
- /* determine existing version */
+ /* 1. determine existing version */
gconf = gconf_client_get_default();
val = gconf_client_get_string(gconf, "/apps/evolution/version", NULL);
if (val) {
@@ -1648,6 +1671,8 @@ e_config_upgrade(const char *edir)
xmlFree(tmp);
}
+ /* 2. Now perform any upgrade duties */
+
d(printf("current config version is '%u.%u.%u'\n", major, minor, revision));
/* For 1.0.x we need to load the accounts first, as data it initialises is used elsewhere */
@@ -1681,7 +1706,7 @@ e_config_upgrade(const char *edir)
}
}
- /* we're done, update our version info if its changed */
+ /* 3. we're done, update our version info if its changed */
if (major < CONF_MAJOR
|| minor < CONF_MINOR
|| revision < CONF_REVISION) {