office-gobmx/cosv/source/strings/string.cxx
2011-11-27 15:24:45 -06:00

246 lines
5.2 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org 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 Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#define CSV_USE_CSV_ASSERTIONS
#include <cosv/csv_env.hxx>
#include <cosv/comfunc.hxx>
#include <cosv/string.hxx>
#include <cosv/streamstr.hxx>
#include <cosv/std_outp.hxx>
#include <cosv/tpl/dyn.hxx>
#include <cosv/string.hxx>
// NOT FULLY DECLARED SERVICES
#include <string.h>
#include <cosv/comfunc.hxx>
namespace csv
{
inline const char *
str_from_StringOffset( const String & i_rStr,
str::size i_nOffset )
{
return i_nOffset < i_rStr.size()
? i_rStr.c_str() + i_nOffset
: "";
}
inline const char *
str_from_ptr( const char * i_str )
{
return valid_str(i_str);
}
//********************* String::S_Data **********************//
inline String::
S_Data::S_Data()
: nCount(1)
{
}
String::
S_Data::S_Data( const char * i_sData,
size_type i_nValidLength )
: aStr( str_from_ptr(i_sData),
(i_nValidLength != str::maxsize
? i_nValidLength
: strlen(i_sData)) ),
nCount(1)
{
}
String::
S_Data::~S_Data()
{
csv_assert( nCount == 0 );
}
const String::S_Data *
String::
S_Data::Acquire() const
{
#ifdef CSV_NO_MUTABLE
++ (const_cast< uintt& >(nCount));
#else
++nCount;
#endif
return this;
}
void
String::
S_Data::Release() const
{
#ifdef CSV_NO_MUTABLE
-- (const_cast< uintt& >(nCount));
#else
--nCount;
#endif
if (nCount == 0)
delete (const_cast< S_Data* >(this));
}
//************************** String **************************//
String::String()
: pd( String::Null_().pd->Acquire() )
{
}
String::String( const char * i_str )
: pd( new S_Data(i_str) )
{
}
String::String( const char * i_str,
size_type i_nLength )
: pd( new S_Data(i_str, i_nLength) )
{
}
String::String( const_iterator i_itBegin,
const_iterator i_itEnd )
: pd( new S_Data(i_itBegin, size_type(i_itEnd - i_itBegin)) )
{
}
String::String( const self & i_rStr )
: pd( i_rStr.pd->Acquire() )
{
}
String::~String()
{
pd->Release();
}
String &
String::operator=( const self & i_rStr )
{
i_rStr.pd->Acquire();
pd->Release();
pd = i_rStr.pd;
return *this;
}
String &
String::operator=( const char * i_str )
{
const S_Data *
pTemp = new S_Data(i_str);
pd->Release();
pd = pTemp;
return *this;
}
void
String::assign( const char * i_str,
size_type i_nLength )
{
const S_Data *
pTemp = new S_Data( i_str, i_nLength );
pd->Release();
pd = pTemp;
}
int
String::compare( const self & i_rStr ) const
{
return strcmp( c_str(), i_rStr.c_str() );
}
int
String::compare( const CharOrder_Table & i_rOrder,
const self & i_rStr ) const
{
return csv::compare( i_rOrder, c_str(), i_rStr.c_str() );
}
const String &
String::Null_()
{
// Must not use the default constructor! Because that one calls
// this function, which would create a circular dependency.
static const String aNull_("");
return aNull_;
}
const char &
String::Nulch_()
{
static const char cNull_ = '\0';
return cNull_;
}
int
compare( const String & i_s1,
csv::str::position i_nStartPosition1,
const char * i_s2,
csv::str::size i_nLength )
{
const char * pS1 = str_from_StringOffset( i_s1, i_nStartPosition1 );
if ( i_nLength != csv::str::maxsize )
return strncmp( pS1,
i_s2,
i_nLength );
else
return strcmp( pS1,
i_s2 );
}
int
compare( const CharOrder_Table & i_rOrder,
const char * i_s1,
const char * i_s2 )
{
const char * it1 = i_s1;
const char * it2 = i_s2;
for ( ; i_rOrder(*it1) == i_rOrder(*it2) AND *it1 != '\0'; ++it1, ++it2 )
{}
return int( i_rOrder(*it1) - i_rOrder(*it2) );
}
} // namespace csv
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */