uses a buffer to read data (instead of reading it one char at a time)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@276
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// Name: config.cpp
// Purpose: implementation of wxConfig class
// Author: Vadim Zeitlin
// Name: config.cpp
// Purpose: implementation of wxConfig class
// Author: Vadim Zeitlin
// Created: 07.04.98
// RCS-ID: $Id$
// Created: 07.04.98
// RCS-ID: $Id$
-// Copyright: (c) 1997 Karsten Ballüder Ballueder@usa.net
+// Copyright: (c) 1997 Karsten Ballüder Ballueder@usa.net
// Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// Licence: wxWindows license
///////////////////////////////////////////////////////////////////////////////
// Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// Licence: wxWindows license
///////////////////////////////////////////////////////////////////////////////
wxString ExpandEnvVars(const wxString& str)
{
wxString strResult;
wxString ExpandEnvVars(const wxString& str)
{
wxString strResult;
+ strResult.Alloc(str.Len());
// don't change the values the enum elements: they must be equal
// to the matching [closing] delimiter.
enum Bracket
// don't change the values the enum elements: they must be equal
// to the matching [closing] delimiter.
enum Bracket
- {
- Bracket_None,
- Bracket_Normal = ')',
+ {
+ Bracket_None,
+ Bracket_Normal = ')',
Bracket_Curly = '}',
#ifdef __WXMSW__
Bracket_Windows = '%' // yeah, Windows people are a bit strange ;-)
Bracket_Curly = '}',
#ifdef __WXMSW__
Bracket_Windows = '%' // yeah, Windows people are a bit strange ;-)
}
else {
switch ( str[n + 1] ) {
}
else {
switch ( str[n + 1] ) {
- case '(':
- bracket = Bracket_Normal;
+ case '(':
+ bracket = Bracket_Normal;
n++; // skip the bracket
break;
n++; // skip the bracket
break;
- wxLogError("file '%s': unexpected character at line %d (missing ']'?)",
- file.GetName(), n + 1);
+ wxLogError("file '%s': unexpected character %c at line %d.",
+ file.GetName(), *pEnd, n + 1);
continue; // skip this line
}
continue; // skip this line
}
wxString FilterIn(const wxString& str)
{
wxString strResult;
wxString FilterIn(const wxString& str)
{
wxString strResult;
+ strResult.Alloc(str.Len());
bool bQuoted = !str.IsEmpty() && str[0] == '"';
bool bQuoted = !str.IsEmpty() && str[0] == '"';
wxString FilterOut(const wxString& str)
{
wxString strResult;
wxString FilterOut(const wxString& str)
{
wxString strResult;
+ strResult.Alloc(str.Len());
// quoting is necessary to preserve spaces in the beginning of the string
bool bQuote = isspace(str[0]) || str[0] == '"';
// quoting is necessary to preserve spaces in the beginning of the string
bool bQuote = isspace(str[0]) || str[0] == '"';
// Name: textfile.cpp
// Purpose: implementation of wxTextFile class
// Author: Vadim Zeitlin
// Name: textfile.cpp
// Purpose: implementation of wxTextFile class
// Author: Vadim Zeitlin
// Created: 03.04.98
// RCS-ID: $Id$
// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// Created: 03.04.98
// RCS-ID: $Id$
// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// ----------------------------------------------------------------------------
// static variables
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// static variables
// ----------------------------------------------------------------------------
// default type is the native one
const wxTextFile::Type wxTextFile::typeDefault = wxTextFile::
#if defined(__WXMSW__)
// default type is the native one
const wxTextFile::Type wxTextFile::typeDefault = wxTextFile::
#if defined(__WXMSW__)
case Type_Unix: nUnix++; break; \
case Type_Dos: nDos++; break; \
case Type_Mac: nMac++; break; \
case Type_Unix: nUnix++; break; \
case Type_Dos: nDos++; break; \
case Type_Mac: nMac++; break; \
+ default: wxFAIL_MSG("unknown line terminator"); \
wxString str;
char ch, chLast = '\0';
wxString str;
char ch, chLast = '\0';
+ char buf[1024];
+ int n, nRead;
while ( !m_file.Eof() ) {
while ( !m_file.Eof() ) {
- // @@ should really use a buffer for efficiency
- if ( m_file.Read(&ch, sizeof(ch)) == ofsInvalid ) {
- // read error
+ nRead = m_file.Read(buf, WXSIZEOF(buf));
+ if ( nRead == ofsInvalid ) {
+ // read error (error message already given in wxFile::Read)
m_file.Close();
return FALSE;
}
m_file.Close();
return FALSE;
}
#pragma message("wxTextFile::Read() hasn't been tested with Mac files.")
#endif
#pragma message("wxTextFile::Read() hasn't been tested with Mac files.")
#endif
- switch ( ch ) {
- case '\n':
- // Dos/Unix line termination
- m_aLines.Add(str);
- m_aTypes.Add(chLast == '\r' ? Type_Dos : Type_Unix);
- str.Empty();
- chLast = '\n';
- break;
-
- case '\r':
- if ( chLast == '\r' ) {
- // Mac empty line
- m_aLines.Add("");
- m_aTypes.Add(Type_Mac);
- }
- else
- chLast = '\r';
- break;
-
- default:
- if ( chLast == '\r' ) {
- // Mac line termination
+ for ( n = 0; n < nRead; n++ ) {
+ ch = buf[n];
+ switch ( ch ) {
+ case '\n':
+ // Dos/Unix line termination
- m_aTypes.Add(Type_Mac);
- str = ch;
- }
- else {
- // add to the current line
- str += ch;
- }
+ m_aTypes.Add(chLast == '\r' ? Type_Dos : Type_Unix);
+ str.Empty();
+ chLast = '\n';
+ break;
+
+ case '\r':
+ if ( chLast == '\r' ) {
+ // Mac empty line
+ m_aLines.Add("");
+ m_aTypes.Add(Type_Mac);
+ }
+ else
+ chLast = '\r';
+ break;
+
+ default:
+ if ( chLast == '\r' ) {
+ // Mac line termination
+ m_aLines.Add(str);
+ m_aTypes.Add(Type_Mac);
+ str = ch;
+ }
+ else {
+ // add to the current line
+ str += ch;
+ }
+ }
uint nCount = m_aLines.Count();
for ( uint n = 0; n < nCount; n++ ) {
uint nCount = m_aLines.Count();
for ( uint n = 0; n < nCount; n++ ) {
- fileTmp.Write(m_aLines[n] +
+ fileTmp.Write(m_aLines[n] +
GetEOL(typeNew == Type_None ? m_aTypes[n] : typeNew));
}
// replace the old file with this one
return fileTmp.Commit();
GetEOL(typeNew == Type_None ? m_aTypes[n] : typeNew));
}
// replace the old file with this one
return fileTmp.Commit();
-}
\ No newline at end of file