]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/datstrm.cpp
Changed name of controls sample.
[wxWidgets.git] / src / common / datstrm.cpp
index 980a280c137fad6de0d7a56705225cede7b596a6..17f2100ebe1516aceeeb5960f46d757ec19c8e6b 100644 (file)
@@ -116,6 +116,27 @@ wxString wxDataStream::ReadLine()
   return i_strg;
 }
 
+wxString wxDataStream::ReadString()
+{
+  wxString wx_string;
+  char *string;
+  unsigned long len;
+
+  if (!m_istream)
+    return "";
+
+  len = Read32();
+  string = new char[len+1];
+
+  m_istream->read(string, len);
+
+  string[len] = 0;
+  wx_string = string;
+  delete string;
+
+  return wx_string; 
+}
+
 void wxDataStream::Write32(unsigned long i)
 {
   char buf[4];
@@ -152,7 +173,11 @@ void wxDataStream::Write8(unsigned char i)
 
 void wxDataStream::WriteLine(const wxString& line)
 {
+#ifdef __WINDOWS__
+  wxString tmp_string = line + "\r\n";
+#else
   wxString tmp_string = line + '\n';
+#endif
 
   if (!m_ostream)
     return;
@@ -160,6 +185,15 @@ void wxDataStream::WriteLine(const wxString& line)
   m_ostream->write((const char *) tmp_string, tmp_string.Length());
 }
 
+void wxDataStream::WriteString(const wxString& string)
+{
+  if (!m_ostream)
+    return;
+
+  Write32(string.Length());
+  m_ostream->write((const char *) string, string.Length());
+}
+
 // Must be at global scope for VC++ 5
 extern "C" void ConvertToIeeeExtended(double num, unsigned char *bytes);
 
@@ -170,6 +204,11 @@ void wxDataStream::WriteDouble(double d)
   if (!m_ostream)
     return;
 
+#if USE_APPLE_IEEE
   ConvertToIeeeExtended(d, (unsigned char *)buf);
+#else
+#      pragma warning "wxDataStream::WriteDouble() not using IeeeExtended - will not work!"
+ buf[0] = '\0';
+#endif
   m_ostream->write(buf, 10);
 }