ios/.gitignore                  |    1 
 ios/CustomTarget_Lo_Xcconfig.mk |  132 ----------------------------------------
 ios/CustomTarget_setup.mk       |   70 +++++++++++++++++++--
 3 files changed, 66 insertions(+), 137 deletions(-)

New commits:
commit 4b2d0e511d4013847fb23e4346cda420a4ce6908
Author: jan Iversen <j...@libreoffice.org>
Date:   Thu Sep 28 10:55:34 2017 +0200

    iOS, cleaned add resources
    
    Simpler setup makefile, that will generate the 2 xcconfig files
    as well as create the resources directory.
    
    The generated directory is on purpose created in the core/ios, because
    the output of the different builds are needed for the app build.
    
    Change-Id: I402604ebf947f962552b069bf24ff3794b2ade9d

diff --git a/ios/.gitignore b/ios/.gitignore
index f0d6995bda19..04927dd74172 100644
--- a/ios/.gitignore
+++ b/ios/.gitignore
@@ -7,3 +7,4 @@
 #
 
 lo*.xcconfig
+generated
diff --git a/ios/CustomTarget_Lo_Xcconfig.mk b/ios/CustomTarget_Lo_Xcconfig.mk
deleted file mode 100644
index 6aea394fab2f..000000000000
--- a/ios/CustomTarget_Lo_Xcconfig.mk
+++ /dev/null
@@ -1,132 +0,0 @@
-# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
-#
-# 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/.
-
-#- Env ------------------------------------------------------------------------
-IOSWORK := $(BUILDDIR)/workdir
-IOSDIR := $(IOSWORK)/ios
-IOSRESOURCE := $(IOSDIR)/resources
-IOSGENERATED := $(IOSDIR)/generated
-LO_XCCONFIG = $(IOSGENERATED)/lo.xcconfig
-
-
-#- Macros to be used, in each target ------------------------------------------
-define IOSbuild
-       CC=; \
-       $(call gb_Helper_print_on_error, \
-               xcodebuild \
-                        -xcconfig $(BUILDDIR)/ios/$1/lo_kit.xconfig \
-                       -project $(SRCDIR)/ios/$(1)/$(1).xcodeproj \
-                       -target $(1) \
-                       -sdk $(XCODEBUILD_SDK) \
-                       -arch $(XCODE_ARCHS) \
-                       -configuration $(if $(ENABLE_DEBUG),Debug,Release) \
-                       $(2) \
-                       , $(IOSDIR)/$(1).log \
-        )
-endef
-
-
-$(eval $(call gb_CustomTarget_CustomTarget,ios/Lo_Xcconfig))
-
-
-$(call gb_CustomTarget_get_target,ios/Lo_Xcconfig): $(LO_XCCONFIG)
-
-.PHONY : $(LO_XCCONFIG)
-
-$(LO_XCCONFIG) :
-       $(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),$(true),ENV,2)
-
-       # prepare work directories for all ios builds
-       rm -rf $(IOSRESOURCE) 2>/dev/null;
-       mkdir -p $(IOSDIR) $(IOSGENERATED) $(IOSRESOURCE) 
$(IOSRESOURCE)/services;
-
-       # generate file with call declarations
-       $(SRCDIR)/solenv/bin/native-code.py \
-               -g core -g writer -g calc -g draw -g edit \
-               > $(IOSGENERATED)/native-code.mm
-
-       # generate resource files used to start/run LibreOffice
-       # copy rdb files
-       cp $(INSTDIR)/program/types.rdb             $(IOSRESOURCE)/udkapi.rdb
-       cp $(INSTDIR)/program/types/offapi.rdb      $(IOSRESOURCE)
-       cp $(INSTDIR)/program/types/oovbaapi.rdb    $(IOSRESOURCE)
-       cp $(INSTDIR)/program/services/services.rdb $(IOSRESOURCE)/services
-       cp $(INSTDIR)/program/services.rdb          $(IOSRESOURCE)
-
-       # soffice.cfg
-       mkdir -p $(IOSRESOURCE)/share/config
-       cp -R $(INSTDIR)/share/config/soffice.cfg $(IOSRESOURCE)/share/config
-
-       # Japanese and Chinese dict files
-       cp $(WORKDIR)/CustomTarget/i18npool/breakiterator/dict_*.data 
$(IOSRESOURCE)/share
-
-       # Drawing ML custom shape data files
-       mkdir -p $(IOSRESOURCE)/share/filter
-       cp $(INSTDIR)/share/filter/oox-drawingml-adj-names 
$(IOSRESOURCE)/share/filter
-       cp $(INSTDIR)/share/filter/oox-drawingml-cs-presets 
$(IOSRESOURCE)/share/filter
-       cp $(INSTDIR)/share/filter/vml-shape-types $(IOSRESOURCE)/share/filter
-
-       # "registry"
-       cp -R $(INSTDIR)/share/registry $(IOSRESOURCE)/share
-
-       # Set up rc, the "inifile". See getIniFileName_Impl().
-       file=$(IOSRESOURCE)/rc; \
-       echo '[Bootstrap]' > $$file; \
-       echo 'URE_BOOTSTRAP=file://$$APP_DATA_DIR/fundamentalrc' >> $$file; \
-       echo 'HOME=$$SYSUSERHOME' >> $$file
-
-       # Set up fundamentalrc, unorc, bootstraprc and versionrc.
-       # Do we really need all these?
-       file=$(IOSRESOURCE)/fundamentalrc; \
-       echo '[Bootstrap]'                                      >  $$file; \
-       echo 'LO_LIB_DIR=file://$$APP_DATA_DIR/lib/'            >> $$file; \
-       echo 'BRAND_BASE_DIR=file://$$APP_DATA_DIR'             >> $$file; \
-       echo 'CONFIGURATION_LAYERS=xcsxcu:$${BRAND_BASE_DIR}/share/registry 
res:$${BRAND_BASE_DIR}/registry' >> $$file; \
-       echo 'UNO_TYPES=file://$$APP_DATA_DIR/udkapi.rdb 
file://$$APP_DATA_DIR/offapi.rdb' >> $$file; \
-       echo 'UNO_SERVICES=file://$$APP_DATA_DIR/services.rdb 
file://$$APP_DATA_DIR/services/services.rdb' >> $$file; \
-       echo 'OSL_SOCKET_PATH=$$APP_DATA_DIR/cache' >> $$file
-
-       file=$(IOSRESOURCE)/unorc; \
-       echo '[Bootstrap]' > $$file;
-
-       # bootstraprc must be in $BRAND_BASE_DIR/program
-       mkdir -p $(IOSRESOURCE)/program
-       file=$(IOSRESOURCE)/program/bootstraprc; \
-       echo '[Bootstrap]'                                                      
        >  $$file; \
