/************************************************************************* * * 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: merge.cxx,v $ * $Revision: 1.29 $ * * 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. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_transex3.hxx" #include #include #include "export.hxx" #include "utf8conv.hxx" #include using namespace std; extern void ConvertHalfwitdhToFullwidth( String& rString ); // // class PFormEntrys // ByteString PFormEntrys::Dump(){ ByteString sRet( "PFormEntrys\n" ); //sRet.Append( Export::DumpMap( ByteString("sText") , sText ) ); //sRet.Append("\n"); ByteString a("sText"); if ( sText.size() ) Export::DumpMap( a , sText ); return sRet; } /*****************************************************************************/ BOOL PFormEntrys::GetText( ByteString &rReturn, USHORT nTyp, const ByteString &nLangIndex, BOOL bDel ) /*****************************************************************************/ { /*printf("DBG: PFormEntrys::GetText(nId=%s)\n",nLangIndex.GetBuffer() ); // DEBUG****************** ByteStringHashMap::const_iterator idbg; std::cout << "HASHKEYS : \n"; for( idbg = sText.begin() ; idbg != sText.end(); ++idbg ) std::cout << (idbg->first).GetBuffer() << "\n"; std::cout << "\n\n"; std::cout << "String sText[ nLangIndex ] = " << sText[ nLangIndex ].GetBuffer() << "\n"; // DEBUG****************** */ BOOL bReturn=TRUE; switch ( nTyp ) { case STRING_TYP_TEXT : rReturn = sText[ nLangIndex ]; if ( bDel ) sText[ nLangIndex ] = ""; bReturn = bTextFirst[ nLangIndex ]; bTextFirst[ nLangIndex ] = FALSE; break; case STRING_TYP_HELPTEXT : rReturn = sHelpText; break; case STRING_TYP_QUICKHELPTEXT : rReturn = sQuickHelpText[ nLangIndex ]; if ( bDel ) sQuickHelpText[ nLangIndex ] = ""; bReturn = bQuickHelpTextFirst[ nLangIndex ]; bQuickHelpTextFirst[ nLangIndex ] = FALSE; break; case STRING_TYP_TITLE : rReturn = sTitle[ nLangIndex ]; if ( bDel ) sTitle[ nLangIndex ] = ""; bReturn = bTitleFirst[ nLangIndex ]; bTitleFirst[ nLangIndex ] = FALSE; break; } //printf("Returning '%s'\n",rReturn.GetBuffer()); return bReturn; } // // class MergeData // /*****************************************************************************/ MergeData::~MergeData() /*****************************************************************************/ { } /*****************************************************************************/ PFormEntrys* MergeData::GetPFormEntrys( ResData *pResData ) /*****************************************************************************/ { (void) pResData; // FIXME if( aMap.find( ByteString("HACK") ) != aMap.end() ){ return aMap[ ByteString("HACK") ]; } else{ return 0; } } void MergeData::Insert( const ByteString& rPFO , PFormEntrys* pfEntrys ){ (void) rPFO; // FIXME aMap.insert( PFormEntrysHashMap::value_type( ByteString("HACK") , pfEntrys ) ); } ByteString MergeData::Dump(){ ByteString sRet( "MergeData\n" ); printf("MergeData sTyp = %s , sGid = %s , sLid =%s , sFilename = %s\n",sTyp.GetBuffer(),sGID.GetBuffer(),sLID.GetBuffer(), sFilename.GetBuffer() ); PFormEntrysHashMap::const_iterator idbg; for( idbg = aMap.begin() ; idbg != aMap.end(); ++idbg ){ printf("aMap[ %s ] = " ,idbg->first.GetBuffer()); ( (PFormEntrys*)(idbg->second) )->Dump(); printf("\n") ; } printf("\n") ; return sRet; } PFormEntrys* MergeData::GetPFObject( const ByteString& rPFO ){ if( aMap.find( ByteString("HACK") ) != aMap.end() ){ return aMap[ rPFO ]; } else{ return 0; } } /*****************************************************************************/ PFormEntrys *MergeData::InsertEntry( const ByteString &rPForm ) /*****************************************************************************/ { PFormEntrys* pFEntrys = new PFormEntrys( rPForm ); aMap.insert( PFormEntrysHashMap::value_type( rPForm , pFEntrys ) ); return pFEntrys; } /*****************************************************************************/ BOOL MergeData::operator==( ResData *pData ) /*****************************************************************************/ { ByteString sResTyp_upper( pData->sResTyp ); sResTyp_upper.ToUpperAscii(); ByteString sTyp_upper( sTyp ); sTyp_upper.ToUpperAscii(); return (( pData->sId == sLID ) && ( pData->sGId == sGID ) && ( sResTyp_upper == sTyp_upper ) ); } // // class MergeDataFile // #define FFORMAT_UNKNOWN 0x0000 #define FFORMAT_NEW 0x0001 #define FFORMAT_OLD 0x0002 /*****************************************************************************/ MergeDataFile::MergeDataFile( const ByteString &rFileName, const ByteString& sFile ,BOOL bErrLog, // CharSet aCharSet, BOOL bUTF8 , bool bCaseSensitive ) CharSet aCharSet, bool bCaseSensitive ) /*****************************************************************************/ : bErrorLog( bErrLog ) { SvFileStream aInputStream( String( rFileName, RTL_TEXTENCODING_ASCII_US ), STREAM_STD_READ ); aInputStream.SetStreamCharSet( aCharSet ); ByteString sLine; // printf("\nReading localize.sdf ...\n"); ByteString sTYP; ByteString sGID; ByteString sLID; ByteString sPFO; ByteString nLANG; ByteString sTEXT; ByteString sQHTEXT; ByteString sTITLE; const ByteString sEmpty(""); if( !aInputStream.IsOpen() ) { printf("ERROR : Can't open %s\n", rFileName.GetBuffer()); exit( -1 ); } while ( !aInputStream.IsEof()) { aInputStream.ReadLine( sLine ); sLine = sLine.Convert( RTL_TEXTENCODING_MS_1252, aCharSet ); if ( sLine.GetTokenCount( '\t' ) == 15 ) { // Skip all wrong filenames ByteString filename = sLine.GetToken( 1 , '\t' ); filename = filename.Copy( filename.SearchCharBackward( "\\" )+1 , filename.Len() ); if( sFile.Equals( sEmpty ) || ( !sFile.Equals( sEmpty ) && filename.Equals( sFile ) ) ) { sTYP = sLine.GetToken( 3, '\t' ); sGID = sLine.GetToken( 4, '\t' ); sLID = sLine.GetToken( 5, '\t' ); sPFO = sLine.GetToken( 7, '\t' ); sPFO = ByteString("HACK"); nLANG = sLine.GetToken( 9, '\t' ); sTEXT = sLine.GetToken( 10, '\t' ); // printf("%s\n",sTEXT.GetBuffer()); // Quote( sTEXT ); // printf("%s\n",sTEXT.GetBuffer()); sQHTEXT = sLine.GetToken( 12, '\t' ); sTITLE = sLine.GetToken( 13, '\t' ); nLANG.EraseLeadingAndTrailingChars(); #ifdef MERGE_SOURCE_LANGUAGES if( true ){ #else if ( !nLANG.EqualsIgnoreCaseAscii("en-US") ){ #endif InsertEntry( sTYP, sGID, sLID, sPFO, nLANG, sTEXT, sQHTEXT, sTITLE , filename , bCaseSensitive ); if( nLANG.Len() > 0 ){ bool bFound = false; for( unsigned int x = 0; x < aLanguages.size(); x++ ){ if( aLanguages[ x ].Equals( nLANG ) ) bFound = true; } // Remember read languages for -l all switch if( !bFound ) aLanguages.push_back( nLANG ); } } } } else if ( sLine.GetTokenCount( '\t' ) == 10 ){ printf("ERROR: File format is obsolete and no longer supported!\n"); } } aInputStream.Close(); } /*****************************************************************************/ MergeDataFile::~MergeDataFile() /*****************************************************************************/ { } /*****************************************************************************/ //void MergeDataFile::WriteErrorLog( const ByteString &rFileName ) /*****************************************************************************/ //{ // DEAD //} ByteString MergeDataFile::Dump(){ ByteString sRet( "MergeDataFile\n" ); //sRet.Append( Export::DumpMap( "aLanguageSet" , aLanguageSet ) ); //sRet.Append( Export::DumpMap( "aLanguages" , aLanguages ) ); printf("MergeDataFile\n"); MergeDataHashMap::const_iterator idbg; for( idbg = aMap.begin() ; idbg != aMap.end(); ++idbg ){ /*sRet.Append( "aMap[" ); sRet.Append( idbg->first ); sRet.Append( "]= " ); sRet.Append( ((MergeData*) (idbg->second))->Dump() ); sRet.Append("\n");*/ printf("aMap[ %s ] = ",idbg->first.GetBuffer()); ((MergeData*) (idbg->second))->Dump(); printf("\n"); } printf("\n"); //sRet.Append("\n"); return sRet; } /*****************************************************************************/ void MergeDataFile::WriteError( const ByteString &rLine ) /*****************************************************************************/ { if ( bErrorLog ) { if ( !aErrLog.IsOpen()) aErrLog.Open( String( sErrorLog, RTL_TEXTENCODING_ASCII_US ), STREAM_STD_WRITE | STREAM_TRUNC ); aErrLog.WriteLine( rLine ); } else fprintf( stderr, "%s\n", rLine.GetBuffer()); } std::vector MergeDataFile::GetLanguages(){ return aLanguages; } /*****************************************************************************/ MergeData *MergeDataFile::GetMergeData( ResData *pResData , bool bCaseSensitive ) /*****************************************************************************/ { ByteString sOldG = pResData->sGId; ByteString sOldL = pResData->sId; ByteString sGID = pResData->sGId; ByteString sLID; if ( !sGID.Len()) sGID = pResData->sId; else sLID = pResData->sId; pResData->sGId = sGID; pResData->sId = sLID; ByteString sKey = CreateKey( pResData->sResTyp , pResData->sGId , pResData->sId , pResData->sFilename , bCaseSensitive ); //printf("DBG: Searching [%s]\n",sKey.GetBuffer()); if( aMap.find( sKey ) != aMap.end() ){ pResData->sGId = sOldG; pResData->sId = sOldL; //printf("DBG: Found[%s]\n",sKey.GetBuffer()); return aMap[ sKey ]; } pResData->sGId = sOldG; pResData->sId = sOldL; //printf("DBG: Found[%s]\n",sKey.GetBuffer()); return NULL; } /*****************************************************************************/ PFormEntrys *MergeDataFile::GetPFormEntrys( ResData *pResData ) /*****************************************************************************/ { // search for requested PFormEntrys MergeData *pData = GetMergeData( pResData ); if ( pData ) return pData->GetPFormEntrys( pResData ); return NULL; } /*****************************************************************************/ PFormEntrys *MergeDataFile::GetPFormEntrysCaseSensitive( ResData *pResData ) /*****************************************************************************/ { // search for requested PFormEntrys MergeData *pData = GetMergeData( pResData , true ); if ( pData ) return pData->GetPFormEntrys( pResData ); return NULL; } /*****************************************************************************/ void MergeDataFile::InsertEntry( const ByteString &rTYP, const ByteString &rGID, const ByteString &rLID, const ByteString &rPFO, const ByteString &nLANG, const ByteString &rTEXT, const ByteString &rQHTEXT, const ByteString &rTITLE , const ByteString &rFilename , bool bCaseSensitive ) /*****************************************************************************/ { MergeData *pData; BOOL bFound = FALSE; // search for MergeData ByteString sKey = CreateKey( rTYP , rGID , rLID , rFilename , bCaseSensitive ); ByteString sKey2; if( aMap.find( sKey ) != aMap.end() ){ pData = aMap[ sKey ]; }else{ pData = new MergeData( rTYP, rGID, rLID , rFilename ); aMap.insert( MergeDataHashMap::value_type( CreateKey( rTYP , rGID , rLID , rFilename , bCaseSensitive ) , pData ) ); } bFound = FALSE; PFormEntrys *pFEntrys = 0; // search for PFormEntrys pFEntrys = pData->GetPFObject( rPFO ); if( !pFEntrys ){ // create new PFormEntrys, cause no one exists with current properties pFEntrys = new PFormEntrys( rPFO ); pData->Insert( rPFO , pFEntrys ); } // finaly insert the cur string pFEntrys->InsertEntry( nLANG , rTEXT, rQHTEXT, rTITLE ); //printf("DBG: MergeDataFile::Insert[]=( sKey=%s,nLang=%s,rTEXT=%s)\n",sKey2.GetBuffer(),nLANG.GetBuffer(),rTEXT.GetBuffer()); } ByteString MergeDataFile::CreateKey( const ByteString& rTYP , const ByteString& rGID , const ByteString& rLID , const ByteString& rFilename , bool bCaseSensitive ){ ByteString sKey( rTYP ); sKey.Append( '-' ); sKey.Append( rGID ); sKey.Append( '-' ); sKey.Append( rLID ); sKey.Append( '-' ); sKey.Append( rFilename ); if( bCaseSensitive ) return sKey; // officecfg case sensitive identifier else return sKey.ToUpperAscii(); }