add iOS Image Node
This commit is contained in:
parent
471e87badc
commit
f1efee6a3e
2
iOS/.gitignore
vendored
2
iOS/.gitignore
vendored
@ -18,7 +18,7 @@ profile
|
|||||||
DerivedData
|
DerivedData
|
||||||
*.hmap
|
*.hmap
|
||||||
*.ipa
|
*.ipa
|
||||||
|
Example/Pods
|
||||||
# Bundler
|
# Bundler
|
||||||
.bundle
|
.bundle
|
||||||
|
|
||||||
|
@ -40,4 +40,5 @@ TODO: Add long description of the pod here.
|
|||||||
s.public_header_files = 'Pod/Classes/**/*.h'
|
s.public_header_files = 'Pod/Classes/**/*.h'
|
||||||
# s.frameworks = 'UIKit', 'MapKit'
|
# s.frameworks = 'UIKit', 'MapKit'
|
||||||
# s.dependency 'AFNetworking', '~> 2.3'
|
# s.dependency 'AFNetworking', '~> 2.3'
|
||||||
|
s.dependency 'SDWebImage', '~> 5.0'
|
||||||
end
|
end
|
||||||
|
@ -1,15 +1,24 @@
|
|||||||
PODS:
|
PODS:
|
||||||
- Doric (0.1.0)
|
- Doric (0.1.0):
|
||||||
|
- SDWebImage (~> 5.0)
|
||||||
|
- SDWebImage (5.0.6):
|
||||||
|
- SDWebImage/Core (= 5.0.6)
|
||||||
|
- SDWebImage/Core (5.0.6)
|
||||||
|
|
||||||
DEPENDENCIES:
|
DEPENDENCIES:
|
||||||
- Doric (from `../`)
|
- Doric (from `../`)
|
||||||
|
|
||||||
|
SPEC REPOS:
|
||||||
|
https://github.com/cocoapods/specs.git:
|
||||||
|
- SDWebImage
|
||||||
|
|
||||||
EXTERNAL SOURCES:
|
EXTERNAL SOURCES:
|
||||||
Doric:
|
Doric:
|
||||||
:path: "../"
|
:path: "../"
|
||||||
|
|
||||||
SPEC CHECKSUMS:
|
SPEC CHECKSUMS:
|
||||||
Doric: 302e4bcf98fb021ca88a5cd986afde45c7cf6320
|
Doric: 3b2bd0260ddecb3a7ec6ed95a88ace58c2a75685
|
||||||
|
SDWebImage: 920f1a2ff1ca8296ad34f6e0510a1ef1d70ac965
|
||||||
|
|
||||||
PODFILE CHECKSUM: 012563d71439e7e33e976dca3b59664ed56cee39
|
PODFILE CHECKSUM: 012563d71439e7e33e976dca3b59664ed56cee39
|
||||||
|
|
||||||
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricAsyncResult.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Extension/DoricBridgeExtension.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricConstant.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContext.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContextHolder.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContextManager.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricDriver.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricGroupNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricHLayoutNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSCoreExecutor.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSEngine.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSExecutorProtocal.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricModalPlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricNativePlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricPromise.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricRegistry.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricRootNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricShaderPlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricStackNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricTextNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricUtil.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricVLayoutNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricViewContainer.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricViewNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/UIView+Doric.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricAsyncResult.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Extension/DoricBridgeExtension.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricConstant.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContext.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContextHolder.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricContextManager.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricDriver.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricGroupNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricHLayoutNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSCoreExecutor.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSEngine.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Engine/DoricJSExecutorProtocal.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricModalPlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricNativePlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricPromise.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/DoricRegistry.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricRootNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Plugin/DoricShaderPlugin.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricStackNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricTextNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Util/DoricUtil.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricVLayoutNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricViewContainer.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/Shader/DoricViewNode.h
|
|
@ -1 +0,0 @@
|
|||||||
../../../../../Pod/Classes/UIView+Doric.h
|
|
24
iOS/Example/Pods/Local Podspecs/Doric.podspec.json
generated
24
iOS/Example/Pods/Local Podspecs/Doric.podspec.json
generated
@ -1,24 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "Doric",
|
|
||||||
"version": "0.1.0",
|
|
||||||
"summary": "A short description of Doric.",
|
|
||||||
"description": "TODO: Add long description of the pod here.",
|
|
||||||
"homepage": "https://github.com/penfeizhou/doric",
|
|
||||||
"license": {
|
|
||||||
"type": "MIT",
|
|
||||||
"file": "LICENSE"
|
|
||||||
},
|
|
||||||
"authors": {
|
|
||||||
"pengfei.zhou": "penfei.zhou@gmail.com"
|
|
||||||
},
|
|
||||||
"source": {
|
|
||||||
"git": "git@github.com:penfeizhou/doric.git",
|
|
||||||
"tag": "0.1.0"
|
|
||||||
},
|
|
||||||
"platforms": {
|
|
||||||
"ios": "8.0"
|
|
||||||
},
|
|
||||||
"source_files": "Pod/Classes/**/*",
|
|
||||||
"resources": "Pod/Assets/**/*",
|
|
||||||
"public_header_files": "Pod/Classes/**/*.h"
|
|
||||||
}
|
|
16
iOS/Example/Pods/Manifest.lock
generated
16
iOS/Example/Pods/Manifest.lock
generated
@ -1,16 +0,0 @@
|
|||||||
PODS:
|
|
||||||
- Doric (0.1.0)
|
|
||||||
|
|
||||||
DEPENDENCIES:
|
|
||||||
- Doric (from `../`)
|
|
||||||
|
|
||||||
EXTERNAL SOURCES:
|
|
||||||
Doric:
|
|
||||||
:path: "../"
|
|
||||||
|
|
||||||
SPEC CHECKSUMS:
|
|
||||||
Doric: 302e4bcf98fb021ca88a5cd986afde45c7cf6320
|
|
||||||
|
|
||||||
PODFILE CHECKSUM: 012563d71439e7e33e976dca3b59664ed56cee39
|
|
||||||
|
|
||||||
COCOAPODS: 1.7.5
|
|
1019
iOS/Example/Pods/Pods.xcodeproj/project.pbxproj
generated
1019
iOS/Example/Pods/Pods.xcodeproj/project.pbxproj
generated
File diff suppressed because it is too large
Load Diff
@ -1,5 +0,0 @@
|
|||||||
#import <Foundation/Foundation.h>
|
|
||||||
@interface PodsDummy_Doric : NSObject
|
|
||||||
@end
|
|
||||||
@implementation PodsDummy_Doric
|
|
||||||
@end
|
|
@ -1,12 +0,0 @@
|
|||||||
#ifdef __OBJC__
|
|
||||||
#import <UIKit/UIKit.h>
|
|
||||||
#else
|
|
||||||
#ifndef FOUNDATION_EXPORT
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
#define FOUNDATION_EXPORT extern "C"
|
|
||||||
#else
|
|
||||||
#define FOUNDATION_EXPORT extern
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
|||||||
CONFIGURATION_BUILD_DIR = ${PODS_CONFIGURATION_BUILD_DIR}/Doric
|
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Private" "${PODS_ROOT}/Headers/Private/Doric" "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_ROOT = ${SRCROOT}
|
|
||||||
PODS_TARGET_SRCROOT = ${PODS_ROOT}/../..
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = org.cocoapods.${PRODUCT_NAME:rfc1034identifier}
|
|
||||||
SKIP_INSTALL = YES
|
|
@ -1,26 +0,0 @@
|
|||||||
# Acknowledgements
|
|
||||||
This application makes use of the following third party libraries:
|
|
||||||
|
|
||||||
## Doric
|
|
||||||
|
|
||||||
Copyright (c) 2019 pengfei.zhou <penfei.zhou@gmail.com>
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
|
|
||||||
Generated by CocoaPods - https://cocoapods.org
|
|
@ -1,58 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>PreferenceSpecifiers</key>
|
|
||||||
<array>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>This application makes use of the following third party libraries:</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>Copyright (c) 2019 pengfei.zhou <penfei.zhou@gmail.com>
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
</string>
|
|
||||||
<key>License</key>
|
|
||||||
<string>MIT</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Doric</string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>Generated by CocoaPods - https://cocoapods.org</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string></string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
</array>
|
|
||||||
<key>StringsTable</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@ -1,5 +0,0 @@
|
|||||||
#import <Foundation/Foundation.h>
|
|
||||||
@interface PodsDummy_Pods_Example : NSObject
|
|
||||||
@end
|
|
||||||
@implementation PodsDummy_Pods_Example
|
|
||||||
@end
|
|
@ -1,137 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "mkdir -p ${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
mkdir -p "${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
SWIFT_STDLIB_PATH="${DT_TOOLCHAIN_DIR}/usr/lib/swift/${PLATFORM_NAME}"
|
|
||||||
|
|
||||||
# Used as a return value for each invocation of `strip_invalid_archs` function.
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
# Copies and strips a vendored framework
|
|
||||||
install_framework()
|
|
||||||
{
|
|
||||||
if [ -r "${BUILT_PRODUCTS_DIR}/$1" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$1"
|
|
||||||
elif [ -r "${BUILT_PRODUCTS_DIR}/$(basename "$1")" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$(basename "$1")"
|
|
||||||
elif [ -r "$1" ]; then
|
|
||||||
local source="$1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local destination="${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
if [ -L "${source}" ]; then
|
|
||||||
echo "Symlinked..."
|
|
||||||
source="$(readlink "${source}")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Use filter instead of exclude so missing patterns don't throw errors.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${destination}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${destination}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework "$1")"
|
|
||||||
binary="${destination}/${basename}.framework/${basename}"
|
|
||||||
if ! [ -r "$binary" ]; then
|
|
||||||
binary="${destination}/${basename}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"dynamically linked shared library"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Resign the code if required by the build settings to avoid unstable apps
|
|
||||||
code_sign_if_enabled "${destination}/$(basename "$1")"
|
|
||||||
|
|
||||||
# Embed linked Swift runtime libraries. No longer necessary as of Xcode 7.
|
|
||||||
if [ "${XCODE_VERSION_MAJOR}" -lt 7 ]; then
|
|
||||||
local swift_runtime_libs
|
|
||||||
swift_runtime_libs=$(xcrun otool -LX "$binary" | grep --color=never @rpath/libswift | sed -E s/@rpath\\/\(.+dylib\).*/\\1/g | uniq -u && exit ${PIPESTATUS[0]})
|
|
||||||
for lib in $swift_runtime_libs; do
|
|
||||||
echo "rsync -auv \"${SWIFT_STDLIB_PATH}/${lib}\" \"${destination}\""
|
|
||||||
rsync -auv "${SWIFT_STDLIB_PATH}/${lib}" "${destination}"
|
|
||||||
code_sign_if_enabled "${destination}/${lib}"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Copies and strips a vendored dSYM
|
|
||||||
install_dsym() {
|
|
||||||
local source="$1"
|
|
||||||
if [ -r "$source" ]; then
|
|
||||||
# Copy the dSYM into a the targets temp dir.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${DERIVED_FILES_DIR}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${DERIVED_FILES_DIR}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework.dSYM "$source")"
|
|
||||||
binary="${DERIVED_FILES_DIR}/${basename}.framework.dSYM/Contents/Resources/DWARF/${basename}"
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"Mach-O dSYM companion"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $STRIP_BINARY_RETVAL == 1 ]]; then
|
|
||||||
# Move the stripped file into its final destination.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${DERIVED_FILES_DIR}/${basename}.framework.dSYM\" \"${DWARF_DSYM_FOLDER_PATH}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${DERIVED_FILES_DIR}/${basename}.framework.dSYM" "${DWARF_DSYM_FOLDER_PATH}"
|
|
||||||
else
|
|
||||||
# The dSYM was not stripped at all, in this case touch a fake folder so the input/output paths from Xcode do not reexecute this script because the file is missing.
|
|
||||||
touch "${DWARF_DSYM_FOLDER_PATH}/${basename}.framework.dSYM"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Signs a framework with the provided identity
|
|
||||||
code_sign_if_enabled() {
|
|
||||||
if [ -n "${EXPANDED_CODE_SIGN_IDENTITY}" -a "${CODE_SIGNING_REQUIRED}" != "NO" -a "${CODE_SIGNING_ALLOWED}" != "NO" ]; then
|
|
||||||
# Use the current code_sign_identitiy
|
|
||||||
echo "Code Signing $1 with Identity ${EXPANDED_CODE_SIGN_IDENTITY_NAME}"
|
|
||||||
local code_sign_cmd="/usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements '$1'"
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
code_sign_cmd="$code_sign_cmd &"
|
|
||||||
fi
|
|
||||||
echo "$code_sign_cmd"
|
|
||||||
eval "$code_sign_cmd"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Strip invalid architectures
|
|
||||||
strip_invalid_archs() {
|
|
||||||
binary="$1"
|
|
||||||
# Get architectures for current target binary
|
|
||||||
binary_archs="$(lipo -info "$binary" | rev | cut -d ':' -f1 | awk '{$1=$1;print}' | rev)"
|
|
||||||
# Intersect them with the architectures we are building for
|
|
||||||
intersected_archs="$(echo ${ARCHS[@]} ${binary_archs[@]} | tr ' ' '\n' | sort | uniq -d)"
|
|
||||||
# If there are no archs supported by this binary then warn the user
|
|
||||||
if [[ -z "$intersected_archs" ]]; then
|
|
||||||
echo "warning: [CP] Vendored binary '$binary' contains architectures ($binary_archs) none of which match the current build architectures ($ARCHS)."
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
stripped=""
|
|
||||||
for arch in $binary_archs; do
|
|
||||||
if ! [[ "${ARCHS}" == *"$arch"* ]]; then
|
|
||||||
# Strip non-valid architectures in-place
|
|
||||||
lipo -remove "$arch" -output "$binary" "$binary" || exit 1
|
|
||||||
stripped="$stripped $arch"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ "$stripped" ]]; then
|
|
||||||
echo "Stripped $binary of architectures:$stripped"
|
|
||||||
fi
|
|
||||||
STRIP_BINARY_RETVAL=1
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
wait
|
|
||||||
fi
|
|
@ -1,3 +0,0 @@
|
|||||||
${PODS_ROOT}/Target Support Files/Pods-Example/Pods-Example-resources.sh
|
|
||||||
${PODS_ROOT}/../../Pod/Assets/doric-lib.js
|
|
||||||
${PODS_ROOT}/../../Pod/Assets/doric-sandbox.js
|
|
@ -1,2 +0,0 @@
|
|||||||
${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/doric-lib.js
|
|
||||||
${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/doric-sandbox.js
|
|
@ -1,3 +0,0 @@
|
|||||||
${PODS_ROOT}/Target Support Files/Pods-Example/Pods-Example-resources.sh
|
|
||||||
${PODS_ROOT}/../../Pod/Assets/doric-lib.js
|
|
||||||
${PODS_ROOT}/../../Pod/Assets/doric-sandbox.js
|
|
@ -1,2 +0,0 @@
|
|||||||
${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/doric-lib.js
|
|
||||||
${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/doric-sandbox.js
|
|
@ -1,131 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
set -u
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
function on_error {
|
|
||||||
echo "$(realpath -mq "${0}"):$1: error: Unexpected failure"
|
|
||||||
}
|
|
||||||
trap 'on_error $LINENO' ERR
|
|
||||||
|
|
||||||
if [ -z ${UNLOCALIZED_RESOURCES_FOLDER_PATH+x} ]; then
|
|
||||||
# If UNLOCALIZED_RESOURCES_FOLDER_PATH is not set, then there's nowhere for us to copy
|
|
||||||
# resources to, so exit 0 (signalling the script phase was successful).
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
|
|
||||||
RESOURCES_TO_COPY=${PODS_ROOT}/resources-to-copy-${TARGETNAME}.txt
|
|
||||||
> "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
XCASSET_FILES=()
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
case "${TARGETED_DEVICE_FAMILY:-}" in
|
|
||||||
1,2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad --target-device iphone"
|
|
||||||
;;
|
|
||||||
1)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device iphone"
|
|
||||||
;;
|
|
||||||
2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad"
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device tv"
|
|
||||||
;;
|
|
||||||
4)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device watch"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device mac"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
install_resource()
|
|
||||||
{
|
|
||||||
if [[ "$1" = /* ]] ; then
|
|
||||||
RESOURCE_PATH="$1"
|
|
||||||
else
|
|
||||||
RESOURCE_PATH="${PODS_ROOT}/$1"
|
|
||||||
fi
|
|
||||||
if [[ ! -e "$RESOURCE_PATH" ]] ; then
|
|
||||||
cat << EOM
|
|
||||||
error: Resource "$RESOURCE_PATH" not found. Run 'pod install' to update the copy resources script.
|
|
||||||
EOM
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
case $RESOURCE_PATH in
|
|
||||||
*.storyboard)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.xib)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.framework)
|
|
||||||
echo "mkdir -p ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" $RESOURCE_PATH ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
;;
|
|
||||||
*.xcdatamodel)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH"`.mom\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodel`.mom"
|
|
||||||
;;
|
|
||||||
*.xcdatamodeld)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd"
|
|
||||||
;;
|
|
||||||
*.xcmappingmodel)
|
|
||||||
echo "xcrun mapc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm\"" || true
|
|
||||||
xcrun mapc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm"
|
|
||||||
;;
|
|
||||||
*.xcassets)
|
|
||||||
ABSOLUTE_XCASSET_FILE="$RESOURCE_PATH"
|
|
||||||
XCASSET_FILES+=("$ABSOLUTE_XCASSET_FILE")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "$RESOURCE_PATH" || true
|
|
||||||
echo "$RESOURCE_PATH" >> "$RESOURCES_TO_COPY"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
if [[ "$CONFIGURATION" == "Debug" ]]; then
|
|
||||||
install_resource "${PODS_ROOT}/../../Pod/Assets/doric-lib.js"
|
|
||||||
install_resource "${PODS_ROOT}/../../Pod/Assets/doric-sandbox.js"
|
|
||||||
fi
|
|
||||||
if [[ "$CONFIGURATION" == "Release" ]]; then
|
|
||||||
install_resource "${PODS_ROOT}/../../Pod/Assets/doric-lib.js"
|
|
||||||
install_resource "${PODS_ROOT}/../../Pod/Assets/doric-sandbox.js"
|
|
||||||
fi
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
if [[ "${ACTION}" == "install" ]] && [[ "${SKIP_INSTALL}" == "NO" ]]; then
|
|
||||||
mkdir -p "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
fi
|
|
||||||
rm -f "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "${XCASSET_FILES:-}" ]
|
|
||||||
then
|
|
||||||
# Find all other xcassets (this unfortunately includes those of path pods and other targets).
|
|
||||||
OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d)
|
|
||||||
while read line; do
|
|
||||||
if [[ $line != "${PODS_ROOT}*" ]]; then
|
|
||||||
XCASSET_FILES+=("$line")
|
|
||||||
fi
|
|
||||||
done <<<"$OTHER_XCASSETS"
|
|
||||||
|
|
||||||
if [ -z ${ASSETCATALOG_COMPILER_APPICON_NAME+x} ]; then
|
|
||||||
printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
else
|
|
||||||
printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}" --app-icon "${ASSETCATALOG_COMPILER_APPICON_NAME}" --output-partial-info-plist "${TARGET_TEMP_DIR}/assetcatalog_generated_info_cocoapods.plist"
|
|
||||||
fi
|
|
||||||
fi
|
|
@ -1,8 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
LIBRARY_SEARCH_PATHS = $(inherited) "${PODS_CONFIGURATION_BUILD_DIR}/Doric"
|
|
||||||
OTHER_LDFLAGS = $(inherited) -ObjC -l"Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -1,8 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
LIBRARY_SEARCH_PATHS = $(inherited) "${PODS_CONFIGURATION_BUILD_DIR}/Doric"
|
|
||||||
OTHER_LDFLAGS = $(inherited) -ObjC -l"Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -1,3 +0,0 @@
|
|||||||
# Acknowledgements
|
|
||||||
This application makes use of the following third party libraries:
|
|
||||||
Generated by CocoaPods - https://cocoapods.org
|
|
@ -1,29 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>PreferenceSpecifiers</key>
|
|
||||||
<array>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>This application makes use of the following third party libraries:</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>Generated by CocoaPods - https://cocoapods.org</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string></string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
</array>
|
|
||||||
<key>StringsTable</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@ -1,5 +0,0 @@
|
|||||||
#import <Foundation/Foundation.h>
|
|
||||||
@interface PodsDummy_Pods_ExampleTests : NSObject
|
|
||||||
@end
|
|
||||||
@implementation PodsDummy_Pods_ExampleTests
|
|
||||||
@end
|
|
@ -1,137 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "mkdir -p ${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
mkdir -p "${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
SWIFT_STDLIB_PATH="${DT_TOOLCHAIN_DIR}/usr/lib/swift/${PLATFORM_NAME}"
|
|
||||||
|
|
||||||
# Used as a return value for each invocation of `strip_invalid_archs` function.
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
# Copies and strips a vendored framework
|
|
||||||
install_framework()
|
|
||||||
{
|
|
||||||
if [ -r "${BUILT_PRODUCTS_DIR}/$1" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$1"
|
|
||||||
elif [ -r "${BUILT_PRODUCTS_DIR}/$(basename "$1")" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$(basename "$1")"
|
|
||||||
elif [ -r "$1" ]; then
|
|
||||||
local source="$1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local destination="${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
if [ -L "${source}" ]; then
|
|
||||||
echo "Symlinked..."
|
|
||||||
source="$(readlink "${source}")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Use filter instead of exclude so missing patterns don't throw errors.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${destination}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${destination}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework "$1")"
|
|
||||||
binary="${destination}/${basename}.framework/${basename}"
|
|
||||||
if ! [ -r "$binary" ]; then
|
|
||||||
binary="${destination}/${basename}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"dynamically linked shared library"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Resign the code if required by the build settings to avoid unstable apps
|
|
||||||
code_sign_if_enabled "${destination}/$(basename "$1")"
|
|
||||||
|
|
||||||
# Embed linked Swift runtime libraries. No longer necessary as of Xcode 7.
|
|
||||||
if [ "${XCODE_VERSION_MAJOR}" -lt 7 ]; then
|
|
||||||
local swift_runtime_libs
|
|
||||||
swift_runtime_libs=$(xcrun otool -LX "$binary" | grep --color=never @rpath/libswift | sed -E s/@rpath\\/\(.+dylib\).*/\\1/g | uniq -u && exit ${PIPESTATUS[0]})
|
|
||||||
for lib in $swift_runtime_libs; do
|
|
||||||
echo "rsync -auv \"${SWIFT_STDLIB_PATH}/${lib}\" \"${destination}\""
|
|
||||||
rsync -auv "${SWIFT_STDLIB_PATH}/${lib}" "${destination}"
|
|
||||||
code_sign_if_enabled "${destination}/${lib}"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Copies and strips a vendored dSYM
|
|
||||||
install_dsym() {
|
|
||||||
local source="$1"
|
|
||||||
if [ -r "$source" ]; then
|
|
||||||
# Copy the dSYM into a the targets temp dir.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${DERIVED_FILES_DIR}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${DERIVED_FILES_DIR}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework.dSYM "$source")"
|
|
||||||
binary="${DERIVED_FILES_DIR}/${basename}.framework.dSYM/Contents/Resources/DWARF/${basename}"
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"Mach-O dSYM companion"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $STRIP_BINARY_RETVAL == 1 ]]; then
|
|
||||||
# Move the stripped file into its final destination.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${DERIVED_FILES_DIR}/${basename}.framework.dSYM\" \"${DWARF_DSYM_FOLDER_PATH}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${DERIVED_FILES_DIR}/${basename}.framework.dSYM" "${DWARF_DSYM_FOLDER_PATH}"
|
|
||||||
else
|
|
||||||
# The dSYM was not stripped at all, in this case touch a fake folder so the input/output paths from Xcode do not reexecute this script because the file is missing.
|
|
||||||
touch "${DWARF_DSYM_FOLDER_PATH}/${basename}.framework.dSYM"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Signs a framework with the provided identity
|
|
||||||
code_sign_if_enabled() {
|
|
||||||
if [ -n "${EXPANDED_CODE_SIGN_IDENTITY}" -a "${CODE_SIGNING_REQUIRED}" != "NO" -a "${CODE_SIGNING_ALLOWED}" != "NO" ]; then
|
|
||||||
# Use the current code_sign_identitiy
|
|
||||||
echo "Code Signing $1 with Identity ${EXPANDED_CODE_SIGN_IDENTITY_NAME}"
|
|
||||||
local code_sign_cmd="/usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements '$1'"
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
code_sign_cmd="$code_sign_cmd &"
|
|
||||||
fi
|
|
||||||
echo "$code_sign_cmd"
|
|
||||||
eval "$code_sign_cmd"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Strip invalid architectures
|
|
||||||
strip_invalid_archs() {
|
|
||||||
binary="$1"
|
|
||||||
# Get architectures for current target binary
|
|
||||||
binary_archs="$(lipo -info "$binary" | rev | cut -d ':' -f1 | awk '{$1=$1;print}' | rev)"
|
|
||||||
# Intersect them with the architectures we are building for
|
|
||||||
intersected_archs="$(echo ${ARCHS[@]} ${binary_archs[@]} | tr ' ' '\n' | sort | uniq -d)"
|
|
||||||
# If there are no archs supported by this binary then warn the user
|
|
||||||
if [[ -z "$intersected_archs" ]]; then
|
|
||||||
echo "warning: [CP] Vendored binary '$binary' contains architectures ($binary_archs) none of which match the current build architectures ($ARCHS)."
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
stripped=""
|
|
||||||
for arch in $binary_archs; do
|
|
||||||
if ! [[ "${ARCHS}" == *"$arch"* ]]; then
|
|
||||||
# Strip non-valid architectures in-place
|
|
||||||
lipo -remove "$arch" -output "$binary" "$binary" || exit 1
|
|
||||||
stripped="$stripped $arch"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ "$stripped" ]]; then
|
|
||||||
echo "Stripped $binary of architectures:$stripped"
|
|
||||||
fi
|
|
||||||
STRIP_BINARY_RETVAL=1
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
wait
|
|
||||||
fi
|
|
@ -1,106 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
|
|
||||||
RESOURCES_TO_COPY=${PODS_ROOT}/resources-to-copy-${TARGETNAME}.txt
|
|
||||||
> "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
XCASSET_FILES=()
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
case "${TARGETED_DEVICE_FAMILY}" in
|
|
||||||
1,2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad --target-device iphone"
|
|
||||||
;;
|
|
||||||
1)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device iphone"
|
|
||||||
;;
|
|
||||||
2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad"
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device tv"
|
|
||||||
;;
|
|
||||||
4)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device watch"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device mac"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
install_resource()
|
|
||||||
{
|
|
||||||
if [[ "$1" = /* ]] ; then
|
|
||||||
RESOURCE_PATH="$1"
|
|
||||||
else
|
|
||||||
RESOURCE_PATH="${PODS_ROOT}/$1"
|
|
||||||
fi
|
|
||||||
if [[ ! -e "$RESOURCE_PATH" ]] ; then
|
|
||||||
cat << EOM
|
|
||||||
error: Resource "$RESOURCE_PATH" not found. Run 'pod install' to update the copy resources script.
|
|
||||||
EOM
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
case $RESOURCE_PATH in
|
|
||||||
*.storyboard)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.xib)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.framework)
|
|
||||||
echo "mkdir -p ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" $RESOURCE_PATH ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
;;
|
|
||||||
*.xcdatamodel)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH"`.mom\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodel`.mom"
|
|
||||||
;;
|
|
||||||
*.xcdatamodeld)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd"
|
|
||||||
;;
|
|
||||||
*.xcmappingmodel)
|
|
||||||
echo "xcrun mapc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm\"" || true
|
|
||||||
xcrun mapc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm"
|
|
||||||
;;
|
|
||||||
*.xcassets)
|
|
||||||
ABSOLUTE_XCASSET_FILE="$RESOURCE_PATH"
|
|
||||||
XCASSET_FILES+=("$ABSOLUTE_XCASSET_FILE")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "$RESOURCE_PATH" || true
|
|
||||||
echo "$RESOURCE_PATH" >> "$RESOURCES_TO_COPY"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
if [[ "${ACTION}" == "install" ]] && [[ "${SKIP_INSTALL}" == "NO" ]]; then
|
|
||||||
mkdir -p "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
fi
|
|
||||||
rm -f "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "$XCASSET_FILES" ]
|
|
||||||
then
|
|
||||||
# Find all other xcassets (this unfortunately includes those of path pods and other targets).
|
|
||||||
OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d)
|
|
||||||
while read line; do
|
|
||||||
if [[ $line != "${PODS_ROOT}*" ]]; then
|
|
||||||
XCASSET_FILES+=("$line")
|
|
||||||
fi
|
|
||||||
done <<<"$OTHER_XCASSETS"
|
|
||||||
|
|
||||||
printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
fi
|
|
@ -1,6 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -1,6 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -1,3 +0,0 @@
|
|||||||
# Acknowledgements
|
|
||||||
This application makes use of the following third party libraries:
|
|
||||||
Generated by CocoaPods - https://cocoapods.org
|
|
@ -1,29 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>PreferenceSpecifiers</key>
|
|
||||||
<array>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>This application makes use of the following third party libraries:</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
<dict>
|
|
||||||
<key>FooterText</key>
|
|
||||||
<string>Generated by CocoaPods - https://cocoapods.org</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string></string>
|
|
||||||
<key>Type</key>
|
|
||||||
<string>PSGroupSpecifier</string>
|
|
||||||
</dict>
|
|
||||||
</array>
|
|
||||||
<key>StringsTable</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
<key>Title</key>
|
|
||||||
<string>Acknowledgements</string>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@ -1,5 +0,0 @@
|
|||||||
#import <Foundation/Foundation.h>
|
|
||||||
@interface PodsDummy_Pods_ExampleUITests : NSObject
|
|
||||||
@end
|
|
||||||
@implementation PodsDummy_Pods_ExampleUITests
|
|
||||||
@end
|
|
@ -1,137 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "mkdir -p ${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
mkdir -p "${CONFIGURATION_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
SWIFT_STDLIB_PATH="${DT_TOOLCHAIN_DIR}/usr/lib/swift/${PLATFORM_NAME}"
|
|
||||||
|
|
||||||
# Used as a return value for each invocation of `strip_invalid_archs` function.
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
# Copies and strips a vendored framework
|
|
||||||
install_framework()
|
|
||||||
{
|
|
||||||
if [ -r "${BUILT_PRODUCTS_DIR}/$1" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$1"
|
|
||||||
elif [ -r "${BUILT_PRODUCTS_DIR}/$(basename "$1")" ]; then
|
|
||||||
local source="${BUILT_PRODUCTS_DIR}/$(basename "$1")"
|
|
||||||
elif [ -r "$1" ]; then
|
|
||||||
local source="$1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local destination="${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
|
|
||||||
if [ -L "${source}" ]; then
|
|
||||||
echo "Symlinked..."
|
|
||||||
source="$(readlink "${source}")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Use filter instead of exclude so missing patterns don't throw errors.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${destination}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${destination}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework "$1")"
|
|
||||||
binary="${destination}/${basename}.framework/${basename}"
|
|
||||||
if ! [ -r "$binary" ]; then
|
|
||||||
binary="${destination}/${basename}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"dynamically linked shared library"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Resign the code if required by the build settings to avoid unstable apps
|
|
||||||
code_sign_if_enabled "${destination}/$(basename "$1")"
|
|
||||||
|
|
||||||
# Embed linked Swift runtime libraries. No longer necessary as of Xcode 7.
|
|
||||||
if [ "${XCODE_VERSION_MAJOR}" -lt 7 ]; then
|
|
||||||
local swift_runtime_libs
|
|
||||||
swift_runtime_libs=$(xcrun otool -LX "$binary" | grep --color=never @rpath/libswift | sed -E s/@rpath\\/\(.+dylib\).*/\\1/g | uniq -u && exit ${PIPESTATUS[0]})
|
|
||||||
for lib in $swift_runtime_libs; do
|
|
||||||
echo "rsync -auv \"${SWIFT_STDLIB_PATH}/${lib}\" \"${destination}\""
|
|
||||||
rsync -auv "${SWIFT_STDLIB_PATH}/${lib}" "${destination}"
|
|
||||||
code_sign_if_enabled "${destination}/${lib}"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Copies and strips a vendored dSYM
|
|
||||||
install_dsym() {
|
|
||||||
local source="$1"
|
|
||||||
if [ -r "$source" ]; then
|
|
||||||
# Copy the dSYM into a the targets temp dir.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${source}\" \"${DERIVED_FILES_DIR}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${source}" "${DERIVED_FILES_DIR}"
|
|
||||||
|
|
||||||
local basename
|
|
||||||
basename="$(basename -s .framework.dSYM "$source")"
|
|
||||||
binary="${DERIVED_FILES_DIR}/${basename}.framework.dSYM/Contents/Resources/DWARF/${basename}"
|
|
||||||
|
|
||||||
# Strip invalid architectures so "fat" simulator / device frameworks work on device
|
|
||||||
if [[ "$(file "$binary")" == *"Mach-O dSYM companion"* ]]; then
|
|
||||||
strip_invalid_archs "$binary"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $STRIP_BINARY_RETVAL == 1 ]]; then
|
|
||||||
# Move the stripped file into its final destination.
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter \"- CVS/\" --filter \"- .svn/\" --filter \"- .git/\" --filter \"- .hg/\" --filter \"- Headers\" --filter \"- PrivateHeaders\" --filter \"- Modules\" \"${DERIVED_FILES_DIR}/${basename}.framework.dSYM\" \"${DWARF_DSYM_FOLDER_PATH}\""
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" --filter "- CVS/" --filter "- .svn/" --filter "- .git/" --filter "- .hg/" --filter "- Headers" --filter "- PrivateHeaders" --filter "- Modules" "${DERIVED_FILES_DIR}/${basename}.framework.dSYM" "${DWARF_DSYM_FOLDER_PATH}"
|
|
||||||
else
|
|
||||||
# The dSYM was not stripped at all, in this case touch a fake folder so the input/output paths from Xcode do not reexecute this script because the file is missing.
|
|
||||||
touch "${DWARF_DSYM_FOLDER_PATH}/${basename}.framework.dSYM"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Signs a framework with the provided identity
|
|
||||||
code_sign_if_enabled() {
|
|
||||||
if [ -n "${EXPANDED_CODE_SIGN_IDENTITY}" -a "${CODE_SIGNING_REQUIRED}" != "NO" -a "${CODE_SIGNING_ALLOWED}" != "NO" ]; then
|
|
||||||
# Use the current code_sign_identitiy
|
|
||||||
echo "Code Signing $1 with Identity ${EXPANDED_CODE_SIGN_IDENTITY_NAME}"
|
|
||||||
local code_sign_cmd="/usr/bin/codesign --force --sign ${EXPANDED_CODE_SIGN_IDENTITY} ${OTHER_CODE_SIGN_FLAGS} --preserve-metadata=identifier,entitlements '$1'"
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
code_sign_cmd="$code_sign_cmd &"
|
|
||||||
fi
|
|
||||||
echo "$code_sign_cmd"
|
|
||||||
eval "$code_sign_cmd"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Strip invalid architectures
|
|
||||||
strip_invalid_archs() {
|
|
||||||
binary="$1"
|
|
||||||
# Get architectures for current target binary
|
|
||||||
binary_archs="$(lipo -info "$binary" | rev | cut -d ':' -f1 | awk '{$1=$1;print}' | rev)"
|
|
||||||
# Intersect them with the architectures we are building for
|
|
||||||
intersected_archs="$(echo ${ARCHS[@]} ${binary_archs[@]} | tr ' ' '\n' | sort | uniq -d)"
|
|
||||||
# If there are no archs supported by this binary then warn the user
|
|
||||||
if [[ -z "$intersected_archs" ]]; then
|
|
||||||
echo "warning: [CP] Vendored binary '$binary' contains architectures ($binary_archs) none of which match the current build architectures ($ARCHS)."
|
|
||||||
STRIP_BINARY_RETVAL=0
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
stripped=""
|
|
||||||
for arch in $binary_archs; do
|
|
||||||
if ! [[ "${ARCHS}" == *"$arch"* ]]; then
|
|
||||||
# Strip non-valid architectures in-place
|
|
||||||
lipo -remove "$arch" -output "$binary" "$binary" || exit 1
|
|
||||||
stripped="$stripped $arch"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ "$stripped" ]]; then
|
|
||||||
echo "Stripped $binary of architectures:$stripped"
|
|
||||||
fi
|
|
||||||
STRIP_BINARY_RETVAL=1
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "${COCOAPODS_PARALLEL_CODE_SIGN}" == "true" ]; then
|
|
||||||
wait
|
|
||||||
fi
|
|
@ -1,106 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
set -e
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
|
|
||||||
RESOURCES_TO_COPY=${PODS_ROOT}/resources-to-copy-${TARGETNAME}.txt
|
|
||||||
> "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
XCASSET_FILES=()
|
|
||||||
|
|
||||||
# This protects against multiple targets copying the same framework dependency at the same time. The solution
|
|
||||||
# was originally proposed here: https://lists.samba.org/archive/rsync/2008-February/020158.html
|
|
||||||
RSYNC_PROTECT_TMP_FILES=(--filter "P .*.??????")
|
|
||||||
|
|
||||||
case "${TARGETED_DEVICE_FAMILY}" in
|
|
||||||
1,2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad --target-device iphone"
|
|
||||||
;;
|
|
||||||
1)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device iphone"
|
|
||||||
;;
|
|
||||||
2)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device ipad"
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device tv"
|
|
||||||
;;
|
|
||||||
4)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device watch"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
TARGET_DEVICE_ARGS="--target-device mac"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
install_resource()
|
|
||||||
{
|
|
||||||
if [[ "$1" = /* ]] ; then
|
|
||||||
RESOURCE_PATH="$1"
|
|
||||||
else
|
|
||||||
RESOURCE_PATH="${PODS_ROOT}/$1"
|
|
||||||
fi
|
|
||||||
if [[ ! -e "$RESOURCE_PATH" ]] ; then
|
|
||||||
cat << EOM
|
|
||||||
error: Resource "$RESOURCE_PATH" not found. Run 'pod install' to update the copy resources script.
|
|
||||||
EOM
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
case $RESOURCE_PATH in
|
|
||||||
*.storyboard)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .storyboard`.storyboardc" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.xib)
|
|
||||||
echo "ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile ${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib $RESOURCE_PATH --sdk ${SDKROOT} ${TARGET_DEVICE_ARGS}" || true
|
|
||||||
ibtool --reference-external-strings-file --errors --warnings --notices --minimum-deployment-target ${!DEPLOYMENT_TARGET_SETTING_NAME} --output-format human-readable-text --compile "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename \"$RESOURCE_PATH\" .xib`.nib" "$RESOURCE_PATH" --sdk "${SDKROOT}" ${TARGET_DEVICE_ARGS}
|
|
||||||
;;
|
|
||||||
*.framework)
|
|
||||||
echo "mkdir -p ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
echo "rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" $RESOURCE_PATH ${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}" || true
|
|
||||||
rsync --delete -av "${RSYNC_PROTECT_TMP_FILES[@]}" "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}"
|
|
||||||
;;
|
|
||||||
*.xcdatamodel)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH"`.mom\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodel`.mom"
|
|
||||||
;;
|
|
||||||
*.xcdatamodeld)
|
|
||||||
echo "xcrun momc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd\"" || true
|
|
||||||
xcrun momc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcdatamodeld`.momd"
|
|
||||||
;;
|
|
||||||
*.xcmappingmodel)
|
|
||||||
echo "xcrun mapc \"$RESOURCE_PATH\" \"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm\"" || true
|
|
||||||
xcrun mapc "$RESOURCE_PATH" "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/`basename "$RESOURCE_PATH" .xcmappingmodel`.cdm"
|
|
||||||
;;
|
|
||||||
*.xcassets)
|
|
||||||
ABSOLUTE_XCASSET_FILE="$RESOURCE_PATH"
|
|
||||||
XCASSET_FILES+=("$ABSOLUTE_XCASSET_FILE")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "$RESOURCE_PATH" || true
|
|
||||||
echo "$RESOURCE_PATH" >> "$RESOURCES_TO_COPY"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
mkdir -p "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
if [[ "${ACTION}" == "install" ]] && [[ "${SKIP_INSTALL}" == "NO" ]]; then
|
|
||||||
mkdir -p "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
rsync -avr --copy-links --no-relative --exclude '*/.svn/*' --files-from="$RESOURCES_TO_COPY" / "${INSTALL_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
fi
|
|
||||||
rm -f "$RESOURCES_TO_COPY"
|
|
||||||
|
|
||||||
if [[ -n "${WRAPPER_EXTENSION}" ]] && [ "`xcrun --find actool`" ] && [ -n "$XCASSET_FILES" ]
|
|
||||||
then
|
|
||||||
# Find all other xcassets (this unfortunately includes those of path pods and other targets).
|
|
||||||
OTHER_XCASSETS=$(find "$PWD" -iname "*.xcassets" -type d)
|
|
||||||
while read line; do
|
|
||||||
if [[ $line != "${PODS_ROOT}*" ]]; then
|
|
||||||
XCASSET_FILES+=("$line")
|
|
||||||
fi
|
|
||||||
done <<<"$OTHER_XCASSETS"
|
|
||||||
|
|
||||||
printf "%s\0" "${XCASSET_FILES[@]}" | xargs -0 xcrun actool --output-format human-readable-text --notices --warnings --platform "${PLATFORM_NAME}" --minimum-deployment-target "${!DEPLOYMENT_TARGET_SETTING_NAME}" ${TARGET_DEVICE_ARGS} --compress-pngs --compile "${BUILT_PRODUCTS_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}"
|
|
||||||
fi
|
|
@ -1,6 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -1,6 +0,0 @@
|
|||||||
GCC_PREPROCESSOR_DEFINITIONS = $(inherited) COCOAPODS=1
|
|
||||||
HEADER_SEARCH_PATHS = $(inherited) "${PODS_ROOT}/Headers/Public" "${PODS_ROOT}/Headers/Public/Doric"
|
|
||||||
PODS_BUILD_DIR = ${BUILD_DIR}
|
|
||||||
PODS_CONFIGURATION_BUILD_DIR = ${PODS_BUILD_DIR}/$(CONFIGURATION)$(EFFECTIVE_PLATFORM_NAME)
|
|
||||||
PODS_PODFILE_DIR_PATH = ${SRCROOT}/.
|
|
||||||
PODS_ROOT = ${SRCROOT}/Pods
|
|
@ -12,6 +12,7 @@
|
|||||||
#import "DoricVLayoutNode.h"
|
#import "DoricVLayoutNode.h"
|
||||||
#import "DoricHLayoutNode.h"
|
#import "DoricHLayoutNode.h"
|
||||||
#import "DoricTextNode.h"
|
#import "DoricTextNode.h"
|
||||||
|
#import "DoricImageNode.h"
|
||||||
|
|
||||||
@interface DoricRegistry ()
|
@interface DoricRegistry ()
|
||||||
|
|
||||||
@ -41,7 +42,7 @@ - (void)innerRegister {
|
|||||||
[self registerViewNode:DoricVLayoutNode.class withName:@"VLayout"];
|
[self registerViewNode:DoricVLayoutNode.class withName:@"VLayout"];
|
||||||
[self registerViewNode:DoricHLayoutNode.class withName:@"HLayout"];
|
[self registerViewNode:DoricHLayoutNode.class withName:@"HLayout"];
|
||||||
[self registerViewNode:DoricTextNode.class withName:@"Text"];
|
[self registerViewNode:DoricTextNode.class withName:@"Text"];
|
||||||
|
[self registerViewNode:DoricImageNode.class withName:@"Image"];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)registerJSBundle:(NSString *)bundle withName:(NSString *)name {
|
- (void)registerJSBundle:(NSString *)bundle withName:(NSString *)name {
|
||||||
|
16
iOS/Pod/Classes/Shader/DoricImageNode.h
Normal file
16
iOS/Pod/Classes/Shader/DoricImageNode.h
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
//
|
||||||
|
// DoricImageNode.h
|
||||||
|
// Doric
|
||||||
|
//
|
||||||
|
// Created by pengfei.zhou on 2019/8/6.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import "DoricViewNode.h"
|
||||||
|
|
||||||
|
NS_ASSUME_NONNULL_BEGIN
|
||||||
|
|
||||||
|
@interface DoricImageNode : DoricViewNode<UIImageView *>
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
NS_ASSUME_NONNULL_END
|
36
iOS/Pod/Classes/Shader/DoricImageNode.m
Normal file
36
iOS/Pod/Classes/Shader/DoricImageNode.m
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
//
|
||||||
|
// DoricImageNode.m
|
||||||
|
// Doric
|
||||||
|
//
|
||||||
|
// Created by pengfei.zhou on 2019/8/6.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import "DoricImageNode.h"
|
||||||
|
#import <SDWebImage/SDWebImage.h>
|
||||||
|
|
||||||
|
@implementation DoricImageNode
|
||||||
|
|
||||||
|
- (UIView *)build:(NSDictionary *)props {
|
||||||
|
return [[UIImageView alloc] init];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)blendView:(UIImageView *)view forPropName:(NSString *)name propValue:(id)prop {
|
||||||
|
if ([name isEqualToString:@"imageUrl"]) {
|
||||||
|
__weak typeof(self) _self = self;
|
||||||
|
[view sd_setImageWithURL:[NSURL URLWithString:prop] completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
|
||||||
|
__strong typeof(_self) self = _self;
|
||||||
|
[self requestLayout];
|
||||||
|
}];
|
||||||
|
} else {
|
||||||
|
[super blendView:view forPropName:name propValue:prop];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)measureByParent:(DoricGroupNode *)parent {
|
||||||
|
DoricLayoutDesc widthSpec = self.layoutParams.width;
|
||||||
|
DoricLayoutDesc heightSpec = self.layoutParams.height;
|
||||||
|
if (widthSpec == LAYOUT_WRAP_CONTENT || heightSpec == LAYOUT_WRAP_CONTENT) {
|
||||||
|
[self.view sizeToFit];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@end
|
@ -14,8 +14,11 @@ - (void)setupRootView:(UIView *)view {
|
|||||||
|
|
||||||
- (void)render:(NSDictionary *)props {
|
- (void)render:(NSDictionary *)props {
|
||||||
[self blend:props];
|
[self blend:props];
|
||||||
|
[self requestLayout];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)requestLayout {
|
||||||
[self measureByParent:self];
|
[self measureByParent:self];
|
||||||
[self layoutByParent:self];
|
[self layoutByParent:self];
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -53,6 +53,8 @@ NS_ASSUME_NONNULL_BEGIN
|
|||||||
- (void)layoutByParent:(DoricGroupNode *)parent;
|
- (void)layoutByParent:(DoricGroupNode *)parent;
|
||||||
|
|
||||||
+ (DoricViewNode *)create:(DoricContext *)context withType:(NSString *)type;
|
+ (DoricViewNode *)create:(DoricContext *)context withType:(NSString *)type;
|
||||||
|
|
||||||
|
- (void)requestLayout;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
NS_ASSUME_NONNULL_END
|
NS_ASSUME_NONNULL_END
|
||||||
|
@ -178,7 +178,11 @@ - (CGFloat)measuredHeight {
|
|||||||
}
|
}
|
||||||
|
|
||||||
- (void)measureByParent:(DoricGroupNode *)parent {
|
- (void)measureByParent:(DoricGroupNode *)parent {
|
||||||
|
DoricLayoutDesc widthSpec = self.layoutParams.width;
|
||||||
|
DoricLayoutDesc heightSpec = self.layoutParams.height;
|
||||||
|
if (widthSpec == LAYOUT_WRAP_CONTENT || heightSpec == LAYOUT_WRAP_CONTENT) {
|
||||||
|
[self.view sizeToFit];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)layoutByParent:(DoricGroupNode *)parent {
|
- (void)layoutByParent:(DoricGroupNode *)parent {
|
||||||
@ -296,4 +300,8 @@ - (void)setCenterY:(CGFloat)centerY {
|
|||||||
((UIView *)self.view).centerY = centerY;
|
((UIView *)self.view).centerY = centerY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)requestLayout {
|
||||||
|
[self.parent requestLayout];
|
||||||
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
Reference in New Issue
Block a user