From ba841b7887b07f638b35c6950053fed104fa7051 Mon Sep 17 00:00:00 2001
From: Rye Mutt <rye@alchemyviewer.org>
Date: Tue, 10 Nov 2020 16:35:32 -0500
Subject: [PATCH] Use system expat on macos to avoid symbol and dylib conflicts
 with system Frameworks

---
 autobuild.xml                        | 72 ++++++++++++++--------------
 indra/cmake/Copy3rdPartyLibs.cmake   |  2 +
 indra/cmake/EXPAT.cmake              | 12 ++---
 indra/llcommon/llsdserialize_xml.cpp |  2 +-
 indra/llui/llxuiparser.cpp           |  6 +--
 indra/llxml/llxmlnode.h              |  6 +--
 indra/llxml/llxmlparser.h            |  6 +--
 indra/newview/llvoicevivox.cpp       |  4 +-
 indra/newview/llvoicevivox.h         |  4 +-
 indra/newview/viewer_manifest.py     |  6 +--
 10 files changed, 59 insertions(+), 61 deletions(-)

diff --git a/autobuild.xml b/autobuild.xml
index f41399efd4a..bad1e2a97e2 100644
--- a/autobuild.xml
+++ b/autobuild.xml
@@ -54,9 +54,11 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>9b8bcc3be6dbe40a04c9c81c313f70dc</string>
+              <string>045acdfadb2d3890f95182ad78bcc5c37d46fb2065982f5e10f69bf8e9319bcb747e8b0bc11268e8065123abe3ebd561</string>
+              <key>hash_algorithm</key>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/68333/658209/apr_suite-1.4.5.548882-darwin64-548882.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/111/packages/generic/apr_suite-668/1.7.0/apr_suite-1.7.0-darwin64-668.tar.xz</string>
             </map>
             <key>name</key>
             <string>darwin64</string>
@@ -66,9 +68,11 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>84a1a140f20b25d714949185e854d14b</string>
+              <string>7fdeae0b56042a597fb135c677dbf2952dda101a6e8dff326560672cc8637c8ea4bbf19feaefa73b2384ca12d14f6c1b</string>
+              <key>hash_algorithm</key>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/4811/15302/apr_suite-1.4.5.504800-linux64-504800.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/111/packages/generic/apr_suite-668/1.7.0/apr_suite-1.7.0-linux64-668.tar.xz</string>
             </map>
             <key>name</key>
             <string>linux64</string>
@@ -103,7 +107,7 @@
           </map>
         </map>
         <key>version</key>
-        <string>1.4.5.328</string>
+        <string>1.7.0</string>
       </map>
       <key>boost</key>
       <map>
@@ -507,26 +511,16 @@
         <string>expat</string>
         <key>platforms</key>
         <map>
-          <key>darwin64</key>
-          <map>
-            <key>archive</key>
-            <map>
-              <key>hash</key>
-              <string>3656b7f7b655cb267fd94f089d2e145c</string>
-              <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/54860/510198/expat-2.1.1.538990-darwin64-538990.tar.bz2</string>
-            </map>
-            <key>name</key>
-            <string>darwin64</string>
-          </map>
           <key>linux64</key>
           <map>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>5e1f025d1cebd12db542080aa755257f</string>
+              <string>29fa7170d908e84c6b456064ad51f1f9feba11effd12d7c0f9600597fb51085ec4d72eee8473420167568018b3c53282</string>
+              <key>hash_algorithm</key>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/380/943/expat-2.1.1.500375-linux64-500375.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/109/packages/generic/expat-658/2.2.10/expat-2.2.10-linux64-658.tar.xz</string>
             </map>
             <key>name</key>
             <string>linux64</string>
@@ -536,11 +530,11 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>4f6ce988932eb420afdb4eacd75dbce8</string>
+              <string>af1d89aa93916ee8ef9382f057b47abf31ebc6e44f1f9ecd8bc16193ef40a98669a821c2c0dd3c9368c14630a5144119</string>
               <key>hash_algorithm</key>
-              <string>md5</string>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/expat/windows/expat-2.2.9.323-windows-323.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/109/packages/generic/expat-658/2.2.10/expat-2.2.10-windows-658.tar.xz</string>
             </map>
             <key>name</key>
             <string>windows</string>
@@ -550,18 +544,18 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>49dc81485705a32d345b4af6dab4ac1c</string>
+              <string>b8f16fdb8a3034a0c9ea616bb2ab4950ba88b2e597e92d4d346305ac6fbf4b9b8ff2b44db9696cd499641b80cf6cce28</string>
               <key>hash_algorithm</key>
-              <string>md5</string>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/expat/windows64/expat-2.2.9.323-windows64-323.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/109/packages/generic/expat-658/2.2.10/expat-2.2.10-windows64-658.tar.xz</string>
             </map>
             <key>name</key>
             <string>windows64</string>
           </map>
         </map>
         <key>version</key>
-        <string>2.2.9.323</string>
+        <string>2.2.10</string>
       </map>
       <key>fmodstudio</key>
       <map>
@@ -2618,9 +2612,11 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>99ea1808ee9f5b55029daa9fdef86776</string>
+              <string>8363cf19c3218df7454f06227e32443f3fdbfc4cca945bec7987d4b0e42ef3e59df879d0d9387dc5675d56e5976f6e05</string>
+              <key>hash_algorithm</key>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/55063/512104/xmlrpc_epi-0.54.1.539072-darwin64-539072.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/110/packages/generic/xmlrpc-epi-669/0.54.1/xmlrpc_epi-0.54.1-darwin64-669.tar.xz</string>
             </map>
             <key>name</key>
             <string>darwin64</string>
@@ -2630,9 +2626,11 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>35df17c3eb673030dea4bde9191aa506</string>
+              <string>048906c305677f634b2fa05191ee312c201fe1030d050abdb3c161ca82e11c291bdc10969b99d8bb8286531eb49c48a7</string>
+              <key>hash_algorithm</key>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/727/1489/xmlrpc_epi-0.54.1.500719-linux64-500719.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/110/packages/generic/xmlrpc-epi-669/0.54.1/xmlrpc_epi-0.54.1-linux64-669.tar.xz</string>
             </map>
             <key>name</key>
             <string>linux64</string>
@@ -2642,11 +2640,11 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>eb26c5779a2bf53f2038a89282bed227</string>
+              <string>f1878aaff7046b5a44eb992bb9c1d3334b404f4a4cc2c3e04b16a91e00370c7c12676063bfed8e2f2445763f11da5400</string>
               <key>hash_algorithm</key>
-              <string>md5</string>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/xmlrpc-epi/windows/xmlrpc_epi-0.54.1.326-windows-326.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/110/packages/generic/xmlrpc-epi-669/0.54.1/xmlrpc_epi-0.54.1-windows-669.tar.xz</string>
             </map>
             <key>name</key>
             <string>windows</string>
@@ -2656,18 +2654,18 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>e33a10439dbd430e158bdca16da2adc4</string>
+              <string>927932400fbede3bbaf7f8ba2ddfd46f1ea89029efeff595fc481a1a4fd9ee715f6653c6ae69719259b6b8d9ce50d925</string>
               <key>hash_algorithm</key>
-              <string>md5</string>
+              <string>sha3_384</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/xmlrpc-epi/windows64/xmlrpc_epi-0.54.1.326-windows64-326.tar.bz2</string>
+              <string>https://git.alchemyviewer.org/api/v4/projects/110/packages/generic/xmlrpc-epi-669/0.54.1/xmlrpc_epi-0.54.1-windows64-669.tar.xz</string>
             </map>
             <key>name</key>
             <string>windows64</string>
           </map>
         </map>
         <key>version</key>
-        <string>0.54.1.326</string>
+        <string>0.54.1</string>
       </map>
       <key>zlib</key>
       <map>
diff --git a/indra/cmake/Copy3rdPartyLibs.cmake b/indra/cmake/Copy3rdPartyLibs.cmake
index 27397511b68..8b7ac2f71b2 100644
--- a/indra/cmake/Copy3rdPartyLibs.cmake
+++ b/indra/cmake/Copy3rdPartyLibs.cmake
@@ -145,6 +145,8 @@ elseif(DARWIN)
         liburiparser.dylib
         liburiparser.1.dylib
         liburiparser.1.0.27.dylib
+        libxmlrpc-epi.dylib
+        libxmlrpc-epi.0.dylib
        )
 
     if (USE_FMODSTUDIO)
diff --git a/indra/cmake/EXPAT.cmake b/indra/cmake/EXPAT.cmake
index 9e1242b5998..844cefd7413 100644
--- a/indra/cmake/EXPAT.cmake
+++ b/indra/cmake/EXPAT.cmake
@@ -6,6 +6,8 @@ set(EXPAT_FIND_REQUIRED ON)
 
 if (USESYSTEMLIBS)
   include(FindEXPAT)
+elseif(DARWIN)
+  find_package(EXPAT REQUIRED)
 else (USESYSTEMLIBS)
     use_prebuilt_binary(expat)
     if (WINDOWS)
@@ -13,13 +15,9 @@ else (USESYSTEMLIBS)
             debug libexpatd.lib
             optimized libexpat.lib)
         set(EXPAT_COPY libexpat.dll)
-    else (WINDOWS)
+    else ()
         set(EXPAT_LIBRARIES expat)
-        if (DARWIN)
-            set(EXPAT_COPY libexpat.1.dylib libexpat.dylib)
-        else ()
-            set(EXPAT_COPY libexpat.so.1 libexpat.so)
-        endif ()
-    endif (WINDOWS)
+        set(EXPAT_COPY libexpat.so.1 libexpat.so)
+    endif ()
     set(EXPAT_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include)
 endif (USESYSTEMLIBS)
diff --git a/indra/llcommon/llsdserialize_xml.cpp b/indra/llcommon/llsdserialize_xml.cpp
index d7dab88e33c..e61a6000e22 100644
--- a/indra/llcommon/llsdserialize_xml.cpp
+++ b/indra/llcommon/llsdserialize_xml.cpp
@@ -35,7 +35,7 @@
 
 extern "C"
 {
-#ifdef LL_USESYSTEMLIBS
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
 # include <expat.h>
 #else
 # include "expat/expat.h"
diff --git a/indra/llui/llxuiparser.cpp b/indra/llui/llxuiparser.cpp
index e7e824f0d72..9803789a1e8 100644
--- a/indra/llui/llxuiparser.cpp
+++ b/indra/llui/llxuiparser.cpp
@@ -30,10 +30,10 @@
 
 #include "llxmlnode.h"
 #include "llfasttimer.h"
-#ifdef LL_USESYSTEMLIBS
-#include <expat.h>
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
+# include <expat.h>
 #else
-#include "expat/expat.h"
+# include "expat/expat.h"
 #endif
 
 #include <fstream>
diff --git a/indra/llxml/llxmlnode.h b/indra/llxml/llxmlnode.h
index 574dd77b57f..b6c5845cb01 100644
--- a/indra/llxml/llxmlnode.h
+++ b/indra/llxml/llxmlnode.h
@@ -27,10 +27,10 @@
 #ifndef LL_LLXMLNODE_H
 #define LL_LLXMLNODE_H
 
-#ifdef LL_USESYSTEMLIBS
-#include <expat.h>
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
+# include <expat.h>
 #else
-#include "expat/expat.h"
+# include "expat/expat.h"
 #endif
 #include <map>
 
diff --git a/indra/llxml/llxmlparser.h b/indra/llxml/llxmlparser.h
index 54c4a838f38..73de6acb21a 100644
--- a/indra/llxml/llxmlparser.h
+++ b/indra/llxml/llxmlparser.h
@@ -27,10 +27,10 @@
 #ifndef LL_LLXMLPARSER_H
 #define LL_LLXMLPARSER_H
 
-#ifdef LL_USESYSTEMLIBS
-#include <expat.h>
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
+# include <expat.h>
 #else
-#include "expat/expat.h"
+# include "expat/expat.h"
 #endif
 
 class LLXmlParser
diff --git a/indra/newview/llvoicevivox.cpp b/indra/newview/llvoicevivox.cpp
index b7eae9b3b67..1631d90e392 100644
--- a/indra/newview/llvoicevivox.cpp
+++ b/indra/newview/llvoicevivox.cpp
@@ -36,8 +36,8 @@
 #include "llbufferstream.h"
 #include "llfile.h"
 #include "llmenugl.h"
-#ifdef LL_USESYSTEMLIBS
-# include "expat.h"
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
+# include <expat.h>
 #else
 # include "expat/expat.h"
 #endif
diff --git a/indra/newview/llvoicevivox.h b/indra/newview/llvoicevivox.h
index 09fc3c5171d..8d83c3d3fdd 100644
--- a/indra/newview/llvoicevivox.h
+++ b/indra/newview/llvoicevivox.h
@@ -41,8 +41,8 @@ class LLVivoxProtocolParser;
 #include "llcoros.h"
 #include <queue>
 
-#ifdef LL_USESYSTEMLIBS
-# include "expat.h"
+#if LL_DARWIN || defined(LL_USESYSTEMLIBS)
+# include <expat.h>
 #else
 # include "expat/expat.h"
 #endif
diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py
index 1154245ad36..457fa0dfbe2 100755
--- a/indra/newview/viewer_manifest.py
+++ b/indra/newview/viewer_manifest.py
@@ -925,6 +925,8 @@ def construct(self):
                 CEF_framework = self.dst_path_of(CEF_framework)
 
                 for libfile in (
+                                'libapr-1.*.dylib',
+                                'libaprutil-1.*.dylib',
                                 'libjpeg.*.dylib',
                                 'libepoxy.*.dylib',
                                 'libGLOD.dylib',
@@ -937,6 +939,7 @@ def construct(self):
                                 'libvorbisenc.*.dylib',
                                 'libvorbisfile.*.dylib',
                                 'libwebp.*.dylib',
+                                'libxmlrpc-epi.*.dylib',
                                 ):
                     self.path(libfile)
 
@@ -1053,9 +1056,6 @@ def construct(self):
                 libfile_parent = self.get_dst_prefix()
                 dylibs=[]
                 for libfile in (
-                                "libapr-1.0.dylib",
-                                "libaprutil-1.0.dylib",
-                                "libexpat.1.dylib",
                                 # libnghttp2.dylib is a symlink to
                                 # libnghttp2.major.dylib, which is a symlink to
                                 # libnghttp2.version.dylib. Get all of them.
-- 
GitLab