/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 . */ /* e.g. make cp workdir/LinkTarget/Executable/fftester instdir/program LD_LIBRARY_PATH=`pwd`/instdir/program instdir/program/fftester png or on macOS make cp workdir/LinkTarget/Executable/fftester instdir/LibreOfficeDev.app/Contents/MacOS/ DYLD_LIBRARY_PATH=`pwd`/instdir/LibreOfficeDev.app/Contents/Frameworks instdir/LibreOfficeDev.app/Contents/MacOS/fftester png */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "../source/filter/igif/gifread.hxx" #include "../source/filter/ixbm/xbmread.hxx" #include "../source/filter/jpeg/jpeg.hxx" using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace cppu; typedef bool (*FFilterCall)(SvStream &rStream); #ifndef DISABLE_DYNLOADING namespace { FFilterCall load(std::u16string_view library, char const * function) { OUString path = OUString::Concat("$LO_LIB_DIR/") + library; rtl::Bootstrap::expandMacros(path); //TODO: check for failure osl::Module aLibrary(path, SAL_LOADMODULE_LAZY); auto const fn = reinterpret_cast(aLibrary.getFunctionSymbol(function)); aLibrary.release(); return fn; } } #endif SAL_IMPLEMENT_MAIN_WITH_ARGS(argc, argv) { int ret = -1; try { if (argc < 3) { fprintf(stderr, "Usage: fftester \n"); return -1; } setenv("SAL_USE_VCLPLUGIN", "svp", 1); setenv("JPEGMEM", "768M", 1); setenv("SC_MAX_MATRIX_ELEMENTS", "60000000", 1); setenv("SC_NO_THREADED_CALCULATION", "1", 1); setenv("SAL_DISABLE_PRINTERLIST", "1", 1); setenv("SAL_DISABLE_DEFAULTPRINTER", "1", 1); setenv("SAL_NO_FONT_LOOKUP", "1", 1); OUString in(argv[1], strlen(argv[1]), RTL_TEXTENCODING_UTF8); OUString out; osl::File::getFileURLFromSystemPath(in, out); tools::extendApplicationEnvironment(); Reference< XComponentContext > xContext = defaultBootstrap_InitialComponentContext(); Reference< XMultiServiceFactory > xServiceManager( xContext->getServiceManager(), UNO_QUERY ); if( !xServiceManager.is() ) Application::Abort( "Failed to bootstrap" ); comphelper::setProcessServiceFactory( xServiceManager ); utl::ConfigManager::EnableFuzzing(); // initialise unconfigured UCB: css::uno::Reference xUcb(comphelper::getProcessServiceFactory()-> createInstance("com.sun.star.ucb.UniversalContentBroker"), css::uno::UNO_QUERY_THROW); css::uno::Sequence aArgs(1); aArgs[0] <<= OUString("NoConfig"); css::uno::Reference xFileProvider(comphelper::getProcessServiceFactory()-> createInstanceWithArguments("com.sun.star.ucb.FileContentProvider", aArgs), css::uno::UNO_QUERY_THROW); xUcb->registerContentProvider(xFileProvider, "file", true); Application::EnableHeadlessMode(false); InitVCL(); if (strcmp(argv[2], "wmf") == 0 || strcmp(argv[2], "emf") == 0) { GDIMetaFile aGDIMetaFile; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ReadWindowMetafile(aFileStream, aGDIMetaFile)); } else if (strcmp(argv[2], "jpg") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportJPEG(aFileStream, aGraphic, GraphicFilterImportFlags::NONE, nullptr)); } else if (strcmp(argv[2], "gif") == 0) { SvFileStream aFileStream(out, StreamMode::READ); Graphic aGraphic; ret = static_cast(ImportGIF(aFileStream, aGraphic)); } else if (strcmp(argv[2], "xbm") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportXBM(aFileStream, aGraphic)); } else if (strcmp(argv[2], "xpm") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportXPM(aFileStream, aGraphic)); } else if (strcmp(argv[2], "png") == 0) { SvFileStream aFileStream(out, StreamMode::READ); vcl::PngImageReader aReader(aFileStream); ret = static_cast(!aReader.read().IsEmpty()); } else if (strcmp(argv[2], "bmp") == 0) { Bitmap aTarget; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ReadDIB(aTarget, aFileStream, true)); } else if (strcmp(argv[2], "svm") == 0) { GDIMetaFile aGDIMetaFile; SvFileStream aFileStream(out, StreamMode::READ); ReadGDIMetaFile(aFileStream, aGDIMetaFile); } else if (strcmp(argv[2], "pcd") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportPcdGraphic(aFileStream, aGraphic, nullptr)); } else if (strcmp(argv[2], "dxf") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportDxfGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "met") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportMetGraphic(aFileStream, aGraphic)); } else if ((strcmp(argv[2], "pbm") == 0) || strcmp(argv[2], "ppm") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportPbmGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "psd") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportPsdGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "eps") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportEpsGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "pct") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportPictGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "pcx") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportPcxGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "ras") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportRasGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "tga") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportTgaGraphic(aFileStream, aGraphic)); } else if (strcmp(argv[2], "tif") == 0) { Graphic aGraphic; SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast(ImportTiffGraphicImport(aFileStream, aGraphic)); } #ifndef DISABLE_DYNLOADING else if ((strcmp(argv[2], "doc") == 0) || (strcmp(argv[2], "ww8") == 0)) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libmswordlo.so", "TestImportWW8"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "ww6") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libmswordlo.so", "TestImportWW6"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "ww2") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libmswordlo.so", "TestImportWW2"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "rtf") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libmswordlo.so", "TestImportRTF"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "html") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libswlo.so", "TestImportHTML"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "fodt") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libswlo.so", "TestImportFODT"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "docx") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libswlo.so", "TestImportDOCX"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "fods") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsclo.so", "TestImportFODS"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "xlsx") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsclo.so", "TestImportXLSX"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "fodp") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsdlo.so", "TestImportFODP"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "pptx") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsdlo.so", "TestImportPPTX"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "xls") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libscfiltlo.so", "TestImportXLS"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "wks") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libscfiltlo.so", "TestImportWKS"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "hwp") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libhwplo.so", "TestImportHWP"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "602") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libt602filterlo.so", "TestImport602"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "lwp") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"liblwpftlo.so", "TestImportLWP"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "ppt") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsdfiltlo.so", "TestImportPPT"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "cgm") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsdlo.so", "TestImportCGM"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "qpw") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libscfiltlo.so", "TestImportQPW"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "dif") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libscfiltlo.so", "TestImportDIF"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "sc-rtf") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libscfiltlo.so", "TestImportCalcRTF"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "slk") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsclo.so", "TestImportSLK"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "ole") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsotlo.so", "TestImportOLE2"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "mml") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsmlo.so", "TestImportMML"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "mtp") == 0) { static FFilterCall pfnImport(nullptr); if (!pfnImport) { pfnImport = load(u"libsmlo.so", "TestImportMathType"); } SvFileStream aFileStream(out, StreamMode::READ); ret = static_cast((*pfnImport)(aFileStream)); } else if (strcmp(argv[2], "sft") == 0) { SvFileStream aFileStream(out, StreamMode::READ); std::vector aData(aFileStream.remainingSize()); aFileStream.ReadBytes(aData.data(), aData.size()); (void)vcl::Font::identifyFont(aData.data(), aData.size()); } #endif } catch (...) { abort(); } return ret; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */