diff options
Diffstat (limited to 'ios')
-rw-r--r-- | ios/experimental/DocumentLoader/Makefile | 127 | ||||
-rw-r--r-- | ios/experimental/DocumentLoader/docloader.mm | 203 |
2 files changed, 330 insertions, 0 deletions
diff --git a/ios/experimental/DocumentLoader/Makefile b/ios/experimental/DocumentLoader/Makefile new file mode 100644 index 000000000000..a30896391208 --- /dev/null +++ b/ios/experimental/DocumentLoader/Makefile @@ -0,0 +1,127 @@ +include ../../../config_host.mk + +APP=LODocumentLoader + +# If run from Xcode, check the CURRENT_ARCH env var for which platform we are +# building, device or simulator + +ifneq (,$(filter i386,$(CC))) +PLATFORM=iphonesimulator +else +PLATFORM=iphoneos +endif + +APPDIR=build/Debug-$(PLATFORM)/$(APP).app + +# Stuff lifted from solenv/gbuild + +gb_CPUDEFS := -DARM32 + +gb_CPUDEFS += -D$(CPUNAME) + +gb_OSDEFS := \ + -D$(OS) \ + -D_PTHREADS \ + -DUNIX \ + -DUNX \ + -D_REENTRANT \ + -DNO_PTHREAD_PRIORITY \ + $(EXTRA_CDEFS) \ + +gb_CPPU_ENV := gcc3 + +gb_COMPILERDEFS := \ + -D$(COM) \ + -DCPPU_ENV=$(gb_CPPU_ENV) \ + +gb_DEBUGLEVEL := 1 + +gb_GLOBALDEFS := \ + -D_REENTRANT \ + -DOSL_DEBUG_LEVEL=$(gb_DEBUGLEVEL) \ + -DSUPD=$(UPD) \ + $(gb_OSDEFS) \ + $(gb_COMPILERDEFS) \ + $(gb_CPUDEFS) \ + +gb_OBJC_OBJCXX_COMMON_FLAGS := -fobjc-abi-version=2 -fobjc-legacy-dispatch -D__IPHONE_OS_VERSION_MIN_REQUIRED=40300 -g +gb_OBJCFLAGS := -x objective-c $(gb_OBJC_OBJCXX_COMMON_FLAGS) +gb_OBJCXXFLAGS := -x objective-c++ $(gb_OBJC_OBJCXX_COMMON_FLAGS) + +gb_Library__FRAMEWORKS := \ + Foundation \ + CoreFoundation \ + CoreGraphics \ + CoreText \ + UIKit \ + +SRCS = docloader.mm + +CFLAGS = $(SOLARINC) + +MOREINCLUDES = -I$(OUTDIR)/inc/udkapi -I$(OUTDIR)/inc/offapi + +LIBS = $(foreach LIB, bin/cppunit/cppunittester lib/bootstrap.uno lib/configmgr.uno lib/expwrap.uno lib/fastsax.uno lib/i18npool.uno lib/introspection.uno lib/reflection.uno lib/stocservices.uno lib/unobootstrapprotector lib/unoexceptionprotector, -Wl,$(OUTDIR)/$(LIB).a) $(SOLARLIB) -lacclo -lanalysislo -lascii_expat_xmlparse -lavmedialo -lbasegfxlo -lcanvastoolslo -llcms2 -lcollator_data -lcomphelpgcc3 -lcppcanvaslo -lcppunit -lcrypto -lcuilo -ldatelo -ldbtoolslo -ldict_ja -ldict_zh -ldrawinglayerlo -leditenglo -legilo -lemelo -lepblo -lepglo -lepplo -lepslo -leptlo -leralo -letilo -lexpat_xmlparse -lexpat_xmltok -lexplo -lfilterconfiglo -lforlo -lforuilo -lfwelo -lfwilo -lfwklo -lgcc3_uno -li18nisolang1gcc3 -li18nutilgcc3 -licdlo -licudata -licui18n -licuuc -lidxlo -limelo -lindex_data -lipblo -lipdlo -lipslo -liptlo -lipxlo -liralo -litglo -litilo -ljpeg -ljvmfwk -llnglo -llocaledata_en -llocaledata_es -llocaledata_euro -llocaledata_others -lmsfilterlo -lorcus -looxlo -lpackage2 -lreg -lsal_textenc -lsalcpprt -lsaxlo -lsax_shared -lscfiltlo -lsclo -lscuilo -lsfxlo -lsotlo -lstore -lsvllo -lsvtlo -lsvxlo -lsvxcorelo -ltest -ltextconv_dict -ltklo -ltllo -lucb1 -lucbhelper4gcc3 -lucpfile1 -lunoxmllo -luno_cppuhelpergcc3 -luno_cppu -luno_sal -luno_salhelpergcc3 -lunotest -lutllo -lvcllo -lxmlscriptlo -lxml2 -lxmlreader -lxolo -lxstor -lz $(addprefix -framework , $(gb_Library__FRAMEWORKS)) -liconv -lobjc + +all: $(APPDIR)/$(APP) stuff + +$(APPDIR)/$(APP): $(SRCS) + mkdir -p $(APPDIR) + $(CXX) -Wl,-map,$(APP).map.mangled -o $@ $(gb_GLOBALDEFS) $(CFLAGS) $(gb_OBJCXXFLAGS) $(MOREINCLUDES) $(SRCS) $(LIBS) + c++filt <$(APP).map.mangled >$(APP).map && rm $(APP).map.mangled + +stuff: +# inifile: + echo 'URE_BOOTSTRAP=$${ORIGIN}/fundamentalrc' >$(APPDIR)/rc +# +# URE_BOOTSTRAP file, fundamentalrc: + ( \ + echo '[Bootstrap]'; \ + echo 'BRAND_BASE_DIR=$${ORIGIN}'; \ + echo 'CONFIGURATION_LAYERS=xcsxcu:$${BRAND_BASE_DIR}/registry module:$${BRAND_BASE_DIR}/registry/modules res:$${BRAND_BASE_DIR}/registry' \ + ) >$(APPDIR)/fundamentalrc + +# +# An unorc is *mandatory*, sigh. We leave it empty except for the +# [Bootstrap} section header, though, and set all the stuff using +# -env: options in docloader.m. Whether that makes sense or not, +# no idea. The ideal would clearly be if *none* of the various rc +# files was mandatory, and the code would automatically use sane +# defaults. (Sane for the particular platform, that is.) + ( \ + echo '[Bootstrap]' \ + ) >$(APPDIR)/unorc +# +# hmm, once again, a hodgepodge of stuff, I don't really know which +# files of which are actually needed... + mkdir -p $(APPDIR)/registry/res + cp $(OUTDIR)/xml/*.xcd $(APPDIR)/registry + mv $(APPDIR)/registry/fcfg_langpack_en-US.xcd $(APPDIR)/registry/res + cp -R $(OUTDIR)/xml/registry/* $(APPDIR)/registry +# +# .rdb files + cp $(OUTDIR)/bin/udkapi.rdb $(OUTDIR)/bin/types.rdb $(OUTDIR)/xml/ure/services.rdb $(APPDIR) + mkdir -p $(APPDIR)/ure + cp $(OUTDIR)/bin/ure/types.rdb $(APPDIR)/ure +# +# a bunch of .component files + for F in framework/util/fwk i18npool/util/i18npool sfx2/util/sfx ucb/source/core/ucb1 ucb/source/ucp/file/ucpfile1 unoxml/source/service/unoxml configmgr/source/configmgr basic/util/sb chart2/source/controller/chartcontroller chart2/source/chartcore comphelper/util/comphelp eventattacher/source/evtatt fileaccess/source/fileacc filter/source/config/cache/filterconfig1 oox/util/oox package/source/xstor/xstor package/util/package2 sax/source/expatwrap/expwrap sax/source/fastparser/fastsax sc/util/sc sc/util/scfilt scaddins/source/analysis/analysis scaddins/source/datefunc/date sot/util/sot svl/util/svl toolkit/util/tk ucb/source/ucp/tdoc/ucptdoc1 unotools/util/utl unoxml/source/rdf/unordf; do \ + mkdir -p $(APPDIR)/ComponentTarget/`dirname $$F`; \ + cp $(WORKDIR)/ComponentTarget/$$F.component $(APPDIR)/ComponentTarget/$$F.component; \ + done +# +# .res files +# +# $BRAND_BASE_DIR/program/resource hardcoded in +# ResMgrContainer::init() in tools/source/rc/resmgr.cxx, so let's use +# that. + mkdir -p $(APPDIR)/program/resource + for F in $(OUTDIR)/bin/*.res; do \ + cp $$F $(APPDIR)/program/resource; \ + done +# +# Test documents + cp $(SRC_ROOT)/odk/examples/java/DocumentHandling/test/test1.odt $(APPDIR) + +clean: + rm -rf $(APPDIR) diff --git a/ios/experimental/DocumentLoader/docloader.mm b/ios/experimental/DocumentLoader/docloader.mm new file mode 100644 index 000000000000..595d5750e8ee --- /dev/null +++ b/ios/experimental/DocumentLoader/docloader.mm @@ -0,0 +1,203 @@ +/* -*- Mode: ObjC; 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/. + */ + +#include <stdlib.h> + +#include <premac.h> +#import <UIKit/UIKit.h> +#include <postmac.h> + +#include <cppuhelper/bootstrap.hxx> +#include <osl/detail/ios-bootstrap.h> +#include <osl/process.h> + +#include <com/sun/star/beans/XPropertySet.hpp> +#include <com/sun/star/bridge/XUnoUrlResolver.hpp> +#include <com/sun/star/frame/XComponentLoader.hpp> +#include <com/sun/star/lang/XMultiComponentFactory.hpp> +#include <com/sun/star/registry/XSimpleRegistry.hpp> + +using namespace com::sun::star::uno; +using namespace com::sun::star::lang; +using namespace com::sun::star::beans; +using namespace com::sun::star::bridge; +using namespace com::sun::star::frame; +using namespace com::sun::star::registry; + +using ::rtl::OUString; +using ::rtl::OUStringToOString; + +#ifdef __cplusplus +extern "C" { +#endif + +extern void * analysis_component_getFactory( const char * pImplName, void * pServiceManager, void * pRegistryKey ); +extern void * date_component_getFactory( const char * pImplName, void * pServiceManager, void * pRegistryKey ); +extern void * sc_component_getFactory( const char * pImplName, void * pServiceManager, void * pRegistryKey ); +extern void * scfilt_component_getFactory( const char * pImplName, void * pServiceManager, void * pRegistryKey ); +extern void * unoxml_component_getFactory( const char * pImplName, void * pServiceManager, void * pRegistryKey ); + +const lib_to_component_mapping * +lo_get_libmap(void) +{ + static lib_to_component_mapping map[] = { + { "libanalysislo.a", analysis_component_getFactory }, + { "libdatelo.a", date_component_getFactory }, + { "libscfiltlo.a", scfilt_component_getFactory }, + { "libsclo.a", sc_component_getFactory }, + { "libunoxmllo.a", unoxml_component_getFactory }, + { NULL, NULL } + }; + + return map; +} + +#ifdef __cplusplus +} +#endif + +int +main(int argc, char ** argv) +{ + NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; + int retVal = UIApplicationMain (argc, argv, @"UIApplication", @"loAppDelegate"); + [pool release]; + return retVal; +} + +@interface loAppDelegate : NSObject <UIApplicationDelegate> { +} +@property (nonatomic, retain) UIWindow *window; +@end + +@implementation loAppDelegate + +@synthesize window=_window; + +- (BOOL)application: (UIApplication *) application +didFinishLaunchingWithOptions: (NSDictionary *) launchOptions +{ + int i; + + (void) application; + (void) launchOptions; + + UIWindow *uiw = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]]; + uiw.backgroundColor = [UIColor redColor]; + self.window = uiw; + [uiw release]; + + // See unotest/source/cpp/bootstrapfixturebase.cxx + const char *app_root = [[[NSBundle mainBundle] bundlePath] UTF8String]; + setenv("SRC_ROOT", app_root, 1); + setenv("OUTDIR_FOR_BUILD", app_root, 1); + + setenv("SAL_LOG", "yes", 1); + + const char *argv[] = { + "lo-qa-sc-filters-test", + "dummy-testlib", + "--headless", + "--protector", + "dummy-libunoexceptionprotector", + "unoexceptionprotector", + "--protector", + "dummy-libunobootstrapprotector", + "unobootstrapprotector", + "-env:URE_INTERNAL_LIB_DIR=file:///", + "placeholder-uno-types", + "placeholder-uno-services" + }; + + const int argc = sizeof(argv)/sizeof(*argv); + + NSString *app_root_escaped = [[[NSBundle mainBundle] bundlePath] stringByAddingPercentEscapesUsingEncoding: NSUTF8StringEncoding]; + + NSString *uno_types = @"-env:UNO_TYPES="; + + uno_types = [uno_types stringByAppendingString: @"file://"]; + uno_types = [uno_types stringByAppendingString: [app_root_escaped stringByAppendingPathComponent: @"udkapi.rdb"]]; + + uno_types = [uno_types stringByAppendingString: @" "]; + uno_types = [uno_types stringByAppendingString: @"file://"]; + uno_types = [uno_types stringByAppendingString: [app_root_escaped stringByAppendingPathComponent: @"types.rdb"]]; + + uno_types = [uno_types stringByAppendingString: @" "]; + uno_types = [uno_types stringByAppendingString: @"file://"]; + uno_types = [uno_types stringByAppendingString: [app_root_escaped stringByAppendingPathComponent: @"ure/types.rdb"]]; + + assert(strcmp(argv[argc-2], "placeholder-uno-types") == 0); + argv[argc-2] = [uno_types UTF8String]; + + NSString *uno_services = @"-env:UNO_SERVICES="; + + const char *services[] = { + "services.rdb", + "ComponentTarget/basic/util/sb.component", + "ComponentTarget/chart2/source/controller/chartcontroller.component", + "ComponentTarget/chart2/source/chartcore.component", + "ComponentTarget/comphelper/util/comphelp.component", + "ComponentTarget/eventattacher/source/evtatt.component", + "ComponentTarget/fileaccess/source/fileacc.component", + "ComponentTarget/filter/source/config/cache/filterconfig1.component", + "ComponentTarget/oox/util/oox.component", + "ComponentTarget/package/source/xstor/xstor.component", + "ComponentTarget/package/util/package2.component", + "ComponentTarget/sax/source/expatwrap/expwrap.component", + "ComponentTarget/sax/source/fastparser/fastsax.component", + "ComponentTarget/sc/util/sc.component", + "ComponentTarget/sc/util/scfilt.component", + "ComponentTarget/scaddins/source/analysis/analysis.component", + "ComponentTarget/scaddins/source/datefunc/date.component", + "ComponentTarget/sot/util/sot.component", + "ComponentTarget/svl/util/svl.component", + "ComponentTarget/toolkit/util/tk.component", + "ComponentTarget/ucb/source/ucp/tdoc/ucptdoc1.component", + "ComponentTarget/unotools/util/utl.component", + "ComponentTarget/unoxml/source/rdf/unordf.component", + "ComponentTarget/framework/util/fwk.component", + "ComponentTarget/i18npool/util/i18npool.component", + "ComponentTarget/sfx2/util/sfx.component", + "ComponentTarget/unoxml/source/service/unoxml.component", + "ComponentTarget/configmgr/source/configmgr.component", + "ComponentTarget/ucb/source/core/ucb1.component", + "ComponentTarget/ucb/source/ucp/file/ucpfile1.component" + }; + + for (i = 0; i < sizeof(services)/sizeof(services[0]); i++) { + uno_services = [uno_services stringByAppendingString: @"file://"]; + uno_services = [uno_services stringByAppendingString: [app_root_escaped stringByAppendingPathComponent: [NSString stringWithUTF8String: services[i]]]]; + if (i < sizeof(services)/sizeof(services[0]) - 1) + uno_services = [uno_services stringByAppendingString: @" "]; + } + + assert(strcmp(argv[argc-1], "placeholder-uno-services") == 0); + argv[argc-1] = [uno_services UTF8String]; + + osl_setCommandArgs(argc, (char **) argv); + + Reference< XComponentContext > xComponentContext(::cppu::defaultBootstrap_InitialComponentContext()); + + Reference< XMultiComponentFactory > xMultiComponentFactoryClient( + xComponentContext->getServiceManager() ); + + Reference< XInterface > xInterface = + xMultiComponentFactoryClient->createInstanceWithContext( + OUString("com.sun.star.frame.Desktop"), + xComponentContext ); + + // Do something here + + [self.window makeKeyAndVisible]; + return YES; +} + +@end + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |