diff options
author | Thomas Lange <tl@openoffice.org> | 2001-03-19 13:52:48 +0000 |
---|---|---|
committer | Thomas Lange <tl@openoffice.org> | 2001-03-19 13:52:48 +0000 |
commit | e6897a638e6d93aa47a428060a1168a8e7b95a35 (patch) | |
tree | 2f08cce8d489c368e3ad233c35fc79800cbe78c6 /linguistic | |
parent | 375a281f2b847dfcd2a104a909232036bf4f1725 (diff) |
#81069 nDicVersion member added to DictionaryNeo; global functions GetDicVersion and GetDicExtension added
Diffstat (limited to 'linguistic')
-rw-r--r-- | linguistic/source/dicimp.cxx | 62 | ||||
-rw-r--r-- | linguistic/source/dicimp.hxx | 8 |
2 files changed, 57 insertions, 13 deletions
diff --git a/linguistic/source/dicimp.cxx b/linguistic/source/dicimp.cxx index 2bd4cb9a1b3d..8c9b0171df90 100644 --- a/linguistic/source/dicimp.cxx +++ b/linguistic/source/dicimp.cxx @@ -2,9 +2,9 @@ * * $RCSfile: dicimp.cxx,v $ * - * $Revision: 1.5 $ + * $Revision: 1.6 $ * - * last change: $Author: tl $ $Date: 2000-12-11 17:41:04 $ + * last change: $Author: tl $ $Date: 2001-03-19 14:52:48 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -122,9 +122,29 @@ using namespace linguistic; #define BUFSIZE 256 #define VERS2_NOLANGUAGE 1024 -static const sal_Char* aIntExt = "int"; -static const sal_Char* aVerStr2 = "WBSWG2"; -static const sal_Char* aVerStr5 = "WBSWG5"; +static const sal_Char* pDicExt = "dic"; +static const sal_Char* pVerStr2 = "WBSWG2"; +static const sal_Char* pVerStr5 = "WBSWG5"; +static const sal_Char* pVerStr6 = "WBSWG6"; + +int GetDicVersion( const sal_Char *pVerStr ) +{ + if (pVerStr) + { + if (0 == strcmp( pVerStr, pVerStr6 )) + return 6; + if (0 == strcmp( pVerStr, pVerStr5 )) + return 5; + if (0 == strcmp( pVerStr, pVerStr2 )) + return 2; + } + return -1; +} + +const String GetDicExtension() +{ + return String::CreateFromAscii( pDicExt ); +} /////////////////////////////////////////////////////////////////////////// @@ -134,6 +154,7 @@ DictionaryNeo::DictionaryNeo() : nLanguage (LANGUAGE_NONE) { nCount = 0; + nDicVersion = -1; bNeedEntries = FALSE; bIsModified = bIsActive = FALSE; bIsReadonly = FALSE; @@ -149,6 +170,7 @@ DictionaryNeo::DictionaryNeo(const OUString &rName, aMainURL (rMainURL) { nCount = 0; + nDicVersion = -1; bNeedEntries = TRUE; bIsModified = bIsActive = FALSE; @@ -167,6 +189,9 @@ DictionaryNeo::DictionaryNeo(const OUString &rName, } if (!bExists) { + // save new dictionaries with in 6.0 Format (uses UTF8) + nDicVersion = 6; + //! create physical representation of an **empty** dictionary //! that could be searched for (see DicList::searchForDictionaries) // (Note: empty dictionaries are not just empty files!) @@ -235,9 +260,15 @@ ULONG DictionaryNeo::loadEntries(const OUString &rMainURL) return nErr; *(aWordBuf + nLen) = 0; - // Version 2.0 ? - if(!strcmp(aWordBuf, aVerStr2) || - !strcmp(aWordBuf, aVerStr5) ) + nDicVersion = GetDicVersion( aWordBuf ); + + rtl_TextEncoding eEnc = RTL_TEXTENCODING_MS_1252; + if (6 == nDicVersion) + eEnc = RTL_TEXTENCODING_UTF8; + + if (6 == nDicVersion || + 5 == nDicVersion || + 2 == nDicVersion) { bSkip = TRUE; // Sprache des Dictionaries @@ -281,7 +312,7 @@ ULONG DictionaryNeo::loadEntries(const OUString &rMainURL) if(*aWordBuf) { ByteString aDummy( aWordBuf ); - String aText( aDummy, RTL_TEXTENCODING_MS_1252 ); + String aText( aDummy, eEnc ); Reference< XDictionaryEntry > xEntry = new DicEntry( aText, bNegativ ); addEntry_Impl( xEntry , TRUE ); //! don't launch events here @@ -339,7 +370,12 @@ ULONG DictionaryNeo::saveEntries(const OUString &rURL) sal_Char aWordBuf[BUFSIZE]; // write version - strcpy( aWordBuf, eDicType == DictionaryType_POSITIVE ? aVerStr2 : aVerStr5 ); + const sal_Char *pVerStr = NULL; + if (6 == nDicVersion) + pVerStr = pVerStr6; + else + pVerStr = eDicType == DictionaryType_POSITIVE ? pVerStr2 : pVerStr5; + strcpy( aWordBuf, pVerStr ); USHORT nLen = strlen( aWordBuf ); *pStream << nLen; if ((nErr = pStream->GetError())) @@ -355,11 +391,15 @@ ULONG DictionaryNeo::saveEntries(const OUString &rURL) if ((nErr = pStream->GetError())) return nErr; + rtl_TextEncoding eEnc = GetTextEncoding(); + if (6 == nDicVersion) + eEnc = RTL_TEXTENCODING_UTF8; + const Reference< XDictionaryEntry > *pEntry = aEntries.getConstArray(); for (INT32 i = 0; i < nCount; i++) { BOOL bIsNegativEntry = pEntry[i]->isNegative(); - rtl_TextEncoding eEnc = GetTextEncoding(); + ByteString aTmp1 ( pEntry[i]->getDictionaryWord().getStr(), eEnc ), aTmp2 ( pEntry[i]->getReplacementText().getStr(), eEnc ); if (bIsNegativEntry) diff --git a/linguistic/source/dicimp.hxx b/linguistic/source/dicimp.hxx index 76e87000d1b2..ff4e928b3723 100644 --- a/linguistic/source/dicimp.hxx +++ b/linguistic/source/dicimp.hxx @@ -2,9 +2,9 @@ * * $RCSfile: dicimp.hxx,v $ * - * $Revision: 1.2 $ + * $Revision: 1.3 $ * - * last change: $Author: tl $ $Date: 2000-12-01 18:58:41 $ + * last change: $Author: tl $ $Date: 2001-03-19 14:51:06 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -86,6 +86,9 @@ #define DIC_MAX_ENTRIES 2000 +int GetDicVersion( const sal_Char *pVerStr ); +const String GetDicExtension(); + /////////////////////////////////////////////////////////////////////////// class DictionaryNeo : @@ -106,6 +109,7 @@ class DictionaryNeo : ::com::sun::star::linguistic2::DictionaryType eDicType; INT16 nCount; INT16 nLanguage; + INT16 nDicVersion; BOOL bNeedEntries; BOOL bIsModified; BOOL bIsActive; |