xref: /AOO41X/main/comphelper/source/misc/sequence.cxx (revision dde7d3faf6dcd9cbeb7b48ba6d0cea5ffcc883d0)
1*dde7d3faSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*dde7d3faSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*dde7d3faSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*dde7d3faSAndrew Rist  * distributed with this work for additional information
6*dde7d3faSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*dde7d3faSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*dde7d3faSAndrew Rist  * "License"); you may not use this file except in compliance
9*dde7d3faSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*dde7d3faSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*dde7d3faSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*dde7d3faSAndrew Rist  * software distributed under the License is distributed on an
15*dde7d3faSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*dde7d3faSAndrew Rist  * KIND, either express or implied.  See the License for the
17*dde7d3faSAndrew Rist  * specific language governing permissions and limitations
18*dde7d3faSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*dde7d3faSAndrew Rist  *************************************************************/
21*dde7d3faSAndrew Rist 
22*dde7d3faSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_comphelper.hxx"
26cdf0e10cSrcweir #include <comphelper/sequence.hxx>
27cdf0e10cSrcweir 
28cdf0e10cSrcweir //.........................................................................
29cdf0e10cSrcweir namespace comphelper
30cdf0e10cSrcweir {
31cdf0e10cSrcweir //.........................................................................
32cdf0e10cSrcweir 
33cdf0e10cSrcweir //------------------------------------------------------------------------------
findValue(const staruno::Sequence<::rtl::OUString> & _rList,const::rtl::OUString & _rValue,sal_Bool _bOnlyFirst)34cdf0e10cSrcweir staruno::Sequence<sal_Int16> findValue(const staruno::Sequence< ::rtl::OUString >& _rList, const ::rtl::OUString& _rValue, sal_Bool _bOnlyFirst)
35cdf0e10cSrcweir {
36cdf0e10cSrcweir 	sal_Int32 nLength = _rList.getLength();
37cdf0e10cSrcweir 
38cdf0e10cSrcweir 	if( _bOnlyFirst )
39cdf0e10cSrcweir 	{
40cdf0e10cSrcweir 		//////////////////////////////////////////////////////////////////////
41cdf0e10cSrcweir 		// An welcher Position finde ich den Wert?
42cdf0e10cSrcweir 		sal_Int32 nPos = -1;
43cdf0e10cSrcweir 		const ::rtl::OUString* pTArray = _rList.getConstArray();
44cdf0e10cSrcweir 		for (sal_Int32 i = 0; i < nLength; ++i, ++pTArray)
45cdf0e10cSrcweir 		{
46cdf0e10cSrcweir 			if( pTArray->equals(_rValue) )
47cdf0e10cSrcweir 			{
48cdf0e10cSrcweir 				nPos = i;
49cdf0e10cSrcweir 				break;
50cdf0e10cSrcweir 			}
51cdf0e10cSrcweir 		}
52cdf0e10cSrcweir 
53cdf0e10cSrcweir 		//////////////////////////////////////////////////////////////////////
54cdf0e10cSrcweir 		// Sequence fuellen
55cdf0e10cSrcweir 		if( nPos>-1 )
56cdf0e10cSrcweir 		{
57cdf0e10cSrcweir 			staruno::Sequence<sal_Int16> aRetSeq( 1 );
58cdf0e10cSrcweir 			aRetSeq.getArray()[0] = (sal_Int16)nPos;
59cdf0e10cSrcweir 
60cdf0e10cSrcweir 			return aRetSeq;
61cdf0e10cSrcweir 		}
62cdf0e10cSrcweir 
63cdf0e10cSrcweir 		return staruno::Sequence<sal_Int16>();
64cdf0e10cSrcweir 
65cdf0e10cSrcweir 	}
66cdf0e10cSrcweir 	else
67cdf0e10cSrcweir 	{
68cdf0e10cSrcweir 		staruno::Sequence<sal_Int16> aRetSeq( nLength );
69cdf0e10cSrcweir 		sal_Int16* pReturn = aRetSeq.getArray();
70cdf0e10cSrcweir 
71cdf0e10cSrcweir 		//////////////////////////////////////////////////////////////////////
72cdf0e10cSrcweir 		// Wie oft kommt der Wert vor?
73cdf0e10cSrcweir 		const ::rtl::OUString* pTArray = _rList.getConstArray();
74cdf0e10cSrcweir 		for (sal_Int32 i = 0; i < nLength; ++i, ++pTArray)
75cdf0e10cSrcweir 		{
76cdf0e10cSrcweir 			if( pTArray->equals(_rValue) )
77cdf0e10cSrcweir 			{
78cdf0e10cSrcweir 				*pReturn = (sal_Int16)i;
79cdf0e10cSrcweir 				++pReturn;
80cdf0e10cSrcweir 			}
81cdf0e10cSrcweir 		}
82cdf0e10cSrcweir 
83cdf0e10cSrcweir 		aRetSeq.realloc(pReturn - aRetSeq.getArray());
84cdf0e10cSrcweir 
85cdf0e10cSrcweir 		return aRetSeq;
86cdf0e10cSrcweir 	}
87cdf0e10cSrcweir }
88cdf0e10cSrcweir // -----------------------------------------------------------------------------
existsValue(const::rtl::OUString & Value,const staruno::Sequence<::rtl::OUString> & _aList)89cdf0e10cSrcweir sal_Bool existsValue(const ::rtl::OUString& Value,const staruno::Sequence< ::rtl::OUString >& _aList)
90cdf0e10cSrcweir {
91cdf0e10cSrcweir     const ::rtl::OUString * pIter	= _aList.getConstArray();
92cdf0e10cSrcweir 	const ::rtl::OUString * pEnd	= pIter + _aList.getLength();
93cdf0e10cSrcweir 	return ::std::find(pIter,pEnd,Value) != pEnd;
94cdf0e10cSrcweir }
95cdf0e10cSrcweir 
96cdf0e10cSrcweir //.........................................................................
97cdf0e10cSrcweir }	// namespace comphelper
98cdf0e10cSrcweir //.........................................................................
99cdf0e10cSrcweir 
100