-       echo 'InstallMode=<installmode>'                                        
        >> $$file; \
-       echo "ProductKey=LibreOffice $(PRODUCTVERSION)"                         
        >> $$file; \
-       echo 'UserInstallation=$$SYSUSERHOME/userinstallation'                  
        >> $$file;
-
-       # Is this really needed?
-       file=$(IOSRESOURCE)/program/versionrc; \
-       echo '[Version]'            >  $$file; \
-       echo 'AllLanguages=en-US'   >> $$file; \
-       echo 'BuildVersion='        >> $$file; \
-       echo "buildid=$(BUILDID)"   >> $$file;
-
-       # Edit the Xcode configuration file generated by autogen.sh:
-       # - the list of all our (static) libs
-       # - compiler flags
-       #
-       all_libs=`$(SRCDIR)/bin/lo-all-static-libs`; \
-       sed -e "s;^\(LINK_LDFLAGS =\).*$$;\1 
-Wl,-lz,-liconv,-map,$(WORKDIR)/\$$(TARGET_NAME).map $$all_libs;" \
-               -e "s,^\(OTHER_CFLAGS =\).*$$,\1 $(gb_GLOBALDEFS)," \
-               -e "s,^\(OTHER_CPLUSPLUSFLAGS =\).*$$,\1 $(gb_GLOBALDEFS)," \
-                       < $(BUILDDIR)/ios/lo.xcconfig > $(LO_XCCONFIG)
-
-       # Do *not* remove $(LO_XCCONFIG) in a clean target. It is created
-       # during configure, not in this custom gbuild makefile.
-
-
-$(call gb_CustomTarget_get_clean_target,ios/Lo_Xcconfig):
-       $(call gb_Output_announce,$(subst $(WORKDIR)/Clean/,,$@),$(false),ENV,2)
-       rm -rf $(IOSDIR)
-       rm -f $(WORKDIR)/CustomTarget/ios/Lo_Xcconfig.done
-
-
-# vim: set noet sw=4 ts=4:
diff --git a/ios/CustomTarget_setup.mk b/ios/CustomTarget_setup.mk
index d0c64d799d32..f526f23edab0 100644
--- a/ios/CustomTarget_setup.mk
+++ b/ios/CustomTarget_setup.mk
@@ -7,20 +7,20 @@
 # file, You can obtain one at http://mozilla.org/MPL/2.0/.
 #- Env ------------------------------------------------------------------------
 IOSGEN := $(SRCDIR)/ios/generated
