projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fixed game crashing when leaving the worldmap
[supertux.git]
/
src
/
gameconfig.cpp
diff --git
a/src/gameconfig.cpp
b/src/gameconfig.cpp
index
b763fef
..
3825011
100644
(file)
--- a/
src/gameconfig.cpp
+++ b/
src/gameconfig.cpp
@@
-1,7
+1,7
@@
-// $Id
: configfile.cpp 2212 2004-11-28 14:57:45Z matzebraun
$
+// $Id$
//
// SuperTux - A Jump'n Run
//
// SuperTux - A Jump'n Run
-// Copyright (C) 200
4 Michael George <mike@georgetech.com
>
+// Copyright (C) 200
6 Matthias Braun <matze@braunis.de
>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
@@
-18,34
+18,40
@@
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include <config.h>
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include <config.h>
-#include "gameconfig.h"
+#include "gameconfig.h
pp
"
-#include <
cstdlib
>
+#include <
stdlib.h
>
#include <string>
#include <stdexcept>
#include <string>
#include <stdexcept>
-#include <sstream>
-#include <fstream>
-#include "lisp/parser.h"
-#include "lisp/lisp.h"
-#include "lisp/writer.h"
-#include "control/joystickkeyboardcontroller.h"
-#include "resources.h"
-#include "main.h"
+#include "lisp/parser.h
pp
"
+#include "lisp/lisp.h
pp
"
+#include "lisp/writer.h
pp
"
+#include "control/joystickkeyboardcontroller.h
pp
"
+#include "resources.h
pp
"
+#include "main.h
pp
"
Config* config = 0;
Config::Config()
{
Config* config = 0;
Config::Config()
{
- use_fullscreen = true;
+ profile = 1;
+ use_fullscreen = false;
+ video = AUTO_VIDEO;
+ try_vsync = true;
show_fps = false;
sound_enabled = true;
music_enabled = true;
show_fps = false;
sound_enabled = true;
music_enabled = true;
- cheats_enabled = false;
+ console_enabled = false;
+ random_seed = 0; // set by time(), by default (unless in config)
screenwidth = 800;
screenheight = 600;
screenwidth = 800;
screenheight = 600;
- use_gl = true;
+ aspect_ratio = -1; // autodetect
+
+ enable_script_debugger = false;
+
+ locale = ""; // autodetect
}
Config::~Config()
}
Config::~Config()
@@
-55,20
+61,27
@@
void
Config::load()
{
lisp::Parser parser;
Config::load()
{
lisp::Parser parser;
-
std::auto_ptr<lisp::Lisp> root (parser.parse("config")
);
+
const lisp::Lisp* root = parser.parse("config"
);
const lisp::Lisp* config_lisp = root->get_lisp("supertux-config");
if(!config_lisp)
throw std::runtime_error("File is not a supertux-config file");
config_lisp->get("show_fps", show_fps);
const lisp::Lisp* config_lisp = root->get_lisp("supertux-config");
if(!config_lisp)
throw std::runtime_error("File is not a supertux-config file");
config_lisp->get("show_fps", show_fps);
- config_lisp->get("cheats", cheats_enabled);
+ config_lisp->get("console", console_enabled);
+ config_lisp->get("locale", locale);
+ config_lisp->get("random_seed", random_seed);
const lisp::Lisp* config_video_lisp = config_lisp->get_lisp("video");
if(config_video_lisp) {
config_video_lisp->get("fullscreen", use_fullscreen);
const lisp::Lisp* config_video_lisp = config_lisp->get_lisp("video");
if(config_video_lisp) {
config_video_lisp->get("fullscreen", use_fullscreen);
+ std::string video_string;
+ config_video_lisp->get("video", video_string);
+ video = get_video_system(video_string);
+ config_video_lisp->get("vsync", try_vsync);
config_video_lisp->get("width", screenwidth);
config_video_lisp->get("height", screenheight);
config_video_lisp->get("width", screenwidth);
config_video_lisp->get("height", screenheight);
+ config_video_lisp->get("aspect_ratio", aspect_ratio);
}
const lisp::Lisp* config_audio_lisp = config_lisp->get_lisp("audio");
}
const lisp::Lisp* config_audio_lisp = config_lisp->get_lisp("audio");
@@
-91,12
+104,16
@@
Config::save()
writer.start_list("supertux-config");
writer.write_bool("show_fps", show_fps);
writer.start_list("supertux-config");
writer.write_bool("show_fps", show_fps);
- writer.write_bool("cheats", cheats_enabled);
+ writer.write_bool("console", console_enabled);
+ writer.write_string("locale", locale);
writer.start_list("video");
writer.write_bool("fullscreen", use_fullscreen);
writer.start_list("video");
writer.write_bool("fullscreen", use_fullscreen);
+ writer.write_string("video", get_video_string(video));
+ writer.write_bool("vsync", try_vsync);
writer.write_int("width", screenwidth);
writer.write_int("height", screenheight);
writer.write_int("width", screenwidth);
writer.write_int("height", screenheight);
+ writer.write_float("aspect_ratio", aspect_ratio);
writer.end_list("video");
writer.start_list("audio");
writer.end_list("video");
writer.start_list("audio");
@@
-109,6
+126,6
@@
Config::save()
main_controller->write(writer);
writer.end_list("control");
}
main_controller->write(writer);
writer.end_list("control");
}
-
+
writer.end_list("supertux-config");
}
writer.end_list("supertux-config");
}