diff options
author | Luboš Luňák <l.lunak@suse.cz> | 2013-03-07 18:37:30 +0100 |
---|---|---|
committer | Luboš Luňák <l.lunak@suse.cz> | 2013-03-08 13:35:26 +0100 |
commit | 5c1c0a4eef933816685364feef93dfb090ff391d (patch) | |
tree | d7e25370a5f3fc9fbc7d543be34eb51b73eb84dd /writerfilter | |
parent | 4596120336b575d94d305c4139054afd95d2f740 (diff) |
function for duplicated code
Change-Id: If9d6a163abb5a1cbd64838ca005b14dcd51c4588
Diffstat (limited to 'writerfilter')
-rw-r--r-- | writerfilter/source/dmapper/FontTable.cxx | 55 |
1 files changed, 4 insertions, 51 deletions
diff --git a/writerfilter/source/dmapper/FontTable.cxx b/writerfilter/source/dmapper/FontTable.cxx index cb737f1edb36..47fdc012549b 100644 --- a/writerfilter/source/dmapper/FontTable.cxx +++ b/writerfilter/source/dmapper/FontTable.cxx @@ -251,35 +251,12 @@ EmbeddedFontHandler::~EmbeddedFontHandler() { if( !inputStream.is()) return; - OUString fileUrl = EmbeddedFontsHelper::fileUrlForTemporaryFont( fontName, style ); - osl::File file( fileUrl ); - switch( file.open( osl_File_OpenFlag_Create | osl_File_OpenFlag_Write )) - { - case osl::File::E_None: - break; // ok - case osl::File::E_EXIST: - return; // Assume it's already been added correctly. - default: - SAL_WARN( "writerfilter", "Cannot open file for temporary font" ); - inputStream->closeInput(); - return; - } + std::vector< unsigned char > key( 32 ); if( !fontKey.isEmpty()) - { // unobfuscate - uno::Sequence< sal_Int8 > buffer; - int read = inputStream->readBytes( buffer, 32 ); - if( read < 32 ) - { - SAL_WARN( "writerfilter", "Embedded font too small" ); - inputStream->closeInput(); - file.close(); - osl::File::remove( fileUrl ); - return; - } + { // key for unobfuscating // 1 3 5 7 10 2 5 7 20 2 5 7 9 1 3 5 // {62E79491-959F-41E9-B76B-6B32631DEA5C} static const int pos[ 16 ] = { 35, 33, 31, 29, 27, 25, 22, 20, 17, 15, 12, 10, 7, 5, 3, 1 }; - char key[ 16 ]; for( int i = 0; i < 16; ++i ) @@ -290,35 +267,11 @@ EmbeddedFontHandler::~EmbeddedFontHandler() assert(( v2 >= '0' && v2 <= '9' ) || ( v2 >= 'A' && v2 <= 'F' )); int val = ( v1 - ( v1 <= '9' ? '0' : 'A' - 10 )) * 16 + v2 - ( v2 <= '9' ? '0' : 'A' - 10 ); key[ i ] = val; + key[ i + 16 ] = val; } - for( int i = 0; - i < 16; - ++i ) - { - buffer[ i ] ^= key[ i ]; - buffer[ i + 16 ] ^= key[ i ]; - } - sal_uInt64 dummy; - file.write( buffer.getConstArray(), 32, dummy ); - } - for(;;) - { - uno::Sequence< sal_Int8 > buffer; - int read = inputStream->readBytes( buffer, 1024 ); - sal_uInt64 dummy; - if( read > 0 ) - file.write( buffer.getConstArray(), read, dummy ); - if( read < 1024 ) - break; } + EmbeddedFontsHelper::addEmbeddedFont( inputStream, fontName, style, key ); inputStream->closeInput(); - if( file.close() != osl::File::E_None ) - { - SAL_WARN( "writerfilter", "Writing temporary font file failed" ); - osl::File::remove( fileUrl ); - return; - } - EmbeddedFontsHelper::activateFont( fontName, fileUrl ); } void EmbeddedFontHandler::lcl_attribute( Id name, Value& val ) |