-IOSKIT := $(IOSGEN)/loKit.xcconfig
-IOSAPP := $(IOSGEN)/loApp.xcconfig
+IOSKIT := $(BUILDDIR)/ios/loKit.xcconfig
+IOSAPP := $(BUILDDIR)/ios/loApp.xcconfig
+IOSRES := $(IOSGEN)/resources
 
 
 #- Top level  -----------------------------------------------------------------
 $(eval $(call gb_CustomTarget_CustomTarget,ios/setup))
 
-$(call gb_CustomTarget_get_target,ios/setup): $(IOSKIT) $(IOSAPP)
+$(call gb_CustomTarget_get_target,ios/setup): $(IOSKIT) $(IOSAPP) iosCopySetup
 
 
 #- Generate xcconfig files  ---------------------------------------------------
 $(IOSKIT) : $(BUILDDIR)/config_host.mk
        $(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),$(true),ENV,2)
-       @mkdir -p $(IOSGEN);
        @echo "// Xcode configuration properties" > $(IOSKIT)
        @echo "// To avoid confusion, the LO-specific ones that aren't as such 
used" >> $(IOSKIT)
        @echo "// Xcode (but only expanded in option values) are prefixed with" 
>> $(IOSKIT)
@@ -69,11 +69,71 @@ $(IOSAPP) : $(BUILDDIR)/config_host.mk
        @echo "LINK_LDFLAGS = -Wl,-lz,-liconv,-map,$(WORKDIR)/iosApp.map " >> 
$(IOSAPP)
        @echo "SYMROOT = $(WORKDIR)/ios/build\n" >> $(IOSAPP)
 
