diff options
Diffstat (limited to 'vcl/workben')
-rw-r--r-- | vcl/workben/scrtffuzzer.cxx | 76 |
1 files changed, 52 insertions, 24 deletions
diff --git a/vcl/workben/scrtffuzzer.cxx b/vcl/workben/scrtffuzzer.cxx index 5221ef045a17..cf9d88c66159 100644 --- a/vcl/workben/scrtffuzzer.cxx +++ b/vcl/workben/scrtffuzzer.cxx @@ -8,36 +8,64 @@ */ #include <tools/stream.hxx> -#include <vcl/FilterConfigItem.hxx> -#include <com/sun/star/ucb/XContentProvider.hpp> -#include <com/sun/star/ucb/XUniversalContentBroker.hpp> #include "commonfuzzer.hxx" +#include <config_features.h> +#include <osl/detail/component-mapping.h> + +extern "C" { +void* i18npool_component_getFactory(const char*, void*, void*); + +void* com_sun_star_i18n_LocaleDataImpl_get_implementation(void*, void*); +void* com_sun_star_i18n_BreakIterator_Unicode_get_implementation(void*, void*); +void* com_sun_star_i18n_BreakIterator_get_implementation(void*, void*); +void* com_sun_star_comp_framework_Desktop_get_implementation(void*, void*); +void* com_sun_star_i18n_CharacterClassification_Unicode_get_implementation(void*, void*); +void* com_sun_star_i18n_CharacterClassification_get_implementation(void*, void*); +void* com_sun_star_i18n_NativeNumberSupplier_get_implementation(void*, void*); +void* com_sun_star_i18n_NumberFormatCodeMapper_get_implementation(void*, void*); +void* com_sun_star_i18n_Transliteration_get_implementation(void*, void*); +} + +const lib_to_factory_mapping* lo_get_factory_map(void) +{ + static lib_to_factory_mapping map[] + = { { "libi18npoollo.a", i18npool_component_getFactory }, { 0, 0 } }; + + return map; +} + +const lib_to_constructor_mapping* lo_get_constructor_map(void) +{ + static lib_to_constructor_mapping map[] + = { { "com_sun_star_i18n_LocaleDataImpl_get_implementation", + com_sun_star_i18n_LocaleDataImpl_get_implementation }, + { "com_sun_star_i18n_BreakIterator_Unicode_get_implementation", + com_sun_star_i18n_BreakIterator_Unicode_get_implementation }, + { "com_sun_star_i18n_BreakIterator_get_implementation", + com_sun_star_i18n_BreakIterator_get_implementation }, + { "com_sun_star_comp_framework_Desktop_get_implementation", + com_sun_star_comp_framework_Desktop_get_implementation }, + { "com_sun_star_i18n_CharacterClassification_Unicode_get_implementation", + com_sun_star_i18n_CharacterClassification_Unicode_get_implementation }, + { "com_sun_star_i18n_CharacterClassification_get_implementation", + com_sun_star_i18n_CharacterClassification_get_implementation }, + { "com_sun_star_i18n_NativeNumberSupplier_get_implementation", + com_sun_star_i18n_NativeNumberSupplier_get_implementation }, + { "com_sun_star_i18n_NumberFormatCodeMapper_get_implementation", + com_sun_star_i18n_NumberFormatCodeMapper_get_implementation }, + { "com_sun_star_i18n_Transliteration_get_implementation", + com_sun_star_i18n_Transliteration_get_implementation }, + { 0, 0 } }; + + return map; +} + extern "C" bool TestImportCalcRTF(SvStream& rStream); extern "C" int LLVMFuzzerInitialize(int* argc, char*** argv) { - if (__lsan_disable) - __lsan_disable(); - - CommonInitialize(argc, argv); - - // initialise unconfigured UCB: - css::uno::Reference<css::ucb::XUniversalContentBroker> xUcb( - comphelper::getProcessServiceFactory()->createInstance( - "com.sun.star.ucb.UniversalContentBroker"), - css::uno::UNO_QUERY_THROW); - css::uno::Sequence<css::uno::Any> aArgs(1); - aArgs[0] <<= OUString("NoConfig"); - css::uno::Reference<css::ucb::XContentProvider> xFileProvider( - comphelper::getProcessServiceFactory()->createInstanceWithArguments( - "com.sun.star.ucb.FileContentProvider", aArgs), - css::uno::UNO_QUERY_THROW); - xUcb->registerContentProvider(xFileProvider, "file", true); - - if (__lsan_enable) - __lsan_enable(); - + TypicalFuzzerInitialize(argc, argv); return 0; } |