www.pudn.com > EasySoap++-0.6.1.rar > SOAPString.h


/* 
 * EasySoap++ - A C++ library for SOAP (Simple Object Access Protocol)
 * Copyright (C) 2001 David Crowley; SciTegic, Inc.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Library General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This library 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
 * Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public
 * License along with this library; if not, write to the Free
 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 * $Id: SOAPString.h,v 1.6 2002/05/20 16:56:11 jgorlick Exp $
 */


#ifndef __SOAPSTRING_H__
#define __SOAPSTRING_H__

#ifdef HAVE_WCHAR_H
#include 
#define HAVE_WCHART
#else
#ifdef STDDEF_HAS_WCHART
#include 
#define HAVE_WCHART
#endif
#endif

#include 
#include 

BEGIN_EASYSOAP_NAMESPACE

/**
*
*/
class EASYSOAP_EXPORT SOAPString
{
private:
	char	*m_str;
	size_t	m_alloc;

	void Assign(const char* str)
	{
		if (str)
		{
			if (m_str)
			{
				// try to copy in place
				size_t rem = m_alloc;
				const char *work = str;
				char *dest = m_str;
				while (rem--)
				{
					if ((*dest++ = *work++) == 0)
						return;
				}
				// we didn't have enough room to copy..
				sp_free(m_str);
			}

			// we need to alloc some space
			size_t req = sp_strlen(str) + 1;
			Resize(req);
			sp_strcpy(m_str, str);
		}
		else
			sp_free(m_str);
	}

public:
	// Default constructor
	SOAPString(const char *str = 0) : m_str(0), m_alloc(32)
	{
		Assign(str);
	}

	// Copy constructor
	SOAPString(const SOAPString& str) : m_str(0), m_alloc(32)
	{
		Assign(str.m_str);
	}

#ifdef HAVE_WCHART
	SOAPString(const wchar_t *str) : m_str(0), m_alloc(32)
	{
		Assign(str);
	}
#endif // HAVE_WCHART

	// Destructor
	~SOAPString()
	{
		sp_free(m_str);
	}

	// Assignment operator
	SOAPString& operator=(const SOAPString& str)
	{
		Assign(str.m_str);
		return *this;
	}

	SOAPString& operator=(const char *str)
	{
		Assign(str);
		return *this;
	}

	SOAPString& Append(const char *str)
	{
		return Append(str, sp_strlen(str));
	}

	SOAPString& Append(const char *str, size_t len)
	{
		size_t tlen = sp_strlen(m_str);
		size_t need = tlen + len + 1;
		Resize(need);
		sp_strncpy(m_str + tlen, str, len);
		m_str[need - 1] = 0;
		return *this;
	}

	SOAPString& operator+=(const char *str)
	{
		return Append(str);
	}

	void Resize(size_t size)
	{
		if (!m_str || m_alloc < size)
		{
			while (m_alloc < size)
				m_alloc *= 2;
			char *newstr = sp_alloc(m_alloc);
			if (m_str)
			{
				sp_strcpy(newstr, m_str);
				sp_free(m_str);
			}
			m_str = newstr;
		}
	}

	void Empty()
	{
		if (m_str)
			*m_str = 0;
	}

	const char *Str() const
	{
		return m_str;
	}

	char *Str()
	{
		return m_str;
	}

	bool operator!() const
	{
		return m_str == 0;
	}

	operator bool() const
	{
		return m_str != 0;
	}

	operator const char *() const
	{
		return Str();
	}

	size_t Length() const
	{
		return m_str ? sp_strlen(m_str) : 0;
	}

	bool IsEmpty() const
	{
		return m_str == 0 || *m_str == 0;
	}

	int Compare(const char *str) const
	{
		return sp_strcmp(m_str, str);
	}

	bool operator==(const SOAPString& str) const
	{
		return Compare(str) == 0;
	}

	bool operator==(const char *str) const
	{
		return Compare(str) == 0;
	}

	bool operator!=(const SOAPString& str) const
	{
		return Compare(str) != 0;
	}

	bool operator!=(const char *str) const
	{
		return Compare(str) != 0;
	}

	bool operator<(const SOAPString& str) const
	{
		return Compare(str) < 0;
	}

	bool operator<(const char *str) const
	{
		return Compare(str) < 0;
	}

#ifdef HAVE_WCHART
	void Assign(const wchar_t *str)
	{
		Assign("");
		Append(str);
	}

	void Append(const wchar_t *str)
	{
		if (str)
		{
			char buffer[1024];
			char *b = buffer;
			const char *const end = b + 1000;
			while (*str)
			{
				int c = 0;
#ifdef _WIN32
				sp_UTF16_UCS(str, c);
#else
				c = *str++;
#endif
				sp_UCS_UTF8(c, b);

				if (b >= end)
				{
					*b = 0;
					Append(buffer);
					b = buffer;
				}
			}
			*b = 0;
			Append(buffer);
		}
	}

	SOAPString& operator=(const wchar_t *str)
	{
		Assign(str);
		return *this;
	}

	SOAPString& operator+=(const wchar_t *str)
	{
		Append(str);
		return *this;
	}
#endif // HAVE_WCHART
};

#ifdef __SOAPHASHMAP_H__

/**
*
*/
template <>
struct SOAPHashCodeFunctor
{
	size_t operator()(const SOAPString& str) const
	{
		return sp_hashcode(str);
	}

	size_t operator()(const char *str) const
	{
		return sp_hashcode(str);
	}
};

/**
*
*/
template <>
struct SOAPHashCodeFunctorNoCase
{
	size_t operator()(const SOAPString& str) const
	{
		return sp_hashcodecase(str);
	}

	size_t operator()(const char *str) const
	{
		return sp_hashcodecase(str);
	}
};

/**
*
*/
template <>
struct SOAPEqualsFunctor
{
	bool operator()(const SOAPString& a, const SOAPString& b) const
	{
		return a == b;
	}

	bool operator()(const SOAPString& a, const char *b) const
	{
		return a == b;
	}
};

/**
*
*/
template <>
struct SOAPEqualsFunctorNoCase
{
	bool operator()(const SOAPString& a, const SOAPString& b) const
	{
		return sp_strcasecmp(a, b) == 0;
	}

	bool operator()(const SOAPString& a, const char *b) const
	{
		return sp_strcasecmp(a, b) == 0;
	}
};

#endif // __SOAPHASHMAP_H__

END_EASYSOAP_NAMESPACE

#endif // __SOAPSTRING_H__