+#- Generate setup  ------------------------------------------------------------
+.PHONY : iosCopySetup
+iosCopySetup:
+ifeq ("$(wildcard $(IOSRES))","")
+       $(call gb_Output_announce,$(subst $(WORKDIR)/,,$@),$(true),ENV,2)
+
+       mkdir -p $(IOSGEN) $(IOSRES) $(IOSRES)/services \
+                $(IOSRES)/share/config $(IOSRES)/share/filter $(IOSRES)/program
+
+       # generate file with call declarations
+       $(SRCDIR)/solenv/bin/native-code.py \
+           -g core -g writer -g calc -g draw -g edit \
+           > $(IOSGEN)/native-code.mm
+
+       # generate resource files used to start/run LibreOffice
+       cp $(INSTDIR)/program/types.rdb             $(IOSRES)/udkapi.rdb
+       cp $(INSTDIR)/program/types/offapi.rdb      $(IOSRES)
+       cp $(INSTDIR)/program/types/oovbaapi.rdb    $(IOSRES)
+       cp $(INSTDIR)/program/services/services.rdb $(IOSRES)/services
+       cp $(INSTDIR)/program/services.rdb          $(IOSRES)
+       cp -R $(INSTDIR)/share/config/soffice.cfg $(IOSRES)/share/config
+       cp $(WORKDIR)/CustomTarget/i18npool/breakiterator/dict_*.data 
$(IOSRES)/share
+       cp $(INSTDIR)/share/filter/oox-drawingml-adj-names 
$(IOSRES)/share/filter
+       cp $(INSTDIR)/share/filter/oox-drawingml-cs-presets 
$(IOSRES)/share/filter
+       cp $(INSTDIR)/share/filter/vml-shape-types $(IOSRES)/share/filter
+       cp -R $(INSTDIR)/share/registry $(IOSRES)/share
+
+       # Set up rc, the "inifile". See getIniFileName_Impl().
+       echo '[Bootstrap]' > $(IOSRES)/rc
+       echo 'URE_BOOTSTRAP=file://$$APP_DATA_DIR/fundamentalrc' >> $(IOSRES)/rc
+       echo 'HOME=$$SYSUSERHOME' >> $(IOSRES)/rc
+
+       # Set up fundamentalrc, unorc, bootstraprc and versionrc.
+       file=$(IOSRES)/fundamentalrc; \
+       echo '[Bootstrap]'                                      >  
$(IOSRES)/fundamentalrc
+       echo 'LO_LIB_DIR=file://$$APP_DATA_DIR/lib/'            >> 
$(IOSRES)/fundamentalrc
+       echo 'BRAND_BASE_DIR=file://$$APP_DATA_DIR'             >> 
$(IOSRES)/fundamentalrc
+       echo 'CONFIGURATION_LAYERS=xcsxcu:$${BRAND_BASE_DIR}/share/registry ' \
+            'res:$${BRAND_BASE_DIR}/registry' >> $(IOSRES)/fundamentalrc
+       echo 'UNO_TYPES=file://$$APP_DATA_DIR/udkapi.rdb ' \
+            'file://$$APP_DATA_DIR/offapi.rdb' >> $(IOSRES)/fundamentalrc
+       echo 'UNO_SERVICES=file://$$APP_DATA_DIR/services.rdb ' \
+            'file://$$APP_DATA_DIR/services/services.rdb' >> 
$(IOSRES)/fundamentalrc
+       echo 'OSL_SOCKET_PATH=$$APP_DATA_DIR/cache' >> $(IOSRES)/fundamentalrc
+
+       echo '[Bootstrap]' > $(IOSRES)/unorc
+
+       # bootstraprc must be in $BRAND_BASE_DIR/program
+       echo '[Bootstrap]'                                     >  
$(IOSRES)/program/bootstraprc
+       echo 'InstallMode=<installmode>'                       >> 
$(IOSRES)/program/bootstraprc
+       echo "ProductKey=LibreOffice $(PRODUCTVERSION)"        >> 
$(IOSRES)/program/bootstraprc
+       echo 'UserInstallation=$$SYSUSERHOME/userinstallation' >> 
$(IOSRES)/program/bootstraprc
+
+       # Is this really needed?
+       echo '[Version]'            >  $(IOSRES)/program/versionrc
+       echo 'AllLanguages=en-US'   >> $(IOSRES)/program/versionrc
+       echo 'BuildVersion='        >> $(IOSRES)/program/versionrc
+       echo "buildid=$(BUILDID)"   >> $(IOSRES)/program/versionrc
+endif
 
 
+#- clean ios  -----------------------------------------------------------------
 $(call gb_CustomTarget_get_clean_target,ios/setup):
        $(call gb_Output_announce,$(subst $(WORKDIR)/Clean/,,$@),$(false),ENV,2)
-       rm -rf $(IOSGEN)
+       rm -rf $(IOSGEN) $(IOSKIT) $(IOSAPP)
 
 
 # vim: set noet sw=4 ts=4:
_______________________________________________
Libreoffice-commits mailing list
libreoffice-comm...@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits

Reply via email to