From 9ef2d56705ba49323bbbc12110c7e8c8dadc67df Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期五, 14 二月 2025 02:39:05 +0800
Subject: [PATCH] 0312 增加工具检测cdn文件

---
 Assets/Editor/XCodeProjectMod.cs |  109 ++++++++++++++++++++++++------------------------------
 1 files changed, 49 insertions(+), 60 deletions(-)

diff --git a/Assets/Editor/XCodeProjectMod.cs b/Assets/Editor/XCodeProjectMod.cs
index aa69e1d..1a263a9 100644
--- a/Assets/Editor/XCodeProjectMod.cs
+++ b/Assets/Editor/XCodeProjectMod.cs
@@ -2,17 +2,15 @@
 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 = "";
     private const string PROVISIONING_DISTRIBUTION = "";
-    private const string TEAM = "5X26T385YZ";
+    private const string TEAM = "";
 
     [UnityEditor.Callbacks.PostProcessBuild(999)]
     public static void OnPostprocessBuild(BuildTarget buildTarget, string path)
@@ -24,53 +22,41 @@
 
         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());
-        string _fwTargetGUID = _project.TargetGuidByName("UnityFramework");
+        string targetGUID = project.TargetGuidByName(PBXProject.GetUnityTargetName());
+        string fwTargetGUID = project.TargetGuidByName("UnityFramework");
 
         //var _codeSign = Debug.isDebugBuild ? CODE_SIGN_DEVELOPER : CODE_SIGN_DISTRIBUTION;
         //var _provision = Debug.isDebugBuild ? PROVISIONING_DEVELOPER : PROVISIONING_DISTRIBUTION;
 
         // 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");
+        project.AddBuildProperty(targetGUID, "OTHER_LDFLAGS", "-ObjC");
+        project.AddBuildProperty(targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
+        //wkwebview
+        project.AddFrameworkToProject(fwTargetGUID, "WebKit.framework", true);
 
-        // 澶勭悊 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.AddFrameworkToProject(fwTargetGUID, "SystemConfiguration.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "Security.framework", true);
+        project.AddFrameworkToProject(fwTargetGUID, "JavaScriptCore.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));
 
         //UnityFramework
-        _project.AddBuildProperty(_fwTargetGUID, "OTHER_LDFLAGS", "-ObjC");
+        project.AddBuildProperty(fwTargetGUID, "OTHER_LDFLAGS", "-ObjC");
 
 
-        File.WriteAllText(_projectPath, _project.WriteToString());
+        File.WriteAllText(_projectPath, project.WriteToString());
 
         //鍔犳帹閫�
         //var _capabilityMgr = new ProjectCapabilityManager(_projectPath, "game003.entitlements", PBXProject.GetUnityTargetName());
@@ -101,11 +87,8 @@
         _dict.SetBoolean("NSIncludesSubdomains", true);
         _dict.SetBoolean("NSExceptionAllowsInsecureHTTPLoads", true);
 
-        _rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹﹀厠椋庢潈闄�");
-        _rootDict.SetString("NSPhotoLibraryAddUsageDescription", "浣跨敤鐩稿唽鏉冮檺,鐢ㄤ互瀛樺偍鎴睆鐨勮处鍙蜂俊鎭�,浠ラ槻蹇樿璐﹀彿瀵嗙爜");
-
-        _rootDict.SetString("YLChannelId", "1000");
-        _rootDict.SetString("YLPlatformId", "1000");
+        //_rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹﹀厠椋庢潈闄�");
+        //_rootDict.SetString("NSPhotoLibraryAddUsageDescription", "浣跨敤鐩稿唽鏉冮檺,鐢ㄤ互瀛樺偍鎴睆鐨勮处鍙蜂俊鎭�,浠ラ槻蹇樿璐﹀彿瀵嗙爜");
 
         File.WriteAllText(_plistPath, _plist.WriteToString());
     }
@@ -115,23 +98,31 @@
         //淇敼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>");
+        _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" +
+                 "extern \"C\" void IOSUniyMessageHandle(const char* jsonString) {\n" +
                  "    [GetAppController().universalSDK HandleUnityMessage:[NSString stringWithUTF8String:jsonString]];\n" +
                  "}";
-        _xclass.WriteBelow("extern \"C\" ScreenOrientation    UnityCurrentOrientation()   { return GetAppController().unityView.contentOrientation; }",newCode);
+        _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);
+        _xclass.WriteBelow("::printf(\"-> applicationDidFinishLaunching()\\n\");", 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{", "[[SMPCQuickSDK defaultInstance] application:application supportedInterfaceOrientationsForWindow:window];");
-        _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("- (NSUInteger)application:(UIApplication*)application supportedInterfaceOrientationsForWindow:(UIWindow*)window\n{", newCode);
+        _xclass.WriteBelow("AppController_SendNotificationWithArg(kUnityDidReceiveRemoteNotification, userInfo);", "[[SMPCQuickSDK defaultInstance] application:application didReceiveRemoteNotification:userInfo];");
+        _xclass.WriteBelow("AppController_SendNotificationWithArg(kUnityDidRegisterForRemoteNotificationsWithDeviceToken, deviceToken);", "[[SMPCQuickSDK defaultInstance] application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];");
+        _xclass.WriteBelow("AppController_SendNotificationWithArg(kUnityDidFailToRegisterForRemoteNotificationsWithError, error);", "[[SMPCQuickSDK defaultInstance] application:application didFailToRegisterForRemoteNotificationsWithError:error];");
+
+        newCode = "\t[[SMPCQuickSDK defaultInstance] openURL:url application:app];\n\tif (sourceApplication && annotation)\n\t{\n\t\t[[SMPCQuickSDK defaultInstance] openURL:url sourceApplication:sourceApplication application:app annotation:annotation];\n\t}\n\t[[SMPCQuickSDK defaultInstance] openURL:url application:app options:options];\n";
+        _xclass.WriteBelow("AppController_SendNotificationWithArg(kUnityOnOpenURL, notifData)", newCode);
         _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];");
@@ -141,7 +132,7 @@
 
         //淇敼UnityAppController.h 鏂囦欢
         _xclass = new XClass(projectPath + "/Classes/UnityAppController.h");
-                _xclass.WriteBelow("@class DisplayConnection;", "@class UniversalSDK;");
+        _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;");
@@ -203,18 +194,16 @@
     [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();
     }
-
-#endif
 
 }

--
Gitblit v1.8.0