summaryrefslogtreecommitdiff
path: root/src/network
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2009-01-18 13:12:57 +0000
committerrubidium <rubidium@openttd.org>2009-01-18 13:12:57 +0000
commit07e135547e1919048756a751adb71921b5beba94 (patch)
tree6d76af52262054593ff7eea5e0e4a6d516cc0935 /src/network
parentb8219eb7a119809944f32dbda8c238afedada595 (diff)
downloadopenttd-07e135547e1919048756a751adb71921b5beba94.tar.xz
(svn r15135) -Fix/Change: allow str_validate (part of receiving strings from the network) to pass newlines instead of replacing them with question marks, but only when asked to do so.
Diffstat (limited to 'src/network')
-rw-r--r--src/network/core/packet.cpp4
-rw-r--r--src/network/core/packet.h2
-rw-r--r--src/network/network_content.cpp2
3 files changed, 4 insertions, 4 deletions
diff --git a/src/network/core/packet.cpp b/src/network/core/packet.cpp
index 21d8cf5df..5c06ab488 100644
--- a/src/network/core/packet.cpp
+++ b/src/network/core/packet.cpp
@@ -233,7 +233,7 @@ uint64 Packet::Recv_uint64()
}
/** Reads a string till it finds a '\0' in the stream */
-void Packet::Recv_string(char *buffer, size_t size)
+void Packet::Recv_string(char *buffer, size_t size, bool allow_newlines)
{
PacketSize pos;
char *bufp = buffer;
@@ -253,7 +253,7 @@ void Packet::Recv_string(char *buffer, size_t size)
}
this->pos = pos;
- str_validate(bufp);
+ str_validate(bufp, allow_newlines);
}
#endif /* ENABLE_NETWORK */
diff --git a/src/network/core/packet.h b/src/network/core/packet.h
index 1dd35a70d..f0202eee6 100644
--- a/src/network/core/packet.h
+++ b/src/network/core/packet.h
@@ -62,7 +62,7 @@ public:
uint16 Recv_uint16();
uint32 Recv_uint32();
uint64 Recv_uint64();
- void Recv_string(char *buffer, size_t size);
+ void Recv_string(char *buffer, size_t size, bool allow_newlines = false);
};
Packet *NetworkSend_Init(PacketType type);
diff --git a/src/network/network_content.cpp b/src/network/network_content.cpp
index d49e09282..26a92324f 100644
--- a/src/network/network_content.cpp
+++ b/src/network/network_content.cpp
@@ -53,7 +53,7 @@ DEF_CONTENT_RECEIVE_COMMAND(Client, PACKET_CONTENT_SERVER_INFO)
p->Recv_string(ci->name, lengthof(ci->name));
p->Recv_string(ci->version, lengthof(ci->name));
p->Recv_string(ci->url, lengthof(ci->url));
- p->Recv_string(ci->description, lengthof(ci->description));
+ p->Recv_string(ci->description, lengthof(ci->description), true);
ci->unique_id = p->Recv_uint32();
for (uint j = 0; j < sizeof(ci->md5sum); j++) {