From e507ac6b33e3a33880bb1aa4cb21cde7581be192 Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期四, 28 十二月 2023 21:25:58 +0800
Subject: [PATCH] 0312 打包

---
 Assets/Editor/XCodeProjectMod.cs |  398 +++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 246 insertions(+), 152 deletions(-)

diff --git a/Assets/Editor/XCodeProjectMod.cs b/Assets/Editor/XCodeProjectMod.cs
index 7b5fcec..958e5e2 100644
--- a/Assets/Editor/XCodeProjectMod.cs
+++ b/Assets/Editor/XCodeProjectMod.cs
@@ -1,13 +1,13 @@
-锘縰sing System.Collections.Generic;
+锘縰sing DG.Tweening.Plugins.Core.PathCore;
+using System;
+using System.Collections.Generic;
 using System.IO;
 using UnityEditor;
 using UnityEditor.iOS.Xcode.Custom;
-using UnityEditor.iOS.Xcode.Custom.Extensions;
 using UnityEngine;
 
 public class XCodeProjectMod
 {
-#if UNITY_IOS
     private const string CODE_SIGN_DEVELOPER = "";
     private const string CODE_SIGN_DISTRIBUTION = "";
     private const string PROVISIONING_DEVELOPER = "";
@@ -22,67 +22,103 @@
             return;
         }
 
+
+        if (ClientPackage.versionConfig1.sdkFileName.Trim().Length == 0)
+        {
+            DoPBXProject(path);
+            BuildPlist(path);
+            ModifyFile(path);
+        }
+        else if (ClientPackage.versionConfig1.sdkFileName == "mlgtgame_quick")
+        {
+            DoPBXProject1(path);
+            BuildPlist1(path);
+            ModifyFile1(path);
+        }
+        else if (ClientPackage.versionConfig1.sdkFileName == "mlgtgame_quickhy")
+        {
+            DoPBXProject(path);
+
+            ModifyFile(path);
+        }
+
+       
+    }
+
+    //鍜櫆
+    static void DoPBXProject(string path)
+    {
         string _projectPath = PBXProject.GetPBXProjectPath(path);
 
-        PBXProject _project = new PBXProject();
-        _project.ReadFromString(File.ReadAllText(_projectPath));
+        PBXProject project = new PBXProject();
+        project.ReadFromString(File.ReadAllText(_projectPath));
 
-        string _targetGUID = _project.TargetGuidByName(PBXProject.GetUnityTargetName());
-
-        //var _codeSign = Debug.isDebugBuild ? CODE_SIGN_DEVELOPER : CODE_SIGN_DISTRIBUTION;
-        //var _provision = Debug.isDebugBuild ? PROVISIONING_DEVELOPER : PROVISIONING_DISTRIBUTION;
+        string targetGUID = project.TargetGuidByName(PBXProject.GetUnityTargetName());
+        string fwTargetGUID = project.TargetGuidByName("UnityFramework");
 
         // BuildSetting閲岀殑鐩稿叧璁剧疆
-        _project.SetBuildProperty(_targetGUID, "ENABLE_BITCODE", "NO");
-        _project.SetBuildProperty(_targetGUID, "DEVELOPMENT_TEAM", TEAM);
+        project.SetBuildProperty(project.ProjectGuid(), "ENABLE_BITCODE", "NO");
+        project.SetBuildProperty(targetGUID, "ENABLE_BITCODE", "NO");
+        project.SetBuildProperty(targetGUID, "DEVELOPMENT_TEAM", TEAM);
 
-        _project.AddBuildProperty(_targetGUID, "OTHER_LDFLAGS", "-ObjC");
-        _project.AddBuildProperty(_targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
-
-        // 澶勭悊 Framework
-        // FreeSDK
-        _project.AddFrameworkToProject(_targetGUID, "CoreGraphics.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "Security.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "CoreTelephony.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "StoreKit.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "MobileCoreServices.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "SystemConfiguration.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "AdSupport.framework", true);
-
-        // 鏋佸厜鎺ㄩ��
-        // JPush
-        _project.AddFrameworkToProject(_targetGUID, "CFNetwork.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "CoreFoundation.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "Foundation.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "UIKit.framework", true);
-        _project.AddFrameworkToProject(_targetGUID, "UserNotifications.framework", true);
+        project.AddBuildProperty(targetGUID, "OTHER_LDFLAGS", "-ObjC");
+        project.AddBuildProperty(targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
+        //wkwebview
+        project.AddFrameworkToProject(fwTargetGUID, "WebKit.framework", true);
+
+        project.AddFrameworkToProject(fwTargetGUID, "SystemConfiguration.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "Security.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "JavaScriptCore.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "Accelerate.framework", true);
 
         // 澶勭悊 搴撴枃浠�
-        _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libz.tbd", "Frameworks/libz.tbd", PBXSourceTree.Sdk));
-        _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libsqlite3.tbd", "Frameworks/libsqlite3.tbd", PBXSourceTree.Sdk));
-        _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libc++.tbd", "Frameworks/libc++.tbd", PBXSourceTree.Sdk));
-        _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libiconv.tbd", "Frameworks/libiconv.tbd", PBXSourceTree.Sdk));
-        _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libresolv.tbd", "Frameworks/libresolv.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libz.tbd", "Frameworks/libz.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libsqlite3.tbd", "Frameworks/libsqlite3.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libc++.tbd", "Frameworks/libc++.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libiconv.tbd", "Frameworks/libiconv.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libresolv.tbd", "Frameworks/libresolv.tbd", PBXSourceTree.Sdk));
 
-        // mr_sdk
-        HandleMrSDK(_project, _targetGUID);
+        //UnityFramework
+        project.AddBuildProperty(fwTargetGUID, "OTHER_LDFLAGS", "-ObjC");
 
-        // sp_sdk
-        HandleSpSDK(_project, _targetGUID);
+        File.WriteAllText(_projectPath, project.WriteToString());
+    }
+
+    //quick鍥藉唴
+    static void DoPBXProject1(string path)
+    {
+        string _projectPath = PBXProject.GetPBXProjectPath(path);
 
-        File.WriteAllText(_projectPath, _project.WriteToString());
+        PBXProject project = new PBXProject();
+        project.ReadFromString(File.ReadAllText(_projectPath));
 
-        var _capabilityMgr = new ProjectCapabilityManager(_projectPath, "game003.entitlements", PBXProject.GetUnityTargetName());
-        _capabilityMgr.AddInAppPurchase();
-        _capabilityMgr.AddPushNotifications(true);
-        _capabilityMgr.WriteToFile();
+        string targetGUID = project.TargetGuidByName(PBXProject.GetUnityTargetName());
+        string fwTargetGUID = project.TargetGuidByName("UnityFramework");
+
+        // BuildSetting閲岀殑鐩稿叧璁剧疆
+        project.SetBuildProperty(project.ProjectGuid(), "ENABLE_BITCODE", "NO");
+        project.SetBuildProperty(targetGUID, "ENABLE_BITCODE", "NO");
+        project.SetBuildProperty(targetGUID, "DEVELOPMENT_TEAM", TEAM);
+
+        project.AddBuildProperty(targetGUID, "OTHER_LDFLAGS", "-ObjC");
+        project.AddBuildProperty(targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
+        //wkwebview
+        project.AddFrameworkToProject(fwTargetGUID, "WebKit.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "SystemConfiguration.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "Security.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "JavaScriptCore.framework", true);
+
+        // 澶勭悊 搴撴枃浠�
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libz.tbd", "Frameworks/libz.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libsqlite3.tbd", "Frameworks/libsqlite3.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libc++.tbd", "Frameworks/libc++.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libiconv.tbd", "Frameworks/libiconv.tbd", PBXSourceTree.Sdk));
+        project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libresolv.tbd", "Frameworks/libresolv.tbd", PBXSourceTree.Sdk));
+
+        //UnityFramework
+        project.AddBuildProperty(fwTargetGUID, "OTHER_LDFLAGS", "-ObjC");
 
-        BuildPlist(path);
-
-        if (!s_IsAppend)
-        {
-            ModifyFile(path);
-        }
+        File.WriteAllText(_projectPath, project.WriteToString());
     }
 
     private static void BuildPlist(string path)
@@ -100,95 +136,174 @@
         _dict.SetBoolean("NSIncludesSubdomains", true);
         _dict.SetBoolean("NSExceptionAllowsInsecureHTTPLoads", true);
 
-        _rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹﹀厠椋庢潈闄�");
-        _rootDict.SetString("NSPhotoLibraryAddUsageDescription", "浣跨敤鐩稿唽鏉冮檺,鐢ㄤ互瀛樺偍鎴睆鐨勮处鍙蜂俊鎭�,浠ラ槻蹇樿璐﹀彿瀵嗙爜");
+        _rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹ュ厠棰ㄦ瑠闄�");
+        _rootDict.SetString("NSPhotoLibraryAddUsageDescription", "闇�瑕佹偍鐨勫悓鎰忥紝淇濆瓨鍦栫墖鍒扮浉鍐�");
+        //_rootDict.SetString("NSCameraUsageDescription", "闇�瑕佹偍鐨勫悓鎰忥紝鎵嶈兘浣跨敤鐩告");
+        _rootDict.SetString("NSUserTrackingUsageDescription", "闇�瑕佹偍鐨勫悓鎰忥紝鎵嶈兘浣跨敤寤e憡杩借工");
+            
+        _rootDict.SetString("FacebookAppID", "843918290533426");
+        _rootDict.SetString("FacebookClientToken", "f36292a301cc9970a5ff50fdb0f61bd9");
+        _rootDict.SetString("FacebookDisplayName", "鍒�鍔嶈悓淇�");
 
-        _rootDict.SetString("YLChannelId", "1000");
-        _rootDict.SetString("YLPlatformId", "1000");
+
+
+        PlistElementArray nsURLTypes = _rootDict.CreateArray("CFBundleURLTypes");
+        var dict0 = nsURLTypes.AddDict();
+        dict0.SetString("CFBundleTypeRole", "Editor");
+        dict0.SetString("CFBundleURLName", "MY");
+        var schemesArray = dict0.CreateArray("CFBundleURLSchemes");
+        schemesArray.AddString("MYAliPayScheme20003");
+
+        dict0 = nsURLTypes.AddDict();
+        dict0.SetString("CFBundleTypeRole", "Editor");
+        dict0.SetString("CFBundleURLName", "fb");
+        schemesArray = dict0.CreateArray("CFBundleURLSchemes");
+        schemesArray.AddString("fb843918290533426");
+
+
+        dict0 = nsURLTypes.AddDict();
+        dict0.SetString("CFBundleTypeRole", "Editor");
+        dict0.SetString("CFBundleURLName", "Google");
+        schemesArray = dict0.CreateArray("CFBundleURLSchemes");
+        schemesArray.AddString("com.googleusercontent.apps.248164024994-m66oqvtjomqh1r8je01gkvk5bhn76m0k");
+
+        var array1 = _rootDict.CreateArray("LSApplicationQueriesSchemes");
+        array1.AddString("safepay");
+        array1.AddString("itms-services");
+        array1.AddString("wechat");
+        array1.AddString("weixin");
+        array1.AddString("mqqapi");
+        array1.AddString("mqq");
+        array1.AddString("mqqOpensdkSSoLogin");
+        array1.AddString("mqqconnect");
+        array1.AddString("mqqopensdkdataline");
+        array1.AddString("mqqopensdkgrouptribeshare");
+        array1.AddString("mqqopensdkfriend");
+        array1.AddString("mqqopensdkapi");
+        array1.AddString("mqqopensdkapiV2");
+        array1.AddString("mqqopensdkapiV3");
+        array1.AddString("mqzoneopensdk");
+        array1.AddString("wtloginmqq");
+        array1.AddString("wtloginmqq2");
+        array1.AddString("mqqwpa");
+        array1.AddString("mqzone");
+        array1.AddString("mqzonev2");
+        array1.AddString("mqzoneshare");
+        array1.AddString("wtloginqzone");
+        array1.AddString("mqzonewx");
+        array1.AddString("mqzoneopensdkapiV2");
+        array1.AddString("mqzoneopensdkapi19");
+        array1.AddString("mqzoneopensdkapi");
+        array1.AddString("mqzoneopensdk");
+        array1.AddString("tim");
+        array1.AddString("alipay");
+        array1.AddString("alipayqr");
+        array1.AddString("alipayshare");
+        array1.AddString("alipays");
+        array1.AddString("pinterestsdk.v1");
+        array1.AddString("weixinULAPI");
+        array1.AddString("fb");
+        array1.AddString("fbapi");
+
 
         File.WriteAllText(_plistPath, _plist.WriteToString());
     }
 
+    private static void BuildPlist1(string path)
+    {
+        string _plistPath = path + "/Info.plist";
+
+        PlistDocument _plist = new PlistDocument();
+        _plist.ReadFromString(File.ReadAllText(_plistPath));
+
+        PlistElementDict _rootDict = _plist.root;
+        PlistElementDict _nsAppTransportSecurity = _rootDict.CreateDict("NSAppTransportSecurity");
+        _nsAppTransportSecurity.SetBoolean("NSAllowsArbitraryLoads", true);
+        PlistElementDict _dict = _nsAppTransportSecurity.CreateDict("Exception Domains");
+        _dict = _dict.CreateDict("jpush.cn");
+        _dict.SetBoolean("NSIncludesSubdomains", true);
+        _dict.SetBoolean("NSExceptionAllowsInsecureHTTPLoads", true);
+
+        _rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹﹀厠椋庢潈闄�");
+        _rootDict.SetString("NSPhotoLibraryAddUsageDescription", "浣跨敤鐩稿唽鏉冮檺,鐢ㄤ互瀛樺偍鎴睆鐨勮处鍙蜂俊鎭�,浠ラ槻蹇樿璐﹀彿瀵嗙爜");
+
+        File.WriteAllText(_plistPath, _plist.WriteToString());
+    }
+
+
     private static void ModifyFile(string projectPath)
     {
-        // -------------- UnityAppController.mm
-        //璇诲彇UnityAppController.mm鏂囦欢
+        //淇敼UnityAppController.mm 鏂囦欢
         var _xclass = new XClass(projectPath + "/Classes/UnityAppController.mm");
-
-        //鍦ㄦ寚瀹氫唬鐮佸悗闈㈠鍔犱竴琛屼唬鐮�
-        _xclass.WriteBelow("#include \"PluginBase/AppDelegateListener.h\"", "#include \"UniversalSDK.h\"\n#include \"JPushService.h\"\n#include \"IAPManager.h\"");
-
+        //寮曞叆UniversalSDK
+        _xclass.WriteBelow("#include \"PluginBase/AppDelegateListener.h\"", "#include \"UniversalSDK.h\"" + "\n#import <MYSDK/MYSDK.h>");
+        //unity浜や簰璋冪敤鐨勬柟娉�
         string newCode = "\n" +
-                         "extern \"C\" void IOSMessageHandle(const char* jsonString) {\n" +
-                         "    [GetAppController().universalSDK HandleUnityMessage:[NSString stringWithUTF8String:jsonString]];\n" +
-                         "}";
-        _xclass.WriteBelow("extern \"C\" ScreenOrientation    UnityCurrentOrientation()   { return GetAppController().unityView.contentOrientation; }",
-                           newCode);
-
+                 "extern \"C\" void IOSMessageHandle(const char* jsonString) {\n" +
+                 "    [GetAppController().universalSDK HandleUnityMessage:[NSString stringWithUTF8String:jsonString]];\n" +
+                 "}";
+        _xclass.WriteBelow("extern \"C\" ScreenOrientation    UnityCurrentOrientation()   { return GetAppController().unityView.contentOrientation; }", newCode);
+        //鍒濆鍖朥niversalSDK
         newCode = "\n" +
-                   "    [[IAPManager shared] startManager];\n" +
-                   "    _universalSDK = [[UniversalSDK alloc] init];\n" +
-                   "    [_universalSDK JPushInit:launchOptions];";
-
-        //鍦ㄦ寚瀹氫唬鐮佸悗闈㈠鍔犱竴澶ц浠g爜
+                "    _universalSDK = [[UniversalSDK alloc] init];\n    [_universalSDK QuickSDKInit:application didFinishLaunchingWithOptions:launchOptions];";
         _xclass.WriteBelow("[KeyboardDelegate Initialize];", newCode);
 
-        _xclass.WriteBelow("UnitySendDeviceToken(deviceToken);", "    [JPUSHService registerDeviceToken:deviceToken];");
-        _xclass.WriteBelow("SensorsCleanup();", "    [[IAPManager shared] startManager];");
 
-        newCode = "UnitySendRemoteNotification(userInfo);\n" +
-            "    [JPUSHService handleRemoteNotification:userInfo];\n";
+        //quick sdk 鐢熷懡鍛ㄦ湡
+        _xclass.WriteBelow("- (BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary<NSString*, id>*)options\n{", "\n  [MYSDK application:app openURL:url options:options];");
+        _xclass.WriteBelow("::printf(\"-> applicationDidEnterBackground()\\n\");", "[MYSDK applicationDidEnterBackground:application];");
+        _xclass.WriteBelow("::printf(\"-> applicationWillEnterForeground()\\n\");", "[MYSDK applicationWillEnterForeground:application];");
 
-        _xclass.Replace("UnitySendRemoteNotification(userInfo);", newCode);
 
-        newCode = "[application setApplicationIconBadgeNumber:0];\n" +
-            "    [application cancelAllLocalNotifications];\n";
-
-        _xclass.WriteBelow("::printf(\"-> applicationWillEnterForeground()\\n\");", newCode);
-        _xclass.WriteBelow("::printf(\"-> applicationDidEnterBackground()\\n\");", "[[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];\n");
-
-        newCode = "    CGRect _winSize = [UIScreen mainScreen].bounds;\n" +
-            "    if(KIsiPhoneX){\n" +
-            "        _winSize.origin.x = 40;\n" +
-            "        _winSize.size.width -= 92;\n" +
-            "        _winSize.size.height -= 15;\n" +
-            "    }\n" +
-            "    _window = [[UIWindow alloc] initWithFrame:_winSize];\n";
-
-        _xclass.Replace("_window         = [[UIWindow alloc] initWithFrame: [UIScreen mainScreen].bounds];", newCode);
-        // -------------- UnityAppController.h
-
+        //淇敼UnityAppController.h 鏂囦欢
         _xclass = new XClass(projectPath + "/Classes/UnityAppController.h");
-
         _xclass.WriteBelow("@class DisplayConnection;", "@class UniversalSDK;");
-        _xclass.WriteBelow("// auto-rotation view contoller goes to index=0", "UniversalSDK* _universalSDK;");
+        _xclass.WriteBelow("DisplayConnection*  _mainDisplay;", "UniversalSDK* _universalSDK;");
         _xclass.WriteBelow("@property (readonly, copy, nonatomic) DisplayConnection*    mainDisplay;",
                            "@property (readonly, copy, nonatomic) UniversalSDK*         universalSDK;");
+    }
 
-        _xclass = new XClass(projectPath + "/Classes/UI/UnityView.mm");
-
-        _xclass.WriteBelow("#include \"Unity/UnityMetalSupport.h\"", "#include \"UniversalSDK.h\"");
-        _xclass.WriteBelow("_curOrientation = OrientationAfterTransform(_curOrientation, TransformBetweenOrientations(from, to));",
-                           @"if(KIsiPhoneX) {
-                                CGRect _winSize = [UIScreen mainScreen].bounds;
-                                if(to == landscapeLeft){
-                                    _winSize.origin.x = 0;
-                                    _winSize.origin.y = 0;
-                                    _winSize.size.width = 720;
-                                    _winSize.size.height = 360;
-                                }else if(to == landscapeRight){
-                                    _winSize.origin.x = 0;
-                                    _winSize.origin.y = -15;
-                                    _winSize.size.width = 720;
-                                    _winSize.size.height = 360;
-                                }
-                                [self setFrame:_winSize];
-                            }");
-
-
-        _xclass = new XClass(projectPath + "/Classes/UI/UnityViewControllerBaseiOS.mm");
-        _xclass.Replace("return res;", "return UIRectEdgeAll;");
-
+    private static void ModifyFile1(string projectPath)
+    {
+        //淇敼UnityAppController.mm 鏂囦欢
+        var _xclass = new XClass(projectPath + "/Classes/UnityAppController.mm");
+        //寮曞叆UniversalSDK
+        _xclass.WriteBelow("#include \"PluginBase/AppDelegateListener.h\"", "#include \"UniversalSDK.h\"" + "\n#import <SMPCQuickSDK/SMPCQuickSDK.h>");
+        //unity浜や簰璋冪敤鐨勬柟娉�
+        string newCode = "\n" +
+                 "extern \"C\" void IOSMessageHandle(const char* jsonString) {\n" +
+                 "    [GetAppController().universalSDK HandleUnityMessage:[NSString stringWithUTF8String:jsonString]];\n" +
+                 "}";
+        _xclass.WriteBelow("extern \"C\" ScreenOrientation    UnityCurrentOrientation()   { return GetAppController().unityView.contentOrientation; }", newCode);
+        //鍒濆鍖朥niversalSDK
+        newCode = "\n" +
+                "    _universalSDK = [[UniversalSDK alloc] init];\n    [_universalSDK QuickSDKInit:application didFinishLaunchingWithOptions:launchOptions];";
+        _xclass.WriteBelow("[KeyboardDelegate Initialize];", newCode);
+
+        newCode = "\n" +
+            "if([SMPCQuickSDK defaultInstance].channelType == 39 ||[SMPCQuickSDK defaultInstance].channelType == 1803 ){\n" +
+            "return [[SMPCQuickSDK defaultInstance] application: application supportedInterfaceOrientationsForWindow:window];}\n" +
+            "else {\n" +
+            "[[SMPCQuickSDK defaultInstance] application: application supportedInterfaceOrientationsForWindow:window];}\n";
+        //quick sdk 鐢熷懡鍛ㄦ湡
+        _xclass.WriteBelow("supportedInterfaceOrientationsForWindow:(UIWindow*)window\n{", newCode);
+        _xclass.WriteBelow("UnitySendRemoteNotification(userInfo);", "[[SMPCQuickSDK defaultInstance] application:application didReceiveRemoteNotification:userInfo];");
+        _xclass.WriteBelow("UnitySendDeviceToken(deviceToken);", "[[SMPCQuickSDK defaultInstance] application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];");
+        _xclass.WriteBelow("UnitySendRemoteNotificationError(error);", "[[SMPCQuickSDK defaultInstance] application:application didFailToRegisterForRemoteNotificationsWithError:error];");
+        _xclass.WriteBelow("- (BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary<NSString*, id>*)options\n{", "[[SMPCQuickSDK defaultInstance] openURL:url application:app options:options];");
+        _xclass.WriteBelow("::printf(\"-> applicationDidEnterBackground()\\n\");", "[[SMPCQuickSDK defaultInstance] applicationDidEnterBackground:application];");
+        _xclass.WriteBelow("::printf(\"-> applicationWillEnterForeground()\\n\");", "[[SMPCQuickSDK defaultInstance] applicationWillEnterForeground:application];");
+        _xclass.WriteBelow("::printf(\"-> applicationDidBecomeActive()\\n\");", "[[SMPCQuickSDK defaultInstance] applicationDidBecomeActive:application];");
+        _xclass.WriteBelow("::printf(\"-> applicationWillResignActive()\\n\");", "[[SMPCQuickSDK defaultInstance] applicationWillResignActive:application];");
+        _xclass.WriteBelow("::printf(\"-> applicationWillTerminate()\\n\");", "[[SMPCQuickSDK defaultInstance] applicationWillTerminate:application];");
+
+
+        //淇敼UnityAppController.h 鏂囦欢
+        _xclass = new XClass(projectPath + "/Classes/UnityAppController.h");
+        _xclass.WriteBelow("@class DisplayConnection;", "@class UniversalSDK;");
+        _xclass.WriteBelow("DisplayConnection*  _mainDisplay;", "UniversalSDK* _universalSDK;");
+        _xclass.WriteBelow("@property (readonly, copy, nonatomic) DisplayConnection*    mainDisplay;",
+                           "@property (readonly, copy, nonatomic) UniversalSDK*         universalSDK;");
     }
 
     private static string GetBuildPath()
@@ -233,51 +348,30 @@
         }
 
         s_IsAppend = true;
-
-        BuildPipeline.BuildPlayer(ClientPackage.baseLevels, _buildPath, BuildTarget.iOS, BuildOptions.Il2CPP | BuildOptions.AcceptExternalModificationsToPlayer);
+        PlayerSettings.SetScriptingBackend(BuildTargetGroup.iOS, ScriptingImplementation.IL2CPP);
+        BuildPipeline.BuildPlayer(ClientPackage.baseLevels, _buildPath, BuildTarget.iOS, BuildOptions.AcceptExternalModificationsToPlayer);
     }
 
     public static void BuildIOSProject_Replace()
     {
         s_IsAppend = false;
-        BuildPipeline.BuildPlayer(ClientPackage.baseLevels, GetBuildPath(), BuildTarget.iOS, BuildOptions.Il2CPP);
+        PlayerSettings.SetScriptingBackend(BuildTargetGroup.iOS, ScriptingImplementation.IL2CPP);
+        BuildPipeline.BuildPlayer(ClientPackage.baseLevels, GetBuildPath(), BuildTarget.iOS, BuildOptions.None);
     }
 
     [MenuItem("Build/ipa")]
     public static void BuildIPA()
     {
-        var _p = new System.Diagnostics.Process();
-        _p.StartInfo.FileName = "osascript";
-        _p.StartInfo.Arguments = string.Format("-e 'tell application \"Terminal\" \n activate \n do script \"cd {0} && sh {1} {2}\" \n end tell'",
+        var p = new System.Diagnostics.Process();
+        p.StartInfo.FileName = "osascript";
+        p.StartInfo.Arguments = string.Format("-e 'tell application \"Terminal\" \n activate \n do script \"cd {0} && sh {1} {2}\" \n end tell'",
                                                Application.dataPath + "/../",
                                               "buildipa.sh",
                                                GetBuildPath());
-        _p.StartInfo.UseShellExecute = false;
-        _p.StartInfo.RedirectStandardOutput = false;
-        _p.Start();
-        _p.WaitForExit();
+        p.StartInfo.UseShellExecute = false;
+        p.StartInfo.RedirectStandardOutput = false;
+        p.Start();
+        p.WaitForExit();
     }
-
-    private static void HandleMrSDK(PBXProject project, string targetGUID)
-    {
-        string _mrPlistPath = Application.dataPath + "/Plugins/iOS/MyMRSDK/MRSDKInfo.plist";
-        if (File.Exists(_mrPlistPath))
-        {
-            string _fileGUID = project.AddFile(_mrPlistPath, "Frameworks/Plugins/iOS/MyMRSDK/MRSDKInfo.plist");
-            project.AddFileToBuild(targetGUID, _fileGUID);
-        }
-    }
-
-    private static void HandleSpSDK(PBXProject project, string targetGUID)
-    {
-        string _filePath = Application.dataPath + "/Plugins/iOS/SPYOUSDK/GDTActionSDK.framework";
-        if (Directory.Exists(_filePath))
-        {
-            string _frameworkGUID = project.FindFileGuidByProjectPath("Frameworks/Plugins/iOS/SPYOUSDK/GDTActionSDK.framework");
-            PBXProjectExtensions.AddFileToEmbedFrameworks(project, targetGUID, _frameworkGUID);
-        }
-    }
-
-#endif
 
 }

--
Gitblit v1.8.0