2002-08-02 19:57:46 +00:00
|
|
|
/*
|
|
|
|
* synergy -- mouse and keyboard sharing utility
|
|
|
|
* Copyright (C) 2002 Chris Schoeneman
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2001-10-06 14:13:28 +00:00
|
|
|
#ifndef CSTRING_H
|
|
|
|
#define CSTRING_H
|
|
|
|
|
2002-07-25 17:23:35 +00:00
|
|
|
#include <stdarg.h>
|
2002-06-01 19:26:11 +00:00
|
|
|
#include "stdpre.h"
|
2001-10-06 14:13:28 +00:00
|
|
|
#include <string>
|
2002-06-01 19:26:11 +00:00
|
|
|
#include "stdpost.h"
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
// use standard C++ string class for our string class
|
2002-06-10 22:06:45 +00:00
|
|
|
typedef std::string CString;
|
2001-10-06 14:13:28 +00:00
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! String utilities
|
|
|
|
/*!
|
|
|
|
This class provides various functions for string manipulation.
|
|
|
|
*/
|
2002-06-03 16:34:22 +00:00
|
|
|
class CStringUtil {
|
|
|
|
public:
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Format positional arguments
|
|
|
|
/*!
|
|
|
|
Format a string using positional arguments. fmt has literal
|
|
|
|
characters and conversion specifications introduced by `\%':
|
|
|
|
- \c\%\% -- literal `\%'
|
|
|
|
- \c\%{n} -- positional element n, n a positive integer, {} are literal
|
|
|
|
|
|
|
|
All arguments in the variable list are const char*. Positional
|
|
|
|
elements are indexed from 1.
|
|
|
|
*/
|
2002-07-25 17:23:35 +00:00
|
|
|
static CString format(const char* fmt, ...);
|
2002-07-26 18:28:18 +00:00
|
|
|
|
|
|
|
//! Format positional arguments
|
|
|
|
/*!
|
|
|
|
Same as format() except takes va_list.
|
|
|
|
*/
|
2002-07-25 17:23:35 +00:00
|
|
|
static CString vformat(const char* fmt, va_list);
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Print a string using printf-style formatting
|
|
|
|
/*!
|
|
|
|
Equivalent to printf() except the result is returned as a CString.
|
|
|
|
*/
|
2002-07-25 17:23:35 +00:00
|
|
|
static CString print(const char* fmt, ...);
|
2002-07-26 18:28:18 +00:00
|
|
|
|
|
|
|
//! Print a string using printf-style formatting
|
|
|
|
/*!
|
|
|
|
Same as print() except takes va_list.
|
|
|
|
*/
|
2002-07-25 17:23:35 +00:00
|
|
|
static CString vprint(const char* fmt, va_list);
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Print a string using printf-style formatting into a buffer
|
|
|
|
/*!
|
|
|
|
This is like print but print into a given buffer. If the resulting
|
|
|
|
string will not fit into \c buffer then a new buffer is allocated and
|
|
|
|
returned, otherwise \c buffer is returned. the caller must delete[]
|
|
|
|
the returned memory if is not \c buffer.
|
|
|
|
|
|
|
|
\c prefix and \c suffix must be >= 0. Exactly \c prefix characters and
|
|
|
|
at least \c suffix characters are available in the buffer before
|
|
|
|
and after the printed string, respectively. \c bufferLength is the
|
|
|
|
length of buffer and should not be adjusted by the caller to
|
|
|
|
account for \c prefix or \c suffix.
|
|
|
|
*/
|
2002-07-25 17:23:35 +00:00
|
|
|
static char* vsprint(char* buffer, int bufferLength,
|
|
|
|
int prefix, int suffix, const char* fmt, va_list);
|
|
|
|
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Case-insensitive comparisons
|
|
|
|
/*!
|
|
|
|
This class provides case-insensitve comparison functions.
|
|
|
|
*/
|
2002-06-03 16:34:22 +00:00
|
|
|
class CaselessCmp {
|
|
|
|
public:
|
2002-07-26 18:28:18 +00:00
|
|
|
//! Same as less()
|
|
|
|
bool operator()(const CString& a, const CString& b) const;
|
|
|
|
|
|
|
|
//! Returns true iff \c a is lexicographically less than \c b
|
|
|
|
static bool less(const CString& a, const CString& b);
|
|
|
|
|
|
|
|
//! Returns true iff \c a is lexicographically equal to \c b
|
|
|
|
static bool equal(const CString& a, const CString& b);
|
|
|
|
|
|
|
|
//! Returns true iff \c a is lexicographically less than \c b
|
|
|
|
static bool cmpLess(const CString::value_type& a,
|
|
|
|
const CString::value_type& b);
|
|
|
|
|
|
|
|
//! Returns true iff \c a is lexicographically equal to \c b
|
|
|
|
static bool cmpEqual(const CString::value_type& a,
|
|
|
|
const CString::value_type& b);
|
2002-06-03 16:34:22 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2001-10-06 14:13:28 +00:00
|
|
|
#endif
|
|
|
|
|