Files
libreoffice/xmloff/source/core/i18nmap.cxx

127 lines
3.5 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2000-09-18 23:31:44 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 23:31:44 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 23:31:44 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 23:31:44 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 23:31:44 +00:00
*
* 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.
2000-09-18 23:31:44 +00:00
*
* 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).
2000-09-18 23:31:44 +00:00
*
* 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.
2000-09-18 23:31:44 +00:00
*
************************************************************************/
#include <rtl/ustring.hxx>
#include <tools/debug.hxx>
#include <svl/svarray.hxx>
#include "xmloff/i18nmap.hxx"
2000-09-18 23:31:44 +00:00
2011-02-26 22:39:23 +01:00
using ::rtl::OUString;
2000-09-18 23:31:44 +00:00
class SvI18NMapEntry_Impl
{
sal_uInt16 nKind;
2000-09-18 23:31:44 +00:00
OUString aName;
OUString aNewName;
public:
const OUString& GetNewName() const { return aNewName; }
SvI18NMapEntry_Impl( sal_uInt16 nKnd, const OUString& rName,
2000-09-18 23:31:44 +00:00
const OUString& rNewName ) :
nKind( nKnd ),
aName( rName ),
aNewName( rNewName )
{}
SvI18NMapEntry_Impl( sal_uInt16 nKnd, const OUString& rName ) :
2000-09-18 23:31:44 +00:00
nKind( nKnd ),
aName( rName )
{}
sal_Bool operator==( const SvI18NMapEntry_Impl& r ) const
2000-09-18 23:31:44 +00:00
{
return nKind == r.nKind &&
aName == r.aName;
}
sal_Bool operator<( const SvI18NMapEntry_Impl& r ) const
2000-09-18 23:31:44 +00:00
{
return nKind < r.nKind ||
( nKind == r.nKind &&
aName < r.aName);
}
};
typedef SvI18NMapEntry_Impl *SvI18NMapEntry_ImplPtr;
SV_DECL_PTRARR_SORT_DEL( SvI18NMap_Impl, SvI18NMapEntry_ImplPtr, 20 )
2000-09-18 23:31:44 +00:00
SV_IMPL_OP_PTRARR_SORT( SvI18NMap_Impl, SvI18NMapEntry_ImplPtr )
// ---------------------------------------------------------------------
SvI18NMapEntry_Impl *SvI18NMap::_Find( sal_uInt16 nKind,
2000-09-18 23:31:44 +00:00
const OUString& rName ) const
{
SvI18NMapEntry_Impl *pRet = 0;
SvI18NMapEntry_Impl aTst( nKind, rName );
sal_uInt16 nPos;
2000-09-18 23:31:44 +00:00
if( pImpl->Seek_Entry( &aTst, &nPos ) )
{
pRet = (*pImpl)[nPos];
}
return pRet;
}
SvI18NMap::SvI18NMap() :
pImpl( 0 )
{
pImpl = new SvI18NMap_Impl;
}
SvI18NMap::~SvI18NMap()
{
delete pImpl;
}
void SvI18NMap::Add( sal_uInt16 nKind, const OUString& rName,
2000-09-18 23:31:44 +00:00
const OUString& rNewName )
{
SvI18NMapEntry_Impl *pEntry = _Find( nKind, rName );
DBG_ASSERT( !pEntry, "SvI18NMap::Add: item registered already" );
if( !pEntry )
{
pEntry = new SvI18NMapEntry_Impl( nKind, rName, rNewName );
pImpl->Insert( pEntry );
}
}
const OUString& SvI18NMap::Get( sal_uInt16 nKind, const OUString& rName ) const
2000-09-18 23:31:44 +00:00
{
SvI18NMapEntry_Impl *pEntry = _Find( nKind, rName );
if( pEntry )
return pEntry->GetNewName();
else
return rName;
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */