projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
this shouldn't be in svn
[supertux.git]
/
src
/
lisp
/
writer.cpp
diff --git
a/src/lisp/writer.cpp
b/src/lisp/writer.cpp
index
ee0633c
..
4126b7f
100644
(file)
--- a/
src/lisp/writer.cpp
+++ b/
src/lisp/writer.cpp
@@
-1,7
+1,7
@@
// $Id$
//
// $Id$
//
-// SuperTux
- A Jump'n Run
-// Copyright (C) 200
4 Matthias Braun <matze@braunis.de
+// SuperTux
+// 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
@@
-23,7
+23,7
@@
#include "writer.hpp"
#include "physfs/physfs_stream.hpp"
#include "writer.hpp"
#include "physfs/physfs_stream.hpp"
-#include "
ms
g.hpp"
+#include "
lo
g.hpp"
namespace lisp
{
namespace lisp
{
@@
-45,7
+45,7
@@
Writer::Writer(std::ostream* newout)
Writer::~Writer()
{
if(lists.size() > 0) {
Writer::~Writer()
{
if(lists.size() > 0) {
-
msg_warning("Not all sections closed in lispwriter")
;
+
log_warning << "Not all sections closed in lispwriter" << std::endl
;
}
if(out_owned)
delete out;
}
if(out_owned)
delete out;
@@
-58,10
+58,15
@@
Writer::write_comment(const std::string& comment)
}
void
}
void
-Writer::start_list(const std::string& listname)
+Writer::start_list(const std::string& listname
, bool string
)
{
indent();
{
indent();
- *out << '(' << listname << '\n';
+ *out << '(';
+ if(string)
+ write_escaped_string(listname);
+ else
+ *out << listname;
+ *out << '\n';
indent_depth += 2;
lists.push_back(listname);
indent_depth += 2;
lists.push_back(listname);
@@
-71,13
+76,11
@@
void
Writer::end_list(const std::string& listname)
{
if(lists.size() == 0) {
Writer::end_list(const std::string& listname)
{
if(lists.size() == 0) {
- msg_warning("Trying to close list '" << listname
- << "', which is not open");
+ log_warning << "Trying to close list '" << listname << "', which is not open" << std::endl;
return;
}
if(lists.back() != listname) {
return;
}
if(lists.back() != listname) {
- msg_warning("trying to close list '" << listname
- << "' while list '" << lists.back() << "' is open");
+ log_warning << "trying to close list '" << listname << "' while list '" << lists.back() << "' is open" << std::endl;
return;
}
lists.pop_back();
return;
}
lists.pop_back();
@@
-108,9
+111,13
@@
Writer::write_string(const std::string& name, const std::string& value,
indent();
*out << '(' << name;
if(translatable) {
indent();
*out << '(' << name;
if(translatable) {
- *out << " (_ \"" << value << "\"))\n";
+ *out << " (_ ";
+ write_escaped_string(value);
+ *out << "))\n";
} else {
} else {
- *out << " \"" << value << "\")\n";
+ *out << " ";
+ write_escaped_string(value);
+ *out << ")\n";
}
}
}
}
@@
-155,6
+162,21
@@
Writer::write_float_vector(const std::string& name,
}
void
}
void
+Writer::write_escaped_string(const std::string& str)
+{
+ *out << '"';
+ for(const char* c = str.c_str(); *c != 0; ++c) {
+ if(*c == '\"')
+ *out << "\\\"";
+ else if(*c == '\\')
+ *out << "\\\\";
+ else
+ *out << *c;
+ }
+ *out << '"';
+}
+
+void
Writer::indent()
{
for(int i = 0; i<indent_depth; ++i)
Writer::indent()
{
for(int i = 0; i<indent_depth; ++i)