/************************************************************************* * * $RCSfile: langbox.cxx,v $ * * $Revision: 1.13 $ * * last change: $Author: vg $ $Date: 2003-04-17 09:57:31 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses * * - GNU Lesser General Public License Version 2.1 * - Sun Industry Standards Source License Version 1.1 * * Sun Microsystems Inc., October, 2000 * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2000 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * * Sun Industry Standards Source License Version 1.1 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.1 (the "License"); You may not use this file * except in compliance with the License. You may obtain a copy of the * License at http://www.openoffice.org/license.html. * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2000 by Sun Microsystems, Inc. * * All Rights Reserved. * * Contributor(s): _______________________________________ * * ************************************************************************/ // include --------------------------------------------------------------- #ifndef _COM_SUN_STAR_LINGUISTIC2_XLINGUSERVICEMANAGER_HDL_ #include #endif #ifndef _COM_SUN_STAR_LINGUISTIC2_XAVAILABLELOCALES_HPP_ #include #endif #ifndef _LINGUISTIC_MISC_HXX_ #include #endif #ifndef _RTL_USTRING_HXX_ #include #endif #ifndef _UNOTOOLS_LOCALEDATAWRAPPER_HXX #include #endif #ifndef _SHL_HXX #include #endif #ifndef _ISOLANG_HXX #include #endif #pragma hdrstop #ifndef _SVX_SCRIPTTYPEITEM_HXX #include #endif #ifndef _UNO_LINGU_HXX #include #endif #ifndef _SVX_LANGTAB_HXX #include #endif #include "langbox.hxx" #include "langtab.hxx" #include "dialmgr.hxx" #include "dialogs.hrc" #include "unolingu.hxx" using namespace ::rtl; using namespace ::com::sun::star::util; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::linguistic2; using namespace ::com::sun::star::uno; #define A2OU(x) OUString::createFromAscii( x ) //======================================================================== // list of languages for forbidden chars //======================================================================== static const LanguageType aForbiddenCharLang[] = { LANGUAGE_CHINESE_TRADITIONAL, LANGUAGE_CHINESE_SIMPLIFIED, LANGUAGE_JAPANESE, LANGUAGE_KOREAN }; static const int nForbiddenCharLang = sizeof( aForbiddenCharLang ) / sizeof( aForbiddenCharLang[0] ); static BOOL lcl_HasLanguage( const LanguageType *pLang, int nCount, LanguageType nLang ) { int i = -1; if (pLang && nCount > 0) { for (i = 0; i < nCount; ++i ) { if (pLang[i] == nLang) break; } } return i >= 0 && i < nCount; } //======================================================================== // misc local helper functions //======================================================================== static Sequence< INT16 > lcl_LocaleSeqToLangSeq( Sequence< Locale > &rSeq ) { const Locale *pLocale = rSeq.getConstArray(); INT32 nCount = rSeq.getLength(); Sequence< INT16 > aLangs( nCount ); INT16 *pLang = aLangs.getArray(); for (INT32 i = 0; i < nCount; ++i) { pLang[i] = SvxLocaleToLanguage( pLocale[i] ); } return aLangs; } static BOOL lcl_SeqHasLang( const Sequence< INT16 > & rLangSeq, INT16 nLang ) { INT32 i = -1; INT32 nLen = rLangSeq.getLength(); if (nLen) { const INT16 *pLang = rLangSeq.getConstArray(); for (i = 0; i < nLen; ++i) { if (nLang == pLang[i]) break; } } return i >= 0 && i < nLen; } //======================================================================== // class SvxLanguageBox //======================================================================== USHORT TypeToPos_Impl( LanguageType eType, const ListBox& rLb ) { USHORT nPos = LISTBOX_ENTRY_NOTFOUND; USHORT nCount = rLb.GetEntryCount(); for ( USHORT i=0; nPos == LISTBOX_ENTRY_NOTFOUND && i aSpellAvailLang; Sequence< INT16 > aHyphAvailLang; Sequence< INT16 > aThesAvailLang; Sequence< INT16 > aSpellUsedLang; Sequence< INT16 > aHyphUsedLang; Sequence< INT16 > aThesUsedLang; Reference< XAvailableLocales > xAvail( LinguMgr::GetLngSvcMgr(), UNO_QUERY ); if (xAvail.is()) { Sequence< Locale > aTmp; if (LANG_LIST_SPELL_AVAIL & nLangList) { aTmp = xAvail->getAvailableLocales( A2OU( SN_SPELLCHECKER ) ); aSpellAvailLang = lcl_LocaleSeqToLangSeq( aTmp ); } if (LANG_LIST_HYPH_AVAIL & nLangList) { aTmp = xAvail->getAvailableLocales( A2OU( SN_HYPHENATOR ) ); aHyphAvailLang = lcl_LocaleSeqToLangSeq( aTmp ); } if (LANG_LIST_THES_AVAIL & nLangList) { aTmp = xAvail->getAvailableLocales( A2OU( SN_THESAURUS ) ); aThesAvailLang = lcl_LocaleSeqToLangSeq( aTmp ); } } if (LANG_LIST_SPELL_USED & nLangList) { Reference< XSpellChecker1 > xTmp1( SvxGetSpellChecker(), UNO_QUERY ); if (xTmp1.is()) aSpellUsedLang = xTmp1->getLanguages(); } if (LANG_LIST_HYPH_USED & nLangList) { Reference< XHyphenator > xTmp( SvxGetHyphenator() ); if (xTmp.is()) { Sequence < Locale > aLocaleSequence( xTmp->getLocales() ); aHyphUsedLang = lcl_LocaleSeqToLangSeq( aLocaleSequence ); } } if (LANG_LIST_THES_USED & nLangList) { Reference< XThesaurus > xTmp( SvxGetThesaurus() ); if (xTmp.is()) { Sequence < Locale > aLocaleSequence( xTmp->getLocales() ); aThesUsedLang = lcl_LocaleSeqToLangSeq( aLocaleSequence ); } } SvxLanguageTable aLangTable; ::com::sun::star::uno::Sequence< sal_uInt16 > xKnown; const sal_uInt16* pKnown; USHORT nCount; if ( nLangList & LANG_LIST_ONLY_KNOWN ) { xKnown = LocaleDataWrapper::getInstalledLanguageTypes(); pKnown = xKnown.getConstArray(); nCount = (USHORT) xKnown.getLength(); } else { nCount = aLangTable.GetEntryCount(); pKnown = NULL; } for ( USHORT i = 0; i < nCount; i++ ) { LanguageType nLangType; if ( nLangList & LANG_LIST_ONLY_KNOWN ) nLangType = pKnown[i]; else nLangType = aLangTable.GetTypeAtIndex( i ); BOOL bInsert = FALSE; if ( nLangType != LANGUAGE_DONTKNOW && nLangType != LANGUAGE_SYSTEM && nLangType != LANGUAGE_NONE && !(LANGUAGE_USER1 <= nLangType && nLangType <= LANGUAGE_USER9) ) { if (!bInsert && (nLangList & LANG_LIST_ALL)) bInsert |= TRUE; if (!bInsert && (nLangList & LANG_LIST_WESTERN)) bInsert |= SCRIPTTYPE_LATIN == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType ); if (!bInsert && (nLangList & LANG_LIST_CTL)) bInsert |= SCRIPTTYPE_COMPLEX == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType ); if (!bInsert && (nLangList & LANG_LIST_CJK)) bInsert |= SCRIPTTYPE_ASIAN == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType ); if (!bInsert && (nLangList & LANG_LIST_FBD_CHARS)) bInsert |= lcl_HasLanguage( aForbiddenCharLang, nForbiddenCharLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_SPELL_AVAIL)) bInsert |= lcl_SeqHasLang( aSpellAvailLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_HYPH_AVAIL)) bInsert |= lcl_SeqHasLang( aHyphAvailLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_THES_AVAIL)) bInsert |= lcl_SeqHasLang( aThesAvailLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_SPELL_USED)) bInsert |= lcl_SeqHasLang( aSpellUsedLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_HYPH_USED)) bInsert |= lcl_SeqHasLang( aHyphUsedLang, nLangType ); if (!bInsert && (nLangList & LANG_LIST_THES_USED)) bInsert |= lcl_SeqHasLang( aThesUsedLang, nLangType ); } if (bInsert) InsertLanguage( nLangType ); } if (bHasLangNone) InsertLanguage( LANGUAGE_NONE ); } } //------------------------------------------------------------------------ USHORT SvxLanguageBox::InsertLanguage( const LanguageType nLangType, USHORT nPos ) { String aStrEntry = m_pLangTable->GetString( nLangType ); if (LANGUAGE_NONE == nLangType && m_bHasLangNone && m_bLangNoneIsLangAll) aStrEntry = m_aAllString; USHORT nAt = 0; if ( m_bWithCheckmark ) { sal_Bool bFound = sal_False; if (!m_pSpellUsedLang) { Reference< XSpellChecker1 > xSpell( SvxGetSpellChecker(), UNO_QUERY ); if ( xSpell.is() ) m_pSpellUsedLang = new Sequence< INT16 >( xSpell->getLanguages() ); } bFound = m_pSpellUsedLang ? lcl_SeqHasLang( *m_pSpellUsedLang, nLangType ) : FALSE; nAt = ImplInsertImgEntry( aStrEntry, nPos, bFound ); } else nAt = InsertEntry( aStrEntry, nPos ); SetEntryData( nAt, (void*)(ULONG)nLangType ); return nPos; } //------------------------------------------------------------------------ USHORT SvxLanguageBox::InsertLanguage( const LanguageType nLangType, BOOL bCheckEntry, USHORT nPos ) { String aStrEntry = m_pLangTable->GetString( nLangType ); if (LANGUAGE_NONE == nLangType && m_bHasLangNone && m_bLangNoneIsLangAll) aStrEntry = m_aAllString; USHORT nAt = ImplInsertImgEntry( aStrEntry, nPos, bCheckEntry ); SetEntryData( nAt, (void*)(ULONG)nLangType ); return nPos; } //------------------------------------------------------------------------ void SvxLanguageBox::RemoveLanguage( const LanguageType eLangType ) { USHORT nAt = TypeToPos_Impl( eLangType, *this ); if ( nAt != LISTBOX_ENTRY_NOTFOUND ) RemoveEntry( nAt ); } //------------------------------------------------------------------------ LanguageType SvxLanguageBox::GetSelectLanguage() const { LanguageType eType = LanguageType(LANGUAGE_DONTKNOW); USHORT nPos = GetSelectEntryPos(); if ( nPos != LISTBOX_ENTRY_NOTFOUND ) return LanguageType( (ULONG)GetEntryData(nPos) ); else return LanguageType( LANGUAGE_DONTKNOW ); } //------------------------------------------------------------------------ void SvxLanguageBox::SelectLanguage( const LanguageType eLangType, BOOL bSelect ) { USHORT nAt = TypeToPos_Impl( eLangType, *this ); if ( nAt != LISTBOX_ENTRY_NOTFOUND ) SelectEntryPos( nAt, bSelect ); } //------------------------------------------------------------------------ BOOL SvxLanguageBox::IsLanguageSelected( const LanguageType eLangType ) const { USHORT nAt = TypeToPos_Impl( eLangType, *this ); if ( nAt != LISTBOX_ENTRY_NOTFOUND ) return IsEntryPosSelected( nAt ); else return FALSE; }