fixed XArchEvalUnix using wrong memeber, string_format using c++11 (which we're not ready for yet), code style (indentation and new lines)

This commit is contained in:
Nick Bolton 2014-03-20 13:34:21 +00:00
parent f9fe1130ac
commit e34e39a41c
3 changed files with 76 additions and 37 deletions

View File

@ -25,8 +25,8 @@
// //
std::string std::string
XArchEvalUnix::eval() const throw() XArchEvalUnix::eval() const
{ {
// FIXME -- not thread safe // FIXME -- not thread safe
return strerror(m_errno); return strerror(m_error);
} }

View File

@ -17,7 +17,7 @@
#include "base/String.h" #include "base/String.h"
#include <memory> #include <stdio.h>
#include <cstdarg> #include <cstdarg>
void void
@ -26,40 +26,37 @@ find_replace_all(
const CString& find, const CString& find,
const CString& replace) const CString& replace)
{ {
size_t pos = 0; size_t pos = 0;
while ((pos = subject.find(find, pos)) != CString::npos) { while ((pos = subject.find(find, pos)) != CString::npos) {
subject.replace(pos, find.length(), replace); subject.replace(pos, find.length(), replace);
pos += replace.length(); pos += replace.length();
} }
} }
CString CString
string_format(const CString format, ...) string_format(const std::string fmt, ...)
{ {
// reserve 2 times as much as the length of the format int size = 100;
size_t final, n = format.size() * 2; std::string str;
va_list ap;
CString str; while (true) {
std::unique_ptr<char[]> formatted; str.resize(size);
va_list ap; va_start(ap, fmt);
int n = vsnprintf((char *)str.c_str(), size, fmt.c_str(), ap);
va_end(ap);
while (true) { if (n > -1 && n < size) {
str.resize(n);
// wrap the plain char array in unique_ptr return str;
formatted.reset(new char[n]); }
if (n > -1) {
strcpy(&formatted[0], format.c_str()); size = n + 1;
va_start(ap, format);
final = vsnprintf(&formatted[0], n, format.c_str(), ap);
va_end(ap);
if (final < 0 || final >= n) {
n += abs(static_cast<int>(final - n + 1));
} }
else { else {
break; size *= 2;
} }
} }
return CString(formatted.get()); return str;
} }

View File

@ -0,0 +1,42 @@
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2014 Bolton Software Ltd.
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "base/String.h"
#include "test/global/gtest.h"
TEST(CStringTests, find_replace_all)
{
CString subject = "foobar";
CString find = "bar";
CString replace = "baz";
find_replace_all(subject, find, replace);
EXPECT_EQ("foobaz", subject);
}
TEST(CStringTests, string_format)
{
CString format = "%s=%d";
const char* arg1 = "answer";
int arg2 = 42;
CString result = string_format(format, arg1, arg2);
EXPECT_EQ("answer=42", result);
}