summaryrefslogtreecommitdiffstats
path: root/katomic/gamewidget.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'katomic/gamewidget.cpp')
-rw-r--r--katomic/gamewidget.cpp25
1 files changed, 24 insertions, 1 deletions
diff --git a/katomic/gamewidget.cpp b/katomic/gamewidget.cpp
index fc6838a8..165e55c0 100644
--- a/katomic/gamewidget.cpp
+++ b/katomic/gamewidget.cpp
@@ -116,6 +116,25 @@ void GameWidget::getMoves(int moves)
ys->setText(current);
}
+void GameWidget::mergeHighScores(int l)
+{
+ KConfigGroup oldConfig(kapp->config(), QString("High Scores Level %1").arg(l).utf8());
+ KConfigGroup newConfig(kapp->config(), QString("Highscores Level %1").arg(l).utf8());
+
+ newConfig.writeEntry("LastPlayer", oldConfig.readEntry("LastPlayer"));
+
+ QString num;
+ for (int i = 1; i <= 10; ++i)
+ {
+ num.setNum(i);
+ QString key = "Pos" + num + "Name";
+ newConfig.writeEntry(key, oldConfig.readEntry(key, "-"));
+ key = "Pos" + num + "Score";
+ newConfig.writeEntry(key, oldConfig.readEntry(key, "-"));
+ }
+ kapp->config()->sync();
+}
+
void GameWidget::updateLevel (int l)
{
level=l;
@@ -128,7 +147,11 @@ void GameWidget::updateLevel (int l)
cfg.setGroup("Level");
feld->load(cfg);
- highScore->setConfigGroup(QString("High Scores Level %1").arg(level));
+ if (!kapp->config()->hasGroup(QString("Highscores Level %1").arg(level)) &&
+ kapp->config()->hasGroup(QString("High Scores Level %1").arg(level)))
+ mergeHighScores(level);
+
+ highScore->setConfigGroup(QString("Highscores Level %1").arg(level));
highest.setNum(highScore->highScore());
if (highest != "0" ) hs->setText(highest);