/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: string.cxx,v $ * $Revision: 1.5 $ * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #include "precompiled_comphelper.hxx" #include "sal/config.h" #include #include #include #include "comphelper/string.hxx" #include "rtl/ustring.hxx" #include "sal/types.h" namespace comphelper { namespace string { rtl::OUString searchAndReplaceAsciiL( rtl::OUString const & source, char const * from, sal_Int32 fromLength, rtl::OUString const & to, sal_Int32 beginAt, sal_Int32 * replacedAt) { sal_Int32 n = source.indexOfAsciiL(from, fromLength, beginAt); if (replacedAt != NULL) { *replacedAt = n; } return n == -1 ? source : source.replaceAt(n, fromLength, to); } COMPHELPER_DLLPUBLIC ::rtl::OUString& searchAndReplaceAsciiI( ::rtl::OUString & _source, sal_Char const * _asciiPattern, ::rtl::OUString const & _replace, sal_Int32 _beginAt, sal_Int32 * _replacedAt ) { sal_Int32 fromLength = strlen( _asciiPattern ); sal_Int32 n = _source.indexOfAsciiL( _asciiPattern, fromLength, _beginAt ); if ( _replacedAt != NULL ) *_replacedAt = n; if ( n != -1 ) _source = _source.replaceAt( n, fromLength, _replace ); return _source; } // convert between sequence of string and comma separated string ::rtl::OUString convertCommaSeparated( ::com::sun::star::uno::Sequence< ::rtl::OUString > const& i_rSeq) { ::rtl::OUString ret; for (sal_Int32 i = 0; i < i_rSeq.getLength(); ++i) { if (i != 0) ret += ::rtl::OUString::createFromAscii(", "); ret += i_rSeq[i]; } return ret; } ::com::sun::star::uno::Sequence< ::rtl::OUString > convertCommaSeparated( ::rtl::OUString const& i_rString ) { std::vector< ::rtl::OUString > vec; sal_Int32 idx = 0; do { ::rtl::OUString kw = i_rString.getToken(0, static_cast (','), idx); kw = kw.trim(); if (kw.getLength() > 0) { vec.push_back(kw); } } while (idx >= 0); ::com::sun::star::uno::Sequence< ::rtl::OUString > kws(vec.size()); for (size_t i = 0; i < vec.size(); ++i) { kws[i] = vec.at(i); } return kws; } } }