1.最近在弄一个python脚本程序,记录下运行过程。
2.编写的python程序如下

#
# Copyright 2017 Pixar
#
# Licensed under the terms set forth in the LICENSE.txt file available at
# https://openusd.org/license.
#
# Check whether this script is being run under Python 2 first. Otherwise,
# any Python 3-only code below will cause the script to fail with an
# unhelpful error message.
import sys
if sys.version_info.major == 2:sys.exit("ERROR: USD does not support Python 2. Use a supported version ""of Python 3 instead.")import argparse
import codecs
import contextlib
import ctypes
import datetime
import fnmatch
import glob
import hashlib
import locale
import multiprocessing
import os
import platform
import re
import shlex
import shutil
import subprocess
import sys
import sysconfig
import zipfilefrom urllib.request import urlopen
from shutil import which# Helpers for printing output
verbosity = 1def Print(msg):if verbosity > 0:print(msg)def PrintWarning(warning):if verbosity > 0:print("WARNING:", warning)def PrintStatus(status):if verbosity >= 1:print("STATUS:", status)def PrintInfo(info):if verbosity >= 2:print("INFO:", info)def PrintCommandOutput(output):if verbosity >= 3:sys.stdout.write(output)def PrintError(error):if verbosity >= 3 and sys.exc_info()[1] is not None:import tracebacktraceback.print_exc()print ("ERROR:", error)# Helpers for determining platform
def Windows():return platform.system() == "Windows"
def Linux():return platform.system() == "Linux"
def MacOS():return platform.system() == "Darwin"if MacOS():import apple_utilsdef MacOSTargetEmbedded(context):return MacOS() and apple_utils.TargetEmbeddedOS(context)def GetLocale():if Windows():# Windows handles encoding a little differently then Linux / Mac# For interactive streams (isatty() == True) it will use the# console codepage, otherwise it will return an ANSI codepage.# To keep things consistent we'll force UTF-8 for non-interactive# streams (which is recommended by Microsoft). See:# https://docs.python.org/3.6/library/sys.html#sys.stdout# https://docs.microsoft.com/en-us/windows/win32/intl/code-page-identifiersif sys.stdout.isatty():return sys.stdout.encodingelse:return "UTF-8"return sys.stdout.encoding or locale.getdefaultlocale()[1] or "UTF-8"def GetCommandOutput(command):"""Executes the specified command and returns output or None."""try:return subprocess.check_output(shlex.split(command), stderr=subprocess.STDOUT).decode(GetLocale(), 'replace').strip()except subprocess.CalledProcessError:passreturn Nonedef GetXcodeDeveloperDirectory():"""Returns the active developer directory as reported by 'xcode-select -p'.Returns None if none is set."""if not MacOS():return Nonereturn GetCommandOutput("xcode-select -p")def GetVisualStudioCompilerAndVersion():"""Returns a tuple containing the path to the Visual Studio compilerand a tuple for its version, e.g. (14, 0). If the compiler is not foundor version number cannot be determined, returns None."""if not Windows():return NonemsvcCompiler = which('cl')if msvcCompiler:# VCToolsVersion environment variable should be set by the# Visual Studio Command Prompt.match = re.search(r"(\d+)\.(\d+)",os.environ.get("VCToolsVersion", ""))if match:return (msvcCompiler, tuple(int(v) for v in match.groups()))return Nonedef IsVisualStudioVersionOrGreater(desiredVersion):if not Windows():return FalsemsvcCompilerAndVersion = GetVisualStudioCompilerAndVersion()if msvcCompilerAndVersion:_, version = msvcCompilerAndVersionreturn version >= desiredVersionreturn False# Helpers to determine the version of "Visual Studio" (also support the Build Tools) based
# on the version of the MSVC compiler.
# See MSVC++ versions table on https://en.wikipedia.org/wiki/Microsoft_Visual_C%2B%2B
def IsVisualStudio2022OrGreater():VISUAL_STUDIO_2022_VERSION = (14, 30)return IsVisualStudioVersionOrGreater(VISUAL_STUDIO_2022_VERSION)
def IsVisualStudio2019OrGreater():VISUAL_STUDIO_2019_VERSION = (14, 20)return IsVisualStudioVersionOrGreater(VISUAL_STUDIO_2019_VERSION)
def IsVisualStudio2017OrGreater():VISUAL_STUDIO_2017_VERSION = (14, 1)return IsVisualStudioVersionOrGreater(VISUAL_STUDIO_2017_VERSION)# Helper to get the current host arch on Windows
def GetWindowsHostArch():identifier = os.environ.get('PROCESSOR_IDENTIFIER')# ARM64 identifiers currently start with "ARMv8 ...."# Note: This could be modified in the future to distinguish between ARMv8 and ARMv9if "ARMv" in identifier:return "ARM64"elif any(x64Arch in identifier for x64Arch in ["AMD64", "Intel64", "EM64T"]):return "x64"else:raise RuntimeError("Unknown Windows host arch")def GetPythonInfo(context):"""Returns a tuple containing the path to the Python executable, sharedlibrary, and include directory corresponding to the version of Pythoncurrently running. Returns None if any path could not be determined.This function is used to extract build information from the Python interpreter used to launch this script. This allows us to supporthaving USD builds for different Python versions built on the samemachine. This is very useful, especially when developers have multipleversions installed on their machine."""# If we were given build python info then just use it.if context.build_python_info:return (context.build_python_info['PYTHON_EXECUTABLE'],context.build_python_info['PYTHON_LIBRARY'],context.build_python_info['PYTHON_INCLUDE_DIR'],context.build_python_info['PYTHON_VERSION'])# First we extract the information that can be uniformly dealt with across# the platforms:pythonExecPath = sys.executablepythonVersion = sysconfig.get_config_var("py_version_short")  # "3.7"# Lib path is unfortunately special for each platform and there is no# config_var for it. But we can deduce it for each platform, and this# logic works for any Python version.def _GetPythonLibraryFilename(context):if Windows():return "python{version}{suffix}.lib".format(version=sysconfig.get_config_var("py_version_nodot"),suffix=('_d' if context.buildDebug and context.debugPythonelse ''))elif Linux():return sysconfig.get_config_var("LDLIBRARY")elif MacOS():return "libpython{version}.dylib".format(version=(sysconfig.get_config_var('LDVERSION') orsysconfig.get_config_var('VERSION') orpythonVersion))else:raise RuntimeError("Platform not supported")pythonIncludeDir = sysconfig.get_path("include")if not pythonIncludeDir or not os.path.isdir(pythonIncludeDir):# as a backup, and for legacy reasons - not preferred because# it may be baked at build timepythonIncludeDir = sysconfig.get_config_var("INCLUDEPY")# if in a venv, installed_base will be the "original" python,# which is where the libs are ("base" will be the venv dir)pythonBaseDir = sysconfig.get_config_var("installed_base")if Windows():pythonLibPath = os.path.join(pythonBaseDir, "libs",_GetPythonLibraryFilename(context))elif Linux():pythonMultiarchSubdir = sysconfig.get_config_var("multiarchsubdir")# Try multiple ways to get the python lib dirfor pythonLibDir in (sysconfig.get_config_var("LIBDIR"),os.path.join(pythonBaseDir, "lib")):if pythonMultiarchSubdir:pythonLibPath = \os.path.join(pythonLibDir + pythonMultiarchSubdir,_GetPythonLibraryFilename(context))if os.path.isfile(pythonLibPath):breakpythonLibPath = os.path.join(pythonLibDir,_GetPythonLibraryFilename(context))if os.path.isfile(pythonLibPath):breakelif MacOS():pythonLibPath = os.path.join(pythonBaseDir, "lib",_GetPythonLibraryFilename(context))else:raise RuntimeError("Platform not supported")return (pythonExecPath, pythonLibPath, pythonIncludeDir, pythonVersion)def GetCPUCount():try:return multiprocessing.cpu_count()except NotImplementedError:return 1def Run(cmd, logCommandOutput = True, env = None):"""Run the specified command in a subprocess."""PrintInfo('Running "{cmd}"'.format(cmd=cmd))with codecs.open("log.txt", "a", "utf-8") as logfile:logfile.write(datetime.datetime.now().strftime("%Y-%m-%d %H:%M"))logfile.write("\n")logfile.write(cmd)logfile.write("\n")# Let exceptions escape from subprocess calls -- higher level# code will handle them.if logCommandOutput:p = subprocess.Popen(shlex.split(cmd), stdout=subprocess.PIPE, stderr=subprocess.STDOUT, env=env)while True:l = p.stdout.readline().decode(GetLocale(), 'replace')if l:logfile.write(l)PrintCommandOutput(l)elif p.poll() is not None:breakelse:p = subprocess.Popen(shlex.split(cmd), env=env)p.wait()if p.returncode != 0:# If verbosity >= 3, we'll have already been printing out command output# so no reason to print the log file again.if verbosity < 3:with open("log.txt", "r") as logfile:Print(logfile.read())raise RuntimeError("Failed to run '{cmd}' in {path}.\nSee {log} for more details.".format(cmd=cmd, path=os.getcwd(), log=os.path.abspath("log.txt")))@contextlib.contextmanager
def CurrentWorkingDirectory(dir):"""Context manager that sets the current working directory to the givendirectory and resets it to the original directory when closed."""curdir = os.getcwd()os.chdir(dir)try: yieldfinally: os.chdir(curdir)def CopyFiles(context, src, dest):"""Copy files like shutil.copy, but src may be a glob pattern."""filesToCopy = glob.glob(src)if not filesToCopy:raise RuntimeError("File(s) to copy {src} not found".format(src=src))instDestDir = os.path.join(context.instDir, dest)if not os.path.isdir(instDestDir):try:os.mkdir(instDestDir)except Exception as e:raise RuntimeError("Unable to create {destDir}".format(destDir=instDestDir)) from efor f in filesToCopy:PrintCommandOutput("Copying {file} to {destDir}\n".format(file=f, destDir=instDestDir))shutil.copy(f, instDestDir)def CopyDirectory(context, srcDir, destDir):"""Copy directory like shutil.copytree."""instDestDir = os.path.join(context.instDir, destDir)if os.path.isdir(instDestDir):shutil.rmtree(instDestDir)    PrintCommandOutput("Copying {srcDir} to {destDir}\n".format(srcDir=srcDir, destDir=instDestDir))shutil.copytree(srcDir, instDestDir)def AppendCXX11ABIArg(buildFlag, context, buildArgs):"""Append a build argument that defines _GLIBCXX_USE_CXX11_ABIbased on the settings in the context. This may either do nothingor append an entry to buildArgs like:<buildFlag>="-D_GLIBCXX_USE_CXX11_ABI={0, 1}"If buildArgs contains settings for buildFlag, those settings willbe merged with the above define."""if context.useCXX11ABI is None:returncxxFlags = ["-D_GLIBCXX_USE_CXX11_ABI={}".format(context.useCXX11ABI)]# buildArgs might look like:# ["-DFOO=1", "-DBAR=2", ...] or ["-DFOO=1 -DBAR=2 ...", ...]## See if any of the arguments in buildArgs start with the given# buildFlag. If so, we want to take whatever that buildFlag has# been set to and merge it in with the cxxFlags above.## For example, if buildArgs = ['-DCMAKE_CXX_FLAGS="-w"', ...]# we want to add "-w" to cxxFlags.splitArgs = [shlex.split(a) for a in buildArgs]for p in [item for arg in splitArgs for item in arg]:if p.startswith(buildFlag):(_, _, flags) = p.partition("=")cxxFlags.append(flags)buildArgs.append('{flag}="{flags}"'.format(flag=buildFlag, flags=" ".join(cxxFlags)))def RunCMake(context, force, extraArgs = None):"""Invoke CMake to configure, build, and install a library whose source code is located in the current working directory."""# Create a directory for out-of-source builds in the build directory# using the name of the current working directory.if extraArgs is None:extraArgs = []else:# ensure we can freely modify our extraArgs without affecting callerextraArgs = list(extraArgs)if context.cmakeBuildArgs:extraArgs.insert(0, context.cmakeBuildArgs)srcDir = os.getcwd()instDir = (context.usdInstDir if srcDir == context.usdSrcDirelse context.instDir)buildDir = os.path.join(context.buildDir, os.path.split(srcDir)[1])if force and os.path.isdir(buildDir):shutil.rmtree(buildDir)if not os.path.isdir(buildDir):os.makedirs(buildDir)generator = context.cmakeGenerator# On Windows, we need to explicitly specify the generator to ensure we're# building a 64-bit project. (Surely there is a better way to do this?)# TODO: figure out exactly what "vcvarsall.bat x64" sets to force x64if generator is None and Windows():if IsVisualStudio2022OrGreater():generator = "Visual Studio 17 2022"elif IsVisualStudio2019OrGreater():generator = "Visual Studio 16 2019"elif IsVisualStudio2017OrGreater():generator = "Visual Studio 15 2017 Win64"if generator is not None:generator = '-G "{gen}"'.format(gen=generator)# Note - don't want to add -A (architecture flag) if generator is, ie, Ninjaif IsVisualStudio2019OrGreater() and "Visual Studio" in generator:generator = generator + " -A " + GetWindowsHostArch()toolset = context.cmakeToolsetif toolset is not None:toolset = '-T "{toolset}"'.format(toolset=toolset)# On MacOS, enable the use of @rpath for relocatable builds.osx_rpath = Noneif MacOS():osx_rpath = "-DCMAKE_MACOSX_RPATH=ON"# For macOS cross compilation, set the Xcode architecture flags.targetArch = apple_utils.GetTargetArch(context)if context.targetNative or targetArch == apple_utils.GetHostArch():extraArgs.append('-DCMAKE_XCODE_ATTRIBUTE_ONLY_ACTIVE_ARCH=YES')else:extraArgs.append('-DCMAKE_XCODE_ATTRIBUTE_ONLY_ACTIVE_ARCH=NO')extraArgs.append('-DCMAKE_OSX_ARCHITECTURES={0}'.format(targetArch))extraArgs = apple_utils.ConfigureCMakeExtraArgs(context, extraArgs)if context.ignorePaths:ignoredPaths = ";".join(context.ignorePaths)extraArgs.append("-DCMAKE_IGNORE_PATH={0}".format(ignoredPaths))extraArgs.append("-DCMAKE_IGNORE_PREFIX_PATH={0}".format(ignoredPaths))# We use -DCMAKE_BUILD_TYPE for single-configuration generators # (Ninja, make), and --config for multi-configuration generators # (Visual Studio); technically we don't need BOTH at the same# time, but specifying both is simpler than branchingconfig = "Release"if context.buildDebug:config = "Debug"elif context.buildRelease:config = "Release"elif context.buildRelWithDebug:config = "RelWithDebInfo"# Append extra argument controlling libstdc++ ABI if specified.AppendCXX11ABIArg("-DCMAKE_CXX_FLAGS", context, extraArgs)with CurrentWorkingDirectory(buildDir):Run('cmake ''-DCMAKE_INSTALL_PREFIX="{instDir}" ''-DCMAKE_PREFIX_PATH="{depsInstDir}" ''-DCMAKE_BUILD_TYPE={config} ''{osx_rpath} ''{generator} ''{toolset} ''{extraArgs} ''"{srcDir}"'.format(instDir=instDir,depsInstDir=context.instDir,config=config,srcDir=srcDir,osx_rpath=(osx_rpath or ""),generator=(generator or ""),toolset=(toolset or ""),extraArgs=(" ".join(extraArgs) if extraArgs else "")))# As of CMake 3.12, the -j parameter for `cmake --build` allows# specifying the number of parallel build jobs, forwarding it to the# underlying native build tool.Run("cmake --build . --config {config} --target install -j {numJobs}".format(config=config, numJobs=context.numJobs))def GetCMakeVersion():"""Returns the CMake version as tuple of integers (major, minor) or(major, minor, patch) or None if an error occured while launching cmake andparsing its output."""output_string = GetCommandOutput("cmake --version")if not output_string:PrintWarning("Could not determine cmake version -- please install it ""and adjust your PATH")return None# cmake reports, e.g., "... version 3.14.3"match = re.search(r"version (\d+)\.(\d+)(\.(\d+))?", output_string)if not match:PrintWarning("Could not determine cmake version")return Nonemajor, minor, patch_group, patch = match.groups()if patch_group is None:return (int(major), int(minor))else:return (int(major), int(minor), int(patch))def ComputeSHA256Hash(filename):"""Returns the SHA256 hash of the specified file."""hasher = hashlib.sha256()with open(filename, "rb") as f:buf = Nonewhile buf != b'':buf = f.read(4096)hasher.update(buf)return hasher.hexdigest()def PatchFile(filename, patches, multiLineMatches=False):"""Applies patches to the specified file. patches is a list of tuples(old string, new string)."""if multiLineMatches:oldLines = [open(filename, 'r').read()]else:oldLines = open(filename, 'r').readlines()newLines = oldLinesfor (oldString, newString) in patches:newLines = [s.replace(oldString, newString) for s in newLines]if newLines != oldLines:PrintInfo("Patching file {filename} (original in {oldFilename})...".format(filename=filename, oldFilename=filename + ".old"))shutil.copy(filename, filename + ".old")open(filename, 'w').writelines(newLines)def DownloadFileWithCurl(url, outputFilename):# Don't log command output so that curl's progress# meter doesn't get written to the log file.Run("curl {progress} -L -o {filename} {url}".format(progress="-#" if verbosity >= 2 else "-s",filename=outputFilename, url=url), logCommandOutput=False)def DownloadFileWithPowershell(url, outputFilename):# It's important that we specify to use TLS v1.2 at least or some# of the downloads will fail.cmd = "powershell [Net.ServicePointManager]::SecurityProtocol = \[Net.SecurityProtocolType]::Tls12; \"(new-object \System.Net.WebClient).DownloadFile('{url}', '{filename}')\""\.format(filename=outputFilename, url=url)Run(cmd,logCommandOutput=False)def DownloadFileWithUrllib(url, outputFilename):r = urlopen(url)with open(outputFilename, "wb") as outfile:outfile.write(r.read())def DownloadURL(url, context, force, extractDir = None, dontExtract = None, destFileName = None,expectedSHA256 = None):"""Download and extract the archive file at given URL to thesource directory specified in the context. dontExtract may be a sequence of path prefixes that willbe excluded when extracting the archive.destFileName may be a string containing the filename wherethe file will be downloaded. If unspecified, this filenamewill be derived from the URL.expectedSHA256 may be a string containing the expected SHA256checksum for the downloaded file. If provided, this functionwill raise a RuntimeError if the SHA256 checksum computed fromthe file does not match.Returns the absolute path to the directory where files have been extracted."""with CurrentWorkingDirectory(context.srcDir):if destFileName:filename = destFileNameelse:filename = url.split("/")[-1]       if force and os.path.exists(filename):os.remove(filename)if os.path.exists(filename):PrintInfo("{0} already exists, skipping download".format(os.path.abspath(filename)))else:PrintInfo("Downloading {0} to {1}".format(url, os.path.abspath(filename)))# To work around occasional hiccups with downloading from websites# (SSL validation errors, etc.), retry a few times if we don't# succeed in downloading the file.maxRetries = 5lastError = None# Download to a temporary file and rename it to the expected# filename when complete. This ensures that incomplete downloads# will be retried if the script is run again.tmpFilename = filename + ".tmp"if os.path.exists(tmpFilename):os.remove(tmpFilename)for i in range(maxRetries):try:context.downloader(url, tmpFilename)breakexcept Exception as e:PrintCommandOutput("Retrying download due to error: {err}\n".format(err=e))lastError = eelse:errorMsg = str(lastError)if "SSL: TLSV1_ALERT_PROTOCOL_VERSION" in errorMsg:errorMsg += ("\n\n""Your OS or version of Python may not support ""TLS v1.2+, which is required for downloading ""files from certain websites. This support ""was added in Python 2.7.9.""\n\n""You can use curl to download dependencies ""by installing it in your PATH and re-running ""this script.")raise RuntimeError("Failed to download {url}: {err}".format(url=url, err=errorMsg))if expectedSHA256:computedSHA256 = ComputeSHA256Hash(tmpFilename)if computedSHA256 != expectedSHA256:raise RuntimeError("Unexpected SHA256 for {url}: got {computed}, ""expected {expected}".format(url=url, computed=computedSHA256,expected=expectedSHA256))shutil.move(tmpFilename, filename)# Open the archive and retrieve the name of the top-most directory.# This assumes the archive contains a single directory with all# of the contents beneath it, unless a specific extractDir is specified,# which is to be used.archive = NonerootDir = Nonemembers = Nonetry:if zipfile.is_zipfile(filename):archive = zipfile.ZipFile(filename)if extractDir:rootDir = extractDirelse:rootDir = archive.namelist()[0].split('/')[0]if dontExtract != None:members = (m for m in archive.namelist() if not any((fnmatch.fnmatch(m, p)for p in dontExtract)))else:raise RuntimeError("unrecognized archive file type")with archive:extractedPath = os.path.abspath(rootDir)if force and os.path.isdir(extractedPath):shutil.rmtree(extractedPath)if os.path.isdir(extractedPath):PrintInfo("Directory {0} already exists, skipping extract".format(extractedPath))else:PrintInfo("Extracting archive to {0}".format(extractedPath))# Extract to a temporary directory then move the contents# to the expected location when complete. This ensures that# incomplete extracts will be retried if the script is run# again.tmpExtractedPath = os.path.abspath("extract_dir")if os.path.isdir(tmpExtractedPath):shutil.rmtree(tmpExtractedPath)archive.extractall(tmpExtractedPath, members=members)shutil.move(os.path.join(tmpExtractedPath, rootDir),extractedPath)shutil.rmtree(tmpExtractedPath)return extractedPathexcept Exception as e:# If extraction failed for whatever reason, assume the# archive file was bad and move it aside so that re-running# the script will try downloading and extracting again.shutil.move(filename, filename + ".bad")raise RuntimeError("Failed to extract archive {filename}: {err}".format(filename=filename, err=e))############################################################
# 3rd-Party DependenciesAllDependencies = list()
AllDependenciesByName = dict()class Dependency(object):def __init__(self, name, installer, *files):self.name = nameself.installer = installerself.filesToCheck = filesAllDependencies.append(self)AllDependenciesByName.setdefault(name.lower(), self)def Exists(self, context):return any([os.path.isfile(os.path.join(context.instDir, f))for f in self.filesToCheck])class PythonDependency(object):def __init__(self, name, getInstructions, moduleNames):self.name = nameself.getInstructions = getInstructionsself.moduleNames = moduleNamesdef Exists(self, context):# If one of the modules in our list imports successfully, we are good.for moduleName in self.moduleNames:try:pyModule = __import__(moduleName)return Trueexcept:passreturn Falsedef AnyPythonDependencies(deps):return any([type(d) is PythonDependency for d in deps])############################################################
# zlibZLIB_URL = "https://github.com/madler/zlib/archive/v1.2.13.zip"def InstallZlib(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(ZLIB_URL, context, force)):# The following test files aren't portable to embedded platforms.# They're not required for use on any platforms, so we elide them# for efficiencyPatchFile("CMakeLists.txt",[("add_executable(example test/example.c)",""),("add_executable(minigzip test/minigzip.c)",""),("target_link_libraries(example zlib)",""),("target_link_libraries(minigzip zlib)",""),("add_test(example example)","")])RunCMake(context, force, buildArgs)ZLIB = Dependency("zlib", InstallZlib, "include/zlib.h")############################################################
# boost# The default installation of boost on Windows puts headers in a versioned 
# subdirectory, which we have to account for here. Specifying "layout=system" 
# would cause the Windows header install to match Linux/MacOS, but the 
# "layout=system" flag also changes the naming of the boost dlls in a 
# manner that causes problems for dependent libraries that rely on boost's
# trick of automatically linking the boost libraries via pragmas in boost's
# standard include files. Dependencies that use boost's pragma linking
# facility in general don't have enough configuration switches to also coerce 
# the naming of the dlls and so it is best to rely on boost's most default
# settings for maximum compatibility.
#
# It's tricky to determine which version of boost we'll be using at this
# point in the script, so we simplify the logic by checking for any of the
# possible boost header locations that are possible outcomes from running
# this script.
BOOST_VERSION_FILES = ["include/boost/version.hpp","include/boost-1_76/boost/version.hpp","include/boost-1_82/boost/version.hpp","include/boost-1_86/boost/version.hpp"
]def InstallBoost_Helper(context, force, buildArgs):# In general we use boost 1.76.0 to adhere to VFX Reference Platform CY2022.# However, there are some cases where a newer version is required.# - Building with Visual Studio 2022 with the 14.4x toolchain requires boost#   1.86.0 or newer, we choose it for all Visual Studio 2022 versions for#   simplicity.# - Building on MacOS requires v1.82.0 or later for C++17 support starting#   with Xcode 15.if IsVisualStudio2022OrGreater():BOOST_VERSION = (1, 86, 0)BOOST_SHA256 = "cd20a5694e753683e1dc2ee10e2d1bb11704e65893ebcc6ced234ba68e5d8646"elif MacOS():BOOST_VERSION = (1, 82, 0)BOOST_SHA256 = "f7c9e28d242abcd7a2c1b962039fcdd463ca149d1883c3a950bbcc0ce6f7c6d9"else:BOOST_VERSION = (1, 76, 0)BOOST_SHA256 = "0fd43bb53580ca54afc7221683dfe8c6e3855b351cd6dce53b1a24a7d7fbeedd"# Documentation files in the boost archive can have exceptionally# long paths. This can lead to errors when extracting boost on Windows,# since paths are limited to 260 characters by default on that platform.# To avoid this, we skip extracting all documentation.## For some examples, see: https://svn.boost.org/trac10/ticket/11677dontExtract = ["*/doc/*","*/libs/*/doc/*","*/libs/wave/test/testwave/testfiles/utf8-test-*"]# Provide backup sources for downloading boost to avoid issues when# one mirror goes down.major, minor, patch = BOOST_VERSIONversion = f"{major}.{minor}.{patch}"filename = f"boost_{major}_{minor}_{patch}.zip"urls = [# The sourceforge mirror is typically faster than archives.boost.io# so we use that first.f"https://sourceforge.net/projects/boost/files/boost/{version}/{filename}/download",f"https://archives.boost.io/release/{version}/source/{filename}"]sourceDir = Nonefor url in urls:try:sourceDir = DownloadURL(url, context, force,dontExtract=dontExtract,destFileName=filename,expectedSHA256=BOOST_SHA256)breakexcept Exception as e:PrintWarning(str(e))if url != urls[-1]:PrintWarning("Trying alternative sources")else:raise RuntimeError("Failed to download boost")with CurrentWorkingDirectory(sourceDir):if Windows():bootstrap = "bootstrap.bat"else:bootstrap = "./bootstrap.sh"# zip doesn't preserve file attributes, so force +x manually.Run('chmod +x ' + bootstrap)Run('chmod +x ./tools/build/src/engine/build.sh')# For cross-compilation on macOS we need to specify the architecture# for both the bootstrap and the b2 phase of building boost.bootstrapCmd = '{bootstrap} --prefix="{instDir}"'.format(bootstrap=bootstrap, instDir=context.instDir)macOSArch = ""if MacOS():if apple_utils.GetTargetArch(context) == \apple_utils.TARGET_X86:macOSArch = "-arch {0}".format(apple_utils.TARGET_X86)elif apple_utils.GetTargetArch(context) == \apple_utils.GetTargetArmArch():macOSArch = "-arch {0}".format(apple_utils.GetTargetArmArch())elif context.targetUniversal:(primaryArch, secondaryArch) = \apple_utils.GetTargetArchPair(context)macOSArch="-arch {0} -arch {1}".format(primaryArch, secondaryArch)if macOSArch:bootstrapCmd += " cxxflags=\"{0} -std=c++17 -stdlib=libc++\" " \" cflags=\"{0}\" " \" linkflags=\"{0}\"".format(macOSArch)bootstrapCmd += " --with-toolset=clang"Run(bootstrapCmd)# b2 supports at most -j64 and will error if given a higher value.num_procs = min(64, context.numJobs)# boost only accepts three variants: debug, release, profileboostBuildVariant = "profile"if context.buildDebug:boostBuildVariant= "debug"elif context.buildRelease:boostBuildVariant= "release"elif context.buildRelWithDebug:boostBuildVariant= "profile"b2_settings = ['--prefix="{instDir}"'.format(instDir=context.instDir),'--build-dir="{buildDir}"'.format(buildDir=context.buildDir),'-j{procs}'.format(procs=num_procs),'address-model=64','link=shared','runtime-link=shared','threading=multi', 'variant={variant}'.format(variant=boostBuildVariant),'--with-atomic','--with-regex']if context.buildOIIO:b2_settings.append("--with-date_time")if context.buildOIIO or context.enableOpenVDB:b2_settings.append("--with-chrono")b2_settings.append("--with-system")b2_settings.append("--with-thread")if context.enableOpenVDB:b2_settings.append("--with-iostreams")# b2 with -sNO_COMPRESSION=1 fails with the following error message:#     error: at [...]/boost_1_61_0/tools/build/src/kernel/modules.jam:107#     error: Unable to find file or target named#     error:     '/zlib//zlib'#     error: referred to from project at#     error:     'libs/iostreams/build'#     error: could not resolve project reference '/zlib'# But to avoid an extra library dependency, we can still explicitly# exclude the bzip2 compression from boost_iostreams (note that# OpenVDB uses blosc compression).b2_settings.append("-sNO_BZIP2=1")if context.buildOIIO:b2_settings.append("--with-filesystem")if force:b2_settings.append("-a")if Windows():# toolset parameter for Visual Studio documented here:# https://github.com/boostorg/build/blob/develop/src/tools/msvc.jamif context.cmakeToolset == "v143":b2_settings.append("toolset=msvc-14.3")elif context.cmakeToolset == "v142":b2_settings.append("toolset=msvc-14.2")elif context.cmakeToolset == "v141":b2_settings.append("toolset=msvc-14.1")elif IsVisualStudio2022OrGreater():b2_settings.append("toolset=msvc-14.3")elif IsVisualStudio2019OrGreater():b2_settings.append("toolset=msvc-14.2")elif IsVisualStudio2017OrGreater():b2_settings.append("toolset=msvc-14.1")if MacOS():# Must specify toolset=clang to ensure install_name for boost# libraries includes @rpathb2_settings.append("toolset=clang")## Xcode 15.3 (and hence Apple Clang 15) removed the global# declaration of std::piecewise_construct which causes boost build# to fail.# https://developer.apple.com/documentation/xcode-release-notes/xcode-15_3-release-notes.# A fix for the same is also available in boost 1.84:# https://github.com/boostorg/container/commit/79a75f470e75f35f5f2a91e10fcc67d03b0a2160b2_settings.append(f"define=BOOST_UNORDERED_HAVE_PIECEWISE_CONSTRUCT=0")if macOSArch:b2_settings.append("cxxflags=\"{0} -std=c++17 -stdlib=libc++\"".format(macOSArch))b2_settings.append("cflags=\"{0}\"".format(macOSArch))b2_settings.append("linkflags=\"{0}\"".format(macOSArch))if context.buildDebug:b2_settings.append("--debug-configuration")# Add on any user-specified extra arguments.b2_settings += buildArgs# Append extra argument controlling libstdc++ ABI if specified.AppendCXX11ABIArg("cxxflags", context, b2_settings)b2 = "b2" if Windows() else "./b2"Run('{b2} {options} install'.format(b2=b2, options=" ".join(b2_settings)))def InstallBoost(context, force, buildArgs):# Boost's build system will install the version.hpp header before# building its libraries. We make sure to remove it in case of# any failure to ensure that the build script detects boost as a # dependency to build the next time it's run.try:InstallBoost_Helper(context, force, buildArgs)except:for versionHeader in [os.path.join(context.instDir, f) for f in BOOST_VERSION_FILES]:if os.path.isfile(versionHeader):try: os.remove(versionHeader)except: passraiseBOOST = Dependency("boost", InstallBoost, *BOOST_VERSION_FILES)############################################################
# Intel oneTBBONETBB_URL = "https://github.com/oneapi-src/oneTBB/archive/refs/tags/v2021.9.0.zip"def InstallOneTBB(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(ONETBB_URL, context, force)):RunCMake(context, force,['-DTBB_TEST=OFF','-DTBB_STRICT=OFF'] + buildArgs)ONETBB = Dependency("oneTBB", InstallOneTBB, "include/oneapi/tbb.h")############################################################
# Intel TBBif Windows():TBB_URL = "https://github.com/oneapi-src/oneTBB/releases/download/v2020.3/tbb-2020.3-win.zip"TBB_ROOT_DIR_NAME = "tbb"
elif MacOS():# On MacOS Intel systems we experience various crashes in tests during# teardown starting with 2018 Update 2. Until we figure that out, we use# 2018 Update 1 on this platform.TBB_URL = "https://github.com/oneapi-src/oneTBB/archive/refs/tags/v2020.3.zip"TBB_INTEL_URL = "https://github.com/oneapi-src/oneTBB/archive/refs/tags/2018_U1.zip"
else:# Use point release with fix https://github.com/oneapi-src/oneTBB/pull/833TBB_URL = "https://github.com/oneapi-src/oneTBB/archive/refs/tags/v2020.3.1.zip"def InstallTBB(context, force, buildArgs):if Windows():InstallTBB_Windows(context, force, buildArgs)elif MacOS():InstallTBB_MacOS(context, force, buildArgs)else:InstallTBB_Linux(context, force, buildArgs)def InstallTBB_Windows(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(TBB_URL, context, force, TBB_ROOT_DIR_NAME)):# On Windows, we simply copy headers and pre-built DLLs to# the appropriate location.if buildArgs:PrintWarning("Ignoring build arguments {}, TBB is ""not built from source on this platform.".format(buildArgs))CopyFiles(context, "bin\\intel64\\vc14\\*.*", "bin")CopyFiles(context, "lib\\intel64\\vc14\\*.*", "lib")CopyDirectory(context, "include\\serial", "include\\serial")CopyDirectory(context, "include\\tbb", "include\\tbb")def InstallTBB_MacOS(context, force, buildArgs):tbb_url = TBB_URL if apple_utils.IsTargetArm(context) else TBB_INTEL_URLwith CurrentWorkingDirectory(DownloadURL(tbb_url, context, force)):# Ensure that the tbb build system picks the proper architecture.PatchFile("build/macos.clang.inc",[("-m64","-m64 -arch {0}".format(apple_utils.TARGET_X86)),("ifeq ($(arch),$(filter $(arch),armv7 armv7s arm64))","ifeq ($(arch),$(filter $(arch),armv7 armv7s {0}))".format(apple_utils.GetTargetArmArch()))])if context.buildTarget == apple_utils.TARGET_VISIONOS:# Create visionOS config from iOS configshutil.copy(src="build/ios.macos.inc",dst="build/visionos.macos.inc")PatchFile("build/visionos.macos.inc",[("ios","visionos"),("iOS", "visionOS"),("iPhone", "XR"),("IPHONEOS","XROS"),("?= 8.0", "?= 1.0")])# iOS clang just reuses the macOS one,# so it's easier to copy it directly.shutil.copy(src="build/macos.clang.inc",dst="build/visionos.clang.inc")PatchFile("build/visionos.clang.inc",[("ios","visionos"),("-miphoneos-version-min=", "-target arm64-apple-xros"),("iOS", "visionOS"),("iPhone", "XR"),("IPHONEOS","XROS")])(primaryArch, secondaryArch) = apple_utils.GetTargetArchPair(context)# tbb uses different arch namesif (primaryArch == apple_utils.TARGET_X86):primaryArch = "intel64"if (secondaryArch == apple_utils.TARGET_X86):secondaryArch = "intel64"# Install both release and debug builds.# See comments in InstallTBB_Linux.def _RunBuild(arch):if not arch:returnenv = os.environ.copy()if MacOSTargetEmbedded(context):env["SDKROOT"] = apple_utils.GetSDKRoot(context)buildArgs.append(f' compiler=clang arch=arm64 extra_inc=big_iron.inc target={context.buildTarget.lower()}')makeTBBCmd = 'make -j{procs} arch={arch} {buildArgs}'.format(arch=arch, procs=context.numJobs,buildArgs=" ".join(buildArgs))Run(makeTBBCmd, env=env)_RunBuild(primaryArch)_RunBuild(secondaryArch)# See comments in InstallTBB_Linux about why we patch the Makefile# and rerun builds. This is only required for TBB 2020; 2019 and# earlier build both release and debug, and 2021 has moved to CMake.if "2020" in tbb_url:PatchFile("Makefile", [("release", "debug")])_RunBuild(primaryArch)_RunBuild(secondaryArch)if context.targetUniversal:x86Files = glob.glob(os.getcwd() +"/build/*intel64*_release/libtbb*.*")armFiles = glob.glob(os.getcwd() +"/build/*{0}*_release/libtbb*.*".format(apple_utils.GetTargetArmArch()))libNames = [os.path.basename(x) for x in x86Files]x86Dir = os.path.dirname(x86Files[0])armDir = os.path.dirname(armFiles[0])apple_utils.CreateUniversalBinaries(context, libNames, x86Dir, armDir)x86Files = glob.glob(os.getcwd() + "/build/*intel64*_debug/libtbb*.*")armFiles = glob.glob(os.getcwd() + "/build/*{0}*_debug/libtbb*.*".format(apple_utils.GetTargetArmArch()))if x86Files and armFiles:libNames = [os.path.basename(x) for x in x86Files]x86Dir = os.path.dirname(x86Files[0])armDir = os.path.dirname(armFiles[0])apple_utils.CreateUniversalBinaries(context, libNames, x86Dir, armDir)else:CopyFiles(context, "build/*_release/libtbb*.*", "lib")CopyFiles(context, "build/*_debug/libtbb*.*", "lib")CopyDirectory(context, "include/serial", "include/serial")CopyDirectory(context, "include/tbb", "include/tbb")def InstallTBB_Linux(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(TBB_URL, context, force)):# Append extra argument controlling libstdc++ ABI if specified.AppendCXX11ABIArg("CXXFLAGS", context, buildArgs)# TBB does not support out-of-source builds in a custom location.makeTBBCmd = 'make -j{procs} {buildArgs}'.format(procs=context.numJobs, buildArgs=" ".join(buildArgs))Run(makeTBBCmd)# Install both release and debug builds. USD requires the debug# libraries when building in debug mode, and installing both# makes it easier for users to install dependencies in some# location that can be shared by both release and debug USD# builds.## As of TBB 2020 the build no longer produces a debug build along# with the release build. There is also no way to specify a debug# build when running make, even though the internals of the build# still support it.## To workaround this, we patch the Makefile to change "release" to# "debug" and re-run the build, copying the debug libraries# afterwards. ## See https://github.com/oneapi-src/oneTBB/issues/207/PatchFile("Makefile", [("release", "debug")])Run(makeTBBCmd)CopyFiles(context, "build/*_release/libtbb*.*", "lib")CopyFiles(context, "build/*_debug/libtbb*.*", "lib")CopyDirectory(context, "include/serial", "include/serial")CopyDirectory(context, "include/tbb", "include/tbb")TBB = Dependency("TBB", InstallTBB, "include/tbb/tbb.h")############################################################
# JPEGJPEG_URL = "https://github.com/libjpeg-turbo/libjpeg-turbo/archive/2.0.1.zip"def InstallJPEG(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(JPEG_URL, context, force)):extraJPEGArgs = buildArgsif not which("nasm"):extraJPEGArgs.append("-DWITH_SIMD=FALSE")RunCMake(context, force, extraJPEGArgs)return os.getcwd()JPEG = Dependency("JPEG", InstallJPEG, "include/jpeglib.h")############################################################
# TIFFTIFF_URL = "https://gitlab.com/libtiff/libtiff/-/archive/v4.0.7/libtiff-v4.0.7.zip"def InstallTIFF(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(TIFF_URL, context, force)):# libTIFF has a build issue on Windows where tools/tiffgt.c# unconditionally includes unistd.h, which does not exist.# To avoid this, we patch the CMakeLists.txt to skip building# the tools entirely. We do this on Linux and MacOS as well# to avoid requiring some GL and X dependencies.## We also need to skip building tests, since they rely on # the tools we've just elided.PatchFile("CMakeLists.txt", [("add_subdirectory(tools)", "# add_subdirectory(tools)"),("add_subdirectory(test)", "# add_subdirectory(test)")])# The libTIFF CMakeScript says the ld-version-script # functionality is only for compilers using GNU ld on # ELF systems or systems which provide an emulation; therefore# skipping it completely on mac and windows.if MacOS() or Windows():extraArgs = ["-Dld-version-script=OFF"]else:extraArgs = []extraArgs += buildArgsRunCMake(context, force, extraArgs)TIFF = Dependency("TIFF", InstallTIFF, "include/tiff.h")############################################################
# PNGPNG_URL = "https://github.com/pnggroup/libpng/archive/refs/tags/v1.6.47.zip"def InstallPNG(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(PNG_URL, context, force)):# Framework builds were enabled by default in v1.6.41 in commit# 8fc13a8. We explicitly disable this to maintain legacy behavior# from v1.6.38, which is what this script used previously.# OpenImageIO v2.5.16.0 runs into linker issues otherwise.macArgs = ["-DPNG_FRAMEWORK=OFF"]if MacOS() and apple_utils.IsTargetArm(context):# Ensure libpng's build doesn't erroneously activate inappropriate# Neon extensionsmacArgs += ["-DCMAKE_C_FLAGS=\"-DPNG_ARM_NEON_OPT=0\""]RunCMake(context, force, buildArgs + macArgs)PNG = Dependency("PNG", InstallPNG, "include/png.h")############################################################
# IlmBase/OpenEXROPENEXR_URL = "https://github.com/AcademySoftwareFoundation/openexr/archive/refs/tags/v3.1.13.zip"def InstallOpenEXR(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(OPENEXR_URL, context, force)):RunCMake(context, force, ['-DOPENEXR_INSTALL_TOOLS=OFF','-DOPENEXR_INSTALL_EXAMPLES=OFF',# Force OpenEXR to build and use a separate Imath library# instead of looking for one externally. This ensures that# OpenEXR and other dependencies use the Imath library# built via this script.'-DOPENEXR_FORCE_INTERNAL_IMATH=ON','-DBUILD_TESTING=OFF'] + buildArgs)OPENEXR = Dependency("OpenEXR", InstallOpenEXR, "include/OpenEXR/ImfVersion.h")############################################################
# PtexPTEX_URL = "https://github.com/wdas/ptex/archive/refs/tags/v2.4.2.zip"
PTEX_VERSION = "v2.4.2"def InstallPtex(context, force, buildArgs):cmakeOptions = ['-DBUILD_TESTING=OFF','-DPTEX_BUILD_STATIC_LIBS=OFF',# We must tell the Ptex build system what version we're building# otherwise we get errors when running CMake.'-DPTEX_VER={v}'.format(v=PTEX_VERSION)]cmakeOptions += buildArgswith CurrentWorkingDirectory(DownloadURL(PTEX_URL, context, force)):RunCMake(context, force, cmakeOptions)PTEX = Dependency("Ptex", InstallPtex, "include/PtexVersion.h")############################################################
# BLOSC (Compression used by OpenVDB)BLOSC_URL = "https://github.com/Blosc/c-blosc/archive/v1.20.1.zip"
if MacOS():# Using blosc v1.21.6 to avoid build errors with Xcode 16.3+ toolchain, # caused by incompatibility with internally used zlib v1.2.8 with blosc # v1.20.1BLOSC_URL = "https://github.com/Blosc/c-blosc/archive/v1.21.6.zip"def InstallBLOSC(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(BLOSC_URL, context, force)):# MacOS we can use the built in Zlib instead of the external one.macArgs = ["-DPREFER_EXTERNAL_ZLIB=ON"]if MacOS() and apple_utils.IsTargetArm(context):# Need to disable SSE for macOS ARM targets.macArgs += ["-DDEACTIVATE_SSE2=ON"]RunCMake(context, force, buildArgs + macArgs)BLOSC = Dependency("Blosc", InstallBLOSC, "include/blosc.h")############################################################
# OpenVDBOPENVDB_URL = "https://github.com/AcademySoftwareFoundation/openvdb/archive/refs/tags/v9.1.0.zip"# OpenVDB v9.1.0 requires TBB 2019.0 or above, but this script installs
# TBB 2018 on macOS Intel systems for reasons documented above. So we
# keep OpenVDB at the version specified for the VFX Reference Platform
# CY2021, which is the last version that supported 2018.
OPENVDB_INTEL_URL = "https://github.com/AcademySoftwareFoundation/openvdb/archive/refs/tags/v8.2.0.zip"def InstallOpenVDB(context, force, buildArgs):openvdb_url = OPENVDB_URLif MacOS() and not apple_utils.IsTargetArm(context):openvdb_url = OPENVDB_INTEL_URLwith CurrentWorkingDirectory(DownloadURL(openvdb_url, context, force)):# Back-port patch from OpenVDB PR #1977 to avoid errors when building# with Xcode 16.3+. This fix is anticipated to be part of an OpenVDB# 12.x release, which is in the VFX Reference Platform CY2025 and is# several major versions ahead of what we currently use.PatchFile("openvdb/openvdb/tree/NodeManager.h",[("OpT::template eval", "OpT::eval")])extraArgs = ['-DOPENVDB_BUILD_PYTHON_MODULE=OFF','-DOPENVDB_BUILD_BINARIES=OFF','-DOPENVDB_BUILD_UNITTESTS=OFF']# Make sure to use boost installed by the build script and not any# system installed boostextraArgs.append('-DBoost_NO_SYSTEM_PATHS=ON')extraArgs.append('-DBLOSC_ROOT="{instDir}"'.format(instDir=context.instDir))extraArgs.append('-DTBB_ROOT="{instDir}"'.format(instDir=context.instDir))# OpenVDB needs Half type from IlmBaseextraArgs.append('-DILMBASE_ROOT="{instDir}"'.format(instDir=context.instDir))# Add on any user-specified extra arguments.extraArgs += buildArgsRunCMake(context, force, extraArgs)OPENVDB = Dependency("OpenVDB", InstallOpenVDB, "include/openvdb/openvdb.h")############################################################
# OpenImageIOOIIO_URL = "https://github.com/OpenImageIO/oiio/archive/refs/tags/v2.5.16.0.zip"def InstallOpenImageIO(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(OIIO_URL, context, force)):# The only time that we want to build tools with OIIO is for testing# purposes. Libraries such as usdImagingGL might need to use tools like# idiff to compare the output images from their testsbuildOIIOTools = 'ON' if (context.buildUsdImagingand context.buildTests) else 'OFF'extraArgs = ['-DOIIO_BUILD_TOOLS={}'.format(buildOIIOTools),'-DOIIO_BUILD_TESTS=OFF','-DBUILD_DOCS=OFF','-DUSE_PYTHON=OFF','-DSTOP_ON_WARNING=OFF']# OIIO's FindOpenEXR module circumvents CMake's normal library # search order, which causes versions of OpenEXR installed in# /usr/local or other hard-coded locations in the module to# take precedence over the version we've built, which would # normally be picked up when we specify CMAKE_PREFIX_PATH. # This may lead to undefined symbol errors at build or runtime. # So, we explicitly specify the OpenEXR we want to use here.extraArgs.append('-DOPENEXR_ROOT="{instDir}"'.format(instDir=context.instDir))# If Ptex support is disabled in USD, disable support in OpenImageIO# as well. This ensures OIIO doesn't accidentally pick up a Ptex# library outside of our build.if not context.enablePtex:extraArgs.append('-DUSE_PTEX=OFF')# Make sure to use boost installed by the build script and not any# system installed boostextraArgs.append('-DBoost_NO_SYSTEM_PATHS=ON')# OIIO 2.5.16 requires Boost_NO_BOOST_CMAKE to be explicitly defined,# else it sets it to ON.extraArgs.append('-DBoost_NO_BOOST_CMAKE=OFF')# OpenImageIO 2.3.5 changed the default postfix for debug library# names from "" to "_d". USD's build system currently does not support# finding the library under this name, so as an interim workaround# we reset it back to its old value.extraArgs.append('-DCMAKE_DEBUG_POSTFIX=""')# Add on any user-specified extra arguments.extraArgs += buildArgsRunCMake(context, force, extraArgs)OPENIMAGEIO = Dependency("OpenImageIO", InstallOpenImageIO,"include/OpenImageIO/oiioversion.h")############################################################
# OpenColorIOOCIO_URL = "https://github.com/AcademySoftwareFoundation/OpenColorIO/archive/refs/tags/v2.1.3.zip"def InstallOpenColorIO(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(OCIO_URL, context, force)):extraArgs = ['-DOCIO_BUILD_APPS=OFF','-DOCIO_BUILD_NUKE=OFF','-DOCIO_BUILD_DOCS=OFF','-DOCIO_BUILD_TESTS=OFF','-DOCIO_BUILD_GPU_TESTS=OFF','-DOCIO_BUILD_PYTHON=OFF']if MacOS():if apple_utils.IsTargetArm(context):extraArgs.append('-DOCIO_USE_SSE=OFF')# Add on any user-specified extra arguments.extraArgs += buildArgsRunCMake(context, force, extraArgs)OPENCOLORIO = Dependency("OpenColorIO", InstallOpenColorIO,"include/OpenColorIO/OpenColorABI.h")############################################################
# OpenSubdivOPENSUBDIV_URL = "https://github.com/PixarAnimationStudios/OpenSubdiv/archive/v3_6_0.zip"def InstallOpenSubdiv(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(OPENSUBDIV_URL, context, force)):extraArgs = ['-DNO_EXAMPLES=ON','-DNO_TUTORIALS=ON','-DNO_REGRESSION=ON','-DNO_DOC=ON','-DNO_OMP=ON','-DNO_CUDA=ON','-DNO_OPENCL=ON','-DNO_DX=ON','-DNO_TESTS=ON','-DNO_GLEW=ON','-DNO_GLFW=ON','-DNO_PTEX=ON','-DNO_TBB=ON',]# Use Metal for macOS and all Apple embedded systems.if MacOS():extraArgs.append('-DNO_OPENGL=ON')# Add on any user-specified extra arguments.extraArgs += buildArgsRunCMake(context, force, extraArgs)OPENSUBDIV = Dependency("OpenSubdiv", InstallOpenSubdiv, "include/opensubdiv/version.h")############################################################
# PyOpenGLdef GetPyOpenGLInstructions():return ('PyOpenGL is not installed. If you have pip ''installed, run "pip install PyOpenGL" to ''install it, then re-run this script.\n''If PyOpenGL is already installed, you may need to ''update your PYTHONPATH to indicate where it is ''located.')PYOPENGL = PythonDependency("PyOpenGL", GetPyOpenGLInstructions, moduleNames=["OpenGL"])############################################################
# PySidedef GetPySideInstructions():# For licensing reasons, this script cannot install PySide itself.if MacOS():# PySide6 is required for Apple Silicon support, so is the default# across all macOS hardware platforms.return ('PySide6 is not installed. If you have pip ''installed, run "pip install PySide6" ''to install it, then re-run this script.\n''If PySide6 is already installed, you may need to ''update your PYTHONPATH to indicate where it is ''located.')else:return ('PySide2 or PySide6 are not installed. If you have pip ''installed, run "pip install PySide2" ''to install it, then re-run this script.\n''If PySide2 is already installed, you may need to ''update your PYTHONPATH to indicate where it is ''located.')PYSIDE = PythonDependency("PySide", GetPySideInstructions,moduleNames=["PySide2", "PySide6"])############################################################
# HDF5HDF5_URL = "https://support.hdfgroup.org/ftp/HDF5/releases/hdf5-1.10/hdf5-1.10.0-patch1/src/hdf5-1.10.0-patch1.zip"def InstallHDF5(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(HDF5_URL, context, force)):if MacOS():PatchFile("config/cmake_ext_mod/ConfigureChecks.cmake",[("if (ARCH_LENGTH GREATER 1)", "if (FALSE)")])if context.targetUniversal:PatchFile("config/cmake/H5pubconf.h.in",[(" #define H5_SIZEOF_LONG_LONG 8"," #define H5_SIZEOF_LONG_LONG 8\n" +" #define H5_SIZEOF_LONG_DOUBLE 16")])RunCMake(context, force,['-DBUILD_TESTING=OFF','-DHDF5_BUILD_TOOLS=OFF','-DHDF5_BUILD_EXAMPLES=OFF'] + buildArgs)HDF5 = Dependency("HDF5", InstallHDF5, "include/hdf5.h")############################################################
# AlembicALEMBIC_URL = "https://github.com/alembic/alembic/archive/refs/tags/1.8.5.zip"def InstallAlembic(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(ALEMBIC_URL, context, force)):cmakeOptions = ['-DUSE_BINARIES=OFF', '-DUSE_TESTS=OFF']if context.enableHDF5:# HDF5 requires the H5_BUILT_AS_DYNAMIC_LIB macro be defined if# it was built with CMake as a dynamic library.cmakeOptions += ['-DUSE_HDF5=ON','-DHDF5_ROOT="{instDir}"'.format(instDir=context.instDir),'-DCMAKE_CXX_FLAGS="-D H5_BUILT_AS_DYNAMIC_LIB"']else:cmakeOptions += ['-DUSE_HDF5=OFF']cmakeOptions += buildArgsRunCMake(context, force, cmakeOptions)ALEMBIC = Dependency("Alembic", InstallAlembic, "include/Alembic/Abc/Base.h")############################################################
# DracoDRACO_URL = "https://github.com/google/draco/archive/refs/tags/1.3.6.zip"def InstallDraco(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(DRACO_URL, context, force)):cmakeOptions = ['-DBUILD_USD_PLUGIN=ON',]cmakeOptions += buildArgsRunCMake(context, force, cmakeOptions)DRACO = Dependency("Draco", InstallDraco, "include/draco/compression/decode.h")############################################################
# MaterialXMATERIALX_URL = "https://github.com/AcademySoftwareFoundation/MaterialX/archive/v1.39.3.zip"def InstallMaterialX(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(MATERIALX_URL, context, force)):cmakeOptions = ['-DMATERIALX_BUILD_SHARED_LIBS=ON','-DMATERIALX_BUILD_TESTS=OFF']if MacOSTargetEmbedded(context):# The materialXShaderGen in hdSt assumes the GLSL shadergen is# available but MaterialX intertwines GLSL shadergen support with# also requiring rendering support.cmakeOptions.extend(['-DMATERIALX_BUILD_GEN_MSL=ON','-DMATERIALX_BUILD_GEN_GLSL=ON','-DMATERIALX_BUILD_IOS=ON'])PatchFile("CMakeLists.txt",[('    set(MATERIALX_BUILD_GEN_GLSL OFF)','    set(MATERIALX_BUILD_GEN_GLSL ON)'),('    if (MATERIALX_BUILD_GEN_GLSL)\n' +'        add_subdirectory(source/MaterialXRenderGlsl)\n' +'    endif()','    if (MATERIALX_BUILD_GEN_GLSL AND NOT MATERIALX_BUILD_IOS)\n' +'        add_subdirectory(source/MaterialXRenderGlsl)\n' +'    endif()')], multiLineMatches=True)cmakeOptions += buildArgsRunCMake(context, force, cmakeOptions)MATERIALX = Dependency("MaterialX", InstallMaterialX, "include/MaterialXCore/Library.h")############################################################
# Embree
# For MacOS we use version 3.13.3 to include a fix from Intel
# to build on Apple Silicon.
if MacOS():EMBREE_URL = "https://github.com/embree/embree/archive/v3.13.3.zip"
else:EMBREE_URL = "https://github.com/embree/embree/archive/v3.2.2.zip"def InstallEmbree(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(EMBREE_URL, context, force)):extraArgs = ['-DTBB_ROOT={instDir}'.format(instDir=context.instDir),'-DEMBREE_TUTORIALS=OFF','-DEMBREE_ISPC_SUPPORT=OFF']if MacOS() and context.targetUniversal:extraArgs += ['-DEMBREE_MAX_ISA=NEON','-DEMBREE_ISA_NEON=ON']extraArgs += buildArgsRunCMake(context, force, extraArgs)EMBREE = Dependency("Embree", InstallEmbree, "include/embree3/rtcore.h")############################################################
# AnimX# This GitHub project has no releases, so we fixed on the latest commit as of
# 2024-02-06 - 5db8ee4, which was committed on 2018-11-05
ANIMX_URL = "https://github.com/Autodesk/animx/archive/5db8ee416d5fa7050357f498d4dcfaa6ff3f7738.zip"def InstallAnimX(context, force, buildArgs):with CurrentWorkingDirectory(DownloadURL(ANIMX_URL, context, force)):# AnimX strangely installs its output to the inst root, rather than the# lib subdirectory.  Fix.PatchFile("src/CMakeLists.txt",[("LIBRARY DESTINATION .", "LIBRARY DESTINATION lib")])extraArgs = ['-DANIMX_BUILD_MAYA_TESTSUITE=OFF','-DMAYA_64BIT_TIME_PRECISION=ON','-DANIMX_BUILD_SHARED=ON','-DANIMX_BUILD_STATIC=OFF']RunCMake(context, force, extraArgs)ANIMX = Dependency("AnimX", InstallAnimX, "include/animx.h")############################################################
# USDdef InstallUSD(context, force, buildArgs):with CurrentWorkingDirectory(context.usdSrcDir):extraArgs = []extraArgs.append('-DPXR_PREFER_SAFETY_OVER_SPEED={}'.format('ON' if context.safetyFirst else 'OFF'))if context.buildPython:extraArgs.append('-DPXR_ENABLE_PYTHON_SUPPORT=ON')# Many people on Windows may not have Python libraries with debug# symbols (denoted by a '_d') installed. This is the common# case when a user installs Python from the official download# website. Therefore we can still let people decide to build USD# with the release version of Python if debugging into Python land# is not what they want which can be done by setting the debugPython# argument.if context.buildDebug and context.debugPython:extraArgs.append('-DPXR_USE_DEBUG_PYTHON=ON')else:extraArgs.append('-DPXR_USE_DEBUG_PYTHON=OFF')# CMake has trouble finding the executable, library, and include# directories when there are multiple versions of Python installed.# This can lead to crashes due to USD being linked against one# version of Python but running through some other Python# interpreter version. This primarily shows up on macOS, as it's# common to have a Python install that's separate from the one# included with the system.## To avoid this, we try to determine these paths from Python# itself rather than rely on CMake's heuristics.pythonInfo = GetPythonInfo(context)if pythonInfo:extraArgs.append('-DPython3_EXECUTABLE="{pyExecPath}"'.format(pyExecPath=pythonInfo[0]))extraArgs.append('-DPython3_LIBRARY="{pyLibPath}"'.format(pyLibPath=pythonInfo[1]))extraArgs.append('-DPython3_INCLUDE_DIR="{pyIncPath}"'.format(pyIncPath=pythonInfo[2]))else:extraArgs.append('-DPXR_ENABLE_PYTHON_SUPPORT=OFF')if context.buildShared:extraArgs.append('-DBUILD_SHARED_LIBS=ON')elif context.buildMonolithic:extraArgs.append('-DPXR_BUILD_MONOLITHIC=ON')if context.buildDebug:extraArgs.append('-DTBB_USE_DEBUG_BUILD=ON')else:extraArgs.append('-DTBB_USE_DEBUG_BUILD=OFF')if context.buildDocs:extraArgs.append('-DPXR_BUILD_DOCUMENTATION=ON')else:extraArgs.append('-DPXR_BUILD_DOCUMENTATION=OFF')if context.buildHtmlDocs:extraArgs.append('-DPXR_BUILD_HTML_DOCUMENTATION=ON')else:extraArgs.append('-DPXR_BUILD_HTML_DOCUMENTATION=OFF')if context.buildPythonDocs:extraArgs.append('-DPXR_BUILD_PYTHON_DOCUMENTATION=ON')else:extraArgs.append('-DPXR_BUILD_PYTHON_DOCUMENTATION=OFF')if context.buildTests:extraArgs.append('-DPXR_BUILD_TESTS=ON')else:extraArgs.append('-DPXR_BUILD_TESTS=OFF')if context.buildExamples:extraArgs.append('-DPXR_BUILD_EXAMPLES=ON')else:extraArgs.append('-DPXR_BUILD_EXAMPLES=OFF')if context.buildTutorials:extraArgs.append('-DPXR_BUILD_TUTORIALS=ON')else:extraArgs.append('-DPXR_BUILD_TUTORIALS=OFF')if context.buildTools:extraArgs.append('-DPXR_BUILD_USD_TOOLS=ON')else:extraArgs.append('-DPXR_BUILD_USD_TOOLS=OFF')if context.buildUsdValidation:extraArgs.append('-DPXR_BUILD_USD_VALIDATION=ON')else:extraArgs.append('-DPXR_BUILD_USD_VALIDATION=OFF')if context.buildImaging:extraArgs.append('-DPXR_BUILD_IMAGING=ON')if context.enablePtex:extraArgs.append('-DPXR_ENABLE_PTEX_SUPPORT=ON')else:extraArgs.append('-DPXR_ENABLE_PTEX_SUPPORT=OFF')if context.enableOpenVDB:extraArgs.append('-DPXR_ENABLE_OPENVDB_SUPPORT=ON')else:extraArgs.append('-DPXR_ENABLE_OPENVDB_SUPPORT=OFF')if context.buildEmbree:extraArgs.append('-DPXR_BUILD_EMBREE_PLUGIN=ON')else:extraArgs.append('-DPXR_BUILD_EMBREE_PLUGIN=OFF')if context.buildPrman:if context.prmanLocation:extraArgs.append('-DRENDERMAN_LOCATION="{location}"'.format(location=context.prmanLocation))extraArgs.append('-DPXR_BUILD_PRMAN_PLUGIN=ON')else:extraArgs.append('-DPXR_BUILD_PRMAN_PLUGIN=OFF')                if context.buildOIIO:extraArgs.append('-DPXR_BUILD_OPENIMAGEIO_PLUGIN=ON')else:extraArgs.append('-DPXR_BUILD_OPENIMAGEIO_PLUGIN=OFF')if context.buildOCIO:extraArgs.append('-DPXR_BUILD_OPENCOLORIO_PLUGIN=ON')else:extraArgs.append('-DPXR_BUILD_OPENCOLORIO_PLUGIN=OFF')if context.enableVulkan:extraArgs.append('-DPXR_ENABLE_VULKAN_SUPPORT=ON')else:extraArgs.append('-DPXR_ENABLE_VULKAN_SUPPORT=OFF')else:extraArgs.append('-DPXR_BUILD_IMAGING=OFF')if context.buildUsdImaging:extraArgs.append('-DPXR_BUILD_USD_IMAGING=ON')else:extraArgs.append('-DPXR_BUILD_USD_IMAGING=OFF')if context.buildUsdview:extraArgs.append('-DPXR_BUILD_USDVIEW=ON')else:extraArgs.append('-DPXR_BUILD_USDVIEW=OFF')if context.buildAlembic:extraArgs.append('-DPXR_BUILD_ALEMBIC_PLUGIN=ON')if context.enableHDF5:extraArgs.append('-DPXR_ENABLE_HDF5_SUPPORT=ON')# CMAKE_PREFIX_PATH isn't sufficient for the FindHDF5 module # to find the HDF5 we've built, so provide an extra hint.extraArgs.append('-DHDF5_ROOT="{instDir}"'.format(instDir=context.instDir))else:extraArgs.append('-DPXR_ENABLE_HDF5_SUPPORT=OFF')else:extraArgs.append('-DPXR_BUILD_ALEMBIC_PLUGIN=OFF')if context.buildDraco:extraArgs.append('-DPXR_BUILD_DRACO_PLUGIN=ON')draco_root = (context.dracoLocationif context.dracoLocation else context.instDir)extraArgs.append('-DDRACO_ROOT="{}"'.format(draco_root))else:extraArgs.append('-DPXR_BUILD_DRACO_PLUGIN=OFF')if context.buildMaterialX:extraArgs.append('-DPXR_ENABLE_MATERIALX_SUPPORT=ON')else:extraArgs.append('-DPXR_ENABLE_MATERIALX_SUPPORT=OFF')if context.buildMayapyTests:extraArgs.append('-DPXR_BUILD_MAYAPY_TESTS=ON')extraArgs.append('-DMAYAPY_LOCATION="{mayapyLocation}"'.format(mayapyLocation=context.mayapyLocation))else:extraArgs.append('-DPXR_BUILD_MAYAPY_TESTS=OFF')if context.buildAnimXTests:extraArgs.append('-DPXR_BUILD_ANIMX_TESTS=ON')else:extraArgs.append('-DPXR_BUILD_ANIMX_TESTS=OFF')if Windows():# Increase the precompiled header buffer limit.extraArgs.append('-DCMAKE_CXX_FLAGS="/Zm150"')# Make sure to use boost installed by the build script and not any# system installed boostextraArgs.append('-DBoost_NO_SYSTEM_PATHS=ON')extraArgs += buildArgsRunCMake(context, force, extraArgs)USD = Dependency("USD", InstallUSD, "include/pxr/pxr.h")############################################################
# Install scriptprogramDescription = """\
Installation Script for USDBuilds and installs USD and 3rd-party dependencies to specified location.The `build_usd.py` script by default downloads and installs the zlib library
when necessary on platforms other than Linux. For those platforms, this behavior
may be overridden by supplying the `--no-zlib` command line option. If this
option is used, then the dependencies of OpenUSD which use zlib must be able to
discover the user supplied zlib in the build environment via the means of cmake's
`find_package` utility.- Libraries:
The following is a list of libraries that this script will download and build
as needed. These names can be used to identify libraries for various script
options, like --force or --build-args.{libraryList}- Downloading Libraries:
If curl or powershell (on Windows) are installed and located in PATH, they
will be used to download dependencies. Otherwise, a built-in downloader will 
be used.- Specifying Custom Build Arguments:
Users may specify custom build arguments for libraries using the --build-args
option. This values for this option must take the form <library name>,<option>. 
For example:%(prog)s --build-args boost,cxxflags=... USD,-DPXR_STRICT_BUILD_MODE=ON ...
%(prog)s --build-args USD,"-DPXR_STRICT_BUILD_MODE=ON -DPXR_HEADLESS_TEST_MODE=ON" ...These arguments will be passed directly to the build system for the specified 
library. Multiple quotes may be needed to ensure arguments are passed on 
exactly as desired. Users must ensure these arguments are suitable for the
specified library and do not conflict with other options, otherwise build 
errors may occur.- Embedded Build Targets
When cross compiling for an embedded target operating system, e.g. iOS, the
following components are disabled: python, tools, tests, examples, tutorials,
opencolorio, openimageio, openvdb, vulkan.- Python Versions and DCC Plugins:
Some DCCs may ship with and run using their own version of Python. In that case,
it is important that USD and the plugins for that DCC are built using the DCC's
version of Python and not the system version. This can be done by running
%(prog)s using the DCC's version of Python.If %(prog)s does not automatically detect the necessary information, the flag
--build-python-info can be used to explicitly pass in the Python that you want
USD to use to build the Python bindings with. This flag takes 4 arguments: 
Python executable, Python include directory Python library and Python version.Note that this is primarily an issue on MacOS, where a DCC's version of Python
is likely to conflict with the version provided by the system.- C++11 ABI Compatibility:
On Linux, the --use-cxx11-abi parameter can be used to specify whether to use
the C++11 ABI for libstdc++ when building USD and any dependencies. The value
given to this parameter will be used to define _GLIBCXX_USE_CXX11_ABI for
all builds.If this parameter is not specified, the compiler's default ABI will be used.For more details see:
https://gcc.gnu.org/onlinedocs/libstdc++/manual/using_dual_abi.html
""".format(libraryList=" ".join(sorted([d.name for d in AllDependencies])))parser = argparse.ArgumentParser(formatter_class=argparse.RawDescriptionHelpFormatter,allow_abbrev=False, description=programDescription)parser.add_argument("install_dir", type=str, help="Directory where USD will be installed")# parser.install_dir=""parser.add_argument("-n", "--dry_run", dest="dry_run", action="store_true",help="Only summarize what would happen")group = parser.add_mutually_exclusive_group()
group.add_argument("-v", "--verbose", action="count", default=1,dest="verbosity",help="Increase verbosity level (1-3)")
group.add_argument("-q", "--quiet", action="store_const", const=0,dest="verbosity",help="Suppress all output except for error messages")group = parser.add_argument_group(title="Build Options")
group.add_argument("-j", "--jobs", type=int, default=GetCPUCount(),help=("Number of build jobs to run in parallel. ""(default: # of processors [{0}])".format(GetCPUCount())))
group.add_argument("--build", type=str,help=("Build directory for USD and 3rd-party dependencies " "(default: <install_dir>/build)"))BUILD_DEBUG = "debug"
BUILD_RELEASE = "release"
BUILD_RELWITHDEBUG = "relwithdebuginfo"
group.add_argument("--build-variant", default=BUILD_RELEASE,choices=[BUILD_DEBUG, BUILD_RELEASE, BUILD_RELWITHDEBUG],help=("Build variant for USD and 3rd-party dependencies. ""(default: {})".format(BUILD_RELEASE)))group.add_argument("--ignore-paths", type=str, nargs="*", default=[],help="Paths for CMake to ignore when configuring projects.")
if MacOS():group.add_argument("--build-target",default=apple_utils.GetBuildTargetDefault(),choices=apple_utils.GetBuildTargets(),help=("Build target for macOS cross compilation. ""(default: {})".format(apple_utils.GetBuildTargetDefault())))if apple_utils.IsHostArm():# Intel Homebrew stores packages in /usr/local which unfortunately can# be where a lot of other things are too. So we only add this flag on arm macs.group.add_argument("--ignore-homebrew", action="store_true",help="Specify that CMake should ignore Homebrew packages.")group.add_argument("--build-args", type=str, nargs="*", default=[],help=("Custom arguments to pass to build system when ""building libraries (see docs above)"))
group.add_argument("--cmake-build-args", type=str,help=("Custom arguments to pass to all builds that use ""cmake; a single string, similar to the args passed ""for a single dependency in --build-args"))
group.add_argument("--build-python-info", type=str, nargs=4, default=[],metavar=('PYTHON_EXECUTABLE', 'PYTHON_INCLUDE_DIR', 'PYTHON_LIBRARY', 'PYTHON_VERSION'),help=("Specify a custom python to use during build"))
group.add_argument("--force", type=str, action="append", dest="force_build",default=[],help=("Force download and build of specified library ""(see docs above)"))
group.add_argument("--force-all", action="store_true",help="Force download and build of all libraries")
group.add_argument("--generator", type=str,help=("CMake generator to use when building libraries with ""cmake"))
group.add_argument("--toolset", type=str,help=("CMake toolset to use when building libraries with ""cmake"))
if MacOS():codesignDefault = True if apple_utils.IsHostArm() else Falsegroup.add_argument("--codesign", dest="macos_codesign",default=codesignDefault, action="store_true",help=("Enable code signing for macOS builds ""(defaults to enabled on Apple Silicon)"))if Linux():group.add_argument("--use-cxx11-abi", type=int, choices=[0, 1],help=("Use C++11 ABI for libstdc++. (see docs above)"))group = parser.add_argument_group(title="3rd Party Dependency Build Options")
group.add_argument("--src", type=str,help=("Directory where dependencies will be downloaded ""(default: <install_dir>/src)"))
group.add_argument("--inst", type=str,help=("Directory where dependencies will be installed ""(default: <install_dir>)"))group = parser.add_argument_group(title="USD Options")(SHARED_LIBS, MONOLITHIC_LIB) = (0, 1)
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--build-shared", dest="build_type",action="store_const", const=SHARED_LIBS, default=SHARED_LIBS,help="Build individual shared libraries (default)")
subgroup.add_argument("--build-monolithic", dest="build_type",action="store_const", const=MONOLITHIC_LIB,help="Build a single monolithic shared library")subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--tests", dest="build_tests", action="store_true",default=False, help="Build unit tests")
subgroup.add_argument("--no-tests", dest="build_tests", action="store_false",help="Do not build unit tests (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--examples", dest="build_examples", action="store_true",default=True, help="Build examples (default)")
subgroup.add_argument("--no-examples", dest="build_examples", action="store_false",help="Do not build examples")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--tutorials", dest="build_tutorials", action="store_true",default=True, help="Build tutorials (default)")
subgroup.add_argument("--no-tutorials", dest="build_tutorials", action="store_false",help="Do not build tutorials")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--tools", dest="build_tools", action="store_true",default=True, help="Build USD tools (default)")
subgroup.add_argument("--no-tools", dest="build_tools", action="store_false",help="Do not build USD tools")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--docs", dest="build_docs", action="store_true",default=False, help="Build C++ documentation")
subgroup.add_argument("--no-docs", dest="build_docs", action="store_false",help="Do not build C++ documentation (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--python-docs", dest="build_python_docs", action="store_true",default=False, help="Build Python docs")
subgroup.add_argument("--no-python-docs", dest="build_python_docs", action="store_false",help="Do not build Python documentation (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--python", dest="build_python", action="store_true",default=True, help="Build python based components ""(default)")
subgroup.add_argument("--no-python", dest="build_python", action="store_false",help="Do not build python based components")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--prefer-safety-over-speed", dest="safety_first",action="store_true", default=True, help="Enable extra safety checks (which may negatively ""impact performance) against malformed input files ""(default)")
subgroup.add_argument("--prefer-speed-over-safety", dest="safety_first",action="store_false", help="Disable performance-impacting safety checks against ""malformed input files")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--usdValidation", dest="build_usd_validation",action="store_true", default=True, help="Build USD " \"Validation library and validators (default)")
subgroup.add_argument("--no-usdValidation", dest="build_usd_validation",action="store_false", help="Do not build USD " \"Validation library and validators")subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--debug-python", dest="debug_python", action="store_true", help="Define Boost Python Debug if your Python library ""comes with Debugging symbols.")
subgroup.add_argument("--no-debug-python", dest="debug_python",action="store_false", help="Don't define Boost Python Debug if your Python ""library comes with Debugging symbols.")(NO_IMAGING, IMAGING, USD_IMAGING) = (0, 1, 2)group = parser.add_argument_group(title="Imaging and USD Imaging Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--imaging", dest="build_imaging", action="store_const", const=IMAGING, default=USD_IMAGING,help="Build imaging component")
subgroup.add_argument("--usd-imaging", dest="build_imaging", action="store_const", const=USD_IMAGING,help="Build imaging and USD imaging components (default)")
subgroup.add_argument("--no-imaging", dest="build_imaging", action="store_const", const=NO_IMAGING,help="Do not build imaging or USD imaging components")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--ptex", dest="enable_ptex", action="store_true", default=False, help="Enable Ptex support in imaging")
subgroup.add_argument("--no-ptex", dest="enable_ptex", action="store_false",help="Disable Ptex support in imaging (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--openvdb", dest="enable_openvdb", action="store_true", default=False, help="Enable OpenVDB support in imaging")
subgroup.add_argument("--no-openvdb", dest="enable_openvdb", action="store_false",help="Disable OpenVDB support in imaging (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--usdview", dest="build_usdview",action="store_true", default=True,help="Build usdview (default)")
subgroup.add_argument("--no-usdview", dest="build_usdview",action="store_false", help="Do not build usdview")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--zlib", dest="build_zlib",action="store_true", default=True,help="Install zlib on behalf of dependencies (default)")
subgroup.add_argument("--no-zlib", dest="build_zlib",action="store_false",help="Do not install zlib for dependencies")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--vulkan", dest="enable_vulkan", action="store_true",default=False, help="Enable Vulkan support")
subgroup.add_argument("--no-vulkan", dest="enable_vulkan", action="store_false",help="Disable Vulkan support (default)")group = parser.add_argument_group(title="Imaging Plugin Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--embree", dest="build_embree", action="store_true",default=False,help="Build Embree sample imaging plugin")
subgroup.add_argument("--no-embree", dest="build_embree", action="store_false",help="Do not build Embree sample imaging plugin (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--prman", dest="build_prman", action="store_true",default=False,help="Build Pixar's RenderMan imaging plugin")
subgroup.add_argument("--no-prman", dest="build_prman", action="store_false",help="Do not build Pixar's RenderMan imaging plugin (default)")
group.add_argument("--prman-location", type=str,help="Directory where Pixar's RenderMan is installed.")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--openimageio", dest="build_oiio", action="store_true", default=False,help="Build OpenImageIO plugin for USD")
subgroup.add_argument("--no-openimageio", dest="build_oiio", action="store_false",help="Do not build OpenImageIO plugin for USD (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--opencolorio", dest="build_ocio", action="store_true", default=False,help="Build OpenColorIO plugin for USD")
subgroup.add_argument("--no-opencolorio", dest="build_ocio", action="store_false",help="Do not build OpenColorIO plugin for USD (default)")group = parser.add_argument_group(title="Alembic Plugin Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--alembic", dest="build_alembic", action="store_true", default=False,help="Build Alembic plugin for USD")
subgroup.add_argument("--no-alembic", dest="build_alembic", action="store_false",help="Do not build Alembic plugin for USD (default)")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--hdf5", dest="enable_hdf5", action="store_true", default=False,help="Enable HDF5 support in the Alembic plugin")
subgroup.add_argument("--no-hdf5", dest="enable_hdf5", action="store_false",help="Disable HDF5 support in the Alembic plugin (default)")group = parser.add_argument_group(title="Draco Plugin Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--draco", dest="build_draco", action="store_true", default=False,help="Build Draco plugin for USD")
subgroup.add_argument("--no-draco", dest="build_draco", action="store_false",help="Do not build Draco plugin for USD (default)")
group.add_argument("--draco-location", type=str,help="Directory where Draco is installed.")group = parser.add_argument_group(title="MaterialX Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--materialx", dest="build_materialx", action="store_true", default=True,help="Enable MaterialX support (default)")
subgroup.add_argument("--no-materialx", dest="build_materialx", action="store_false",help="Disable MaterialX support")group = parser.add_argument_group(title="TBB Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--onetbb", dest="build_onetbb", action="store_true",default=False,help="Build using oneTBB instead of TBB")
subgroup.add_argument("--no-onetbb", dest="build_onetbb", action="store_false",help="Build using TBB (default)")group = parser.add_argument_group(title="Spline Test Options")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--mayapy-tests",dest="build_mayapy_tests", action="store_true",default=False,help="Build mayapy spline tests")
subgroup.add_argument("--no-mayapy-tests",dest="build_mayapy_tests", action="store_false",help="Do not build mayapy spline tests (default)")
group.add_argument("--mayapy-location", type=str,help="Directory where mayapy is installed")
subgroup = group.add_mutually_exclusive_group()
subgroup.add_argument("--animx-tests",dest="build_animx_tests", action="store_true",default=False,help="Build AnimX spline tests")
subgroup.add_argument("--no-animx-tests",dest="build_animx_tests", action="store_false",help="Do not build AnimX spline tests (default)")args = parser.parse_args()class InstallContext:def __init__(self, args):# Assume the USD source directory is in the parent directoryself.usdSrcDir = os.path.normpath(os.path.join(os.path.abspath(os.path.dirname(__file__)), ".."))# Directory where USD will be installedself.usdInstDir = os.path.abspath(args.install_dir)# Directory where dependencies will be installedself.instDir = (os.path.abspath(args.inst) if args.inst else self.usdInstDir)# Directory where dependencies will be downloaded and extractedself.srcDir = (os.path.abspath(args.src) if args.srcelse os.path.join(self.usdInstDir, "src"))# Directory where USD and dependencies will be builtself.buildDir = (os.path.abspath(args.build) if args.buildelse os.path.join(self.usdInstDir, "build"))# Determine which downloader to use.  The reason we don't simply# use urllib2 all the time is that some older versions of Python# don't support TLS v1.2, which is required for downloading some# dependencies.if which("curl"):self.downloader = DownloadFileWithCurlself.downloaderName = "curl"elif Windows() and which("powershell"):self.downloader = DownloadFileWithPowershellself.downloaderName = "powershell"else:self.downloader = DownloadFileWithUrllibself.downloaderName = "built-in"# CMake generator and toolsetself.cmakeGenerator = args.generatorself.cmakeToolset = args.toolsetself.cmakeBuildArgs = args.cmake_build_args# Number of jobsself.numJobs = args.jobsif self.numJobs <= 0:raise ValueError("Number of jobs must be greater than 0")# Build argumentsself.buildArgs = dict()for a in args.build_args:(depName, _, arg) = a.partition(",")if not depName or not arg:raise ValueError("Invalid argument for --build-args: {}".format(a))if depName.lower() not in AllDependenciesByName:raise ValueError("Invalid library for --build-args: {}".format(depName))self.buildArgs.setdefault(depName.lower(), []).append(arg)# Build python infoself.build_python_info = dict()if args.build_python_info:self.build_python_info['PYTHON_EXECUTABLE'] = args.build_python_info[0]self.build_python_info['PYTHON_INCLUDE_DIR'] = args.build_python_info[1]self.build_python_info['PYTHON_LIBRARY'] = args.build_python_info[2]self.build_python_info['PYTHON_VERSION'] = args.build_python_info[3]# Build typeself.buildDebug = (args.build_variant == BUILD_DEBUG)self.buildRelease = (args.build_variant == BUILD_RELEASE)self.buildRelWithDebug = (args.build_variant == BUILD_RELWITHDEBUG)self.debugPython = args.debug_pythonself.buildShared = (args.build_type == SHARED_LIBS)self.buildMonolithic = (args.build_type == MONOLITHIC_LIB)self.ignorePaths = args.ignore_paths or []# Build target and code signingif MacOS():self.buildTarget = args.build_targetapple_utils.SetTarget(self, self.buildTarget)self.macOSCodesign = \(args.macos_codesign if hasattr(args, "macos_codesign")else False)if apple_utils.IsHostArm() and args.ignore_homebrew:self.ignorePaths.append("/opt/homebrew")else:self.buildTarget = ""self.useCXX11ABI = \(args.use_cxx11_abi if hasattr(args, "use_cxx11_abi") else None)self.safetyFirst = args.safety_first# Dependencies that are forced to be builtself.forceBuildAll = args.force_allself.forceBuild = [dep.lower() for dep in args.force_build]# Some components are disabled for embedded build targetsembedded = MacOSTargetEmbedded(self)# Optional componentsself.buildTests = args.build_tests and not embeddedself.buildPython = args.build_python and not embeddedself.buildExamples = args.build_examples and not embeddedself.buildTutorials = args.build_tutorials and not embeddedself.buildTools = args.build_tools and not embeddedself.buildUsdValidation = args.build_usd_validation and not embedded# - Documentationself.buildDocs = args.build_docs or args.build_python_docsself.buildHtmlDocs = args.build_docsself.buildPythonDocs = args.build_python_docs# - Imagingself.buildImaging = (args.build_imaging == IMAGING orargs.build_imaging == USD_IMAGING)self.enablePtex = self.buildImaging and args.enable_ptexself.enableOpenVDB = (self.buildImagingand args.enable_openvdband not embedded)self.enableVulkan = (self.buildImagingand args.enable_vulkanand not embedded)# - USD Imagingself.buildUsdImaging = (args.build_imaging == USD_IMAGING)# - usdviewself.buildUsdview = (self.buildUsdImaging and self.buildPython and args.build_usdview)# - zlibself.buildZlib = args.build_zlib# - Imaging pluginsself.buildEmbree = self.buildImaging and args.build_embreeself.buildPrman = self.buildImaging and args.build_prmanself.prmanLocation = (os.path.abspath(args.prman_location)if args.prman_location else None)                               self.buildOIIO = ((args.build_oiio or (self.buildUsdImagingand self.buildTests))and not embedded)self.buildOCIO = args.build_ocio and not embedded# - Alembic Pluginself.buildAlembic = args.build_alembicself.enableHDF5 = self.buildAlembic and args.enable_hdf5# - Draco Pluginself.buildDraco = args.build_dracoself.dracoLocation = (os.path.abspath(args.draco_location)if args.draco_location else None)# - MaterialXself.buildMaterialX = args.build_materialx# - TBBself.buildOneTBB = args.build_onetbb# - Spline Testsself.buildMayapyTests = args.build_mayapy_testsself.mayapyLocation = args.mayapy_locationself.buildAnimXTests = args.build_animx_testsdef GetBuildArguments(self, dep):return self.buildArgs.get(dep.name.lower(), [])def ForceBuildDependency(self, dep):# Never force building a Python dependency, since users are required# to build these dependencies themselves.if type(dep) is PythonDependency:return Falsereturn self.forceBuildAll or dep.name.lower() in self.forceBuildtry:context = InstallContext(args)
except Exception as e:PrintError(str(e))sys.exit(1)verbosity = args.verbosity# Augment PATH on Windows so that 3rd-party dependencies can find libraries
# they depend on. In particular, this is needed for building IlmBase/OpenEXR.
extraPaths = []
extraPythonPaths = []
if Windows():extraPaths.append(os.path.join(context.instDir, "lib"))extraPaths.append(os.path.join(context.instDir, "bin"))if extraPaths:paths = os.environ.get('PATH', '').split(os.pathsep) + extraPathsos.environ['PATH'] = os.pathsep.join(paths)if extraPythonPaths:paths = os.environ.get('PYTHONPATH', '').split(os.pathsep) + extraPythonPathsos.environ['PYTHONPATH'] = os.pathsep.join(paths)# Determine list of dependencies that are required based on options
# user has selected.
if context.buildOneTBB:TBB = ONETBBrequiredDependencies = [TBB]if context.buildAlembic:if context.enableHDF5:requiredDependencies += [ZLIB, HDF5]requiredDependencies += [OPENEXR, ALEMBIC]if context.buildDraco:requiredDependencies += [DRACO]if context.buildMaterialX:requiredDependencies += [MATERIALX]if context.buildImaging:if context.enablePtex:requiredDependencies += [ZLIB, PTEX]requiredDependencies += [OPENSUBDIV]if context.enableOpenVDB:requiredDependencies += [ZLIB, TBB, BLOSC, BOOST, OPENEXR, OPENVDB]if context.buildOIIO:requiredDependencies += [ZLIB, BOOST, JPEG, TIFF, PNG, OPENEXR, OPENIMAGEIO]if context.buildOCIO:requiredDependencies += [ZLIB, OPENCOLORIO]if context.buildEmbree:requiredDependencies += [TBB, EMBREE]if context.buildUsdview:requiredDependencies += [PYOPENGL, PYSIDE]if context.buildAnimXTests:requiredDependencies += [ANIMX]# Linux and MacOS provide zlib. Skipping it here avoids issues where a host 
# application loads a different version of zlib than the one we build against.
# Building zlib is the default when a dependency requires it, although OpenUSD
# itself does not require it. The --no-zlib flag can be passed to the build
# script to allow the dependency to find zlib in the build environment.
if (Linux() or MacOS() or not context.buildZlib) and ZLIB in requiredDependencies:requiredDependencies = [r for r in requiredDependencies if r != ZLIB]# Error out if user is building monolithic library on windows with draco plugin
# enabled. This currently results in missing symbols.
if context.buildDraco and context.buildMonolithic and Windows():PrintError("Draco plugin can not be enabled for monolithic build on Windows")sys.exit(1)# The versions of Embree we currently support do not support oneTBB.
if context.buildOneTBB and context.buildEmbree:PrintError("Embree support cannot be enabled when building against oneTBB")sys.exit(1)# Windows ARM64 requires oneTBB. Since oneTBB is a non-standard option for the
# currently aligned version of the VFX Reference Platform, we error out and 
# require the user to explicitly specify --onetbb instead of silently switching
# to oneTBB for them.
if Windows() and GetWindowsHostArch() == "ARM64" and not context.buildOneTBB:PrintError("Windows ARM64 builds require oneTBB. Enable via the --onetbb argument")sys.exit(1)# Error out if user enables Vulkan support but env var VULKAN_SDK is not set.
if context.enableVulkan and not 'VULKAN_SDK' in os.environ:PrintError("Vulkan support cannot be enabled when VULKAN_SDK environment ""variable is not set")sys.exit(1)# Error out if user explicitly enabled components which aren't
# supported for embedded build targets.
if MacOSTargetEmbedded(context):if "--tests" in sys.argv:PrintError("Cannot build tests for embedded build targets")sys.exit(1)if "--python" in sys.argv:PrintError("Cannot build python components for embedded build targets")sys.exit(1)if "--examples" in sys.argv:PrintError("Cannot build examples for embedded build targets")sys.exit(1)if "--tutorials" in sys.argv:PrintError("Cannot build tutorials for embedded build targets")sys.exit(1)if "--tools" in sys.argv:PrintError("Cannot build tools for embedded build targets")sys.exit(1)if "--openimageio" in sys.argv:PrintError("Cannot build openimageio for embedded build targets")sys.exit(1)if "--opencolorio" in sys.argv:PrintError("Cannot build opencolorio for embedded build targets")sys.exit(1)if "--openvdb" in sys.argv:PrintError("Cannot build openvdb for embedded build targets")sys.exit(1)if "--vulkan" in sys.argv:PrintError("Cannot build vulkan for embedded build targets")sys.exit(1)# Error out if user explicitly specified building usdview without required
# components. Otherwise, usdview will be silently disabled. This lets users
# specify "--no-python" without explicitly having to specify "--no-usdview",
# for instance.
if "--usdview" in sys.argv:if not context.buildUsdImaging:PrintError("Cannot build usdview when usdImaging is disabled.")sys.exit(1)if not context.buildPython:PrintError("Cannot build usdview when Python support is disabled.")sys.exit(1)dependenciesToBuild = []
for dep in requiredDependencies:if context.ForceBuildDependency(dep) or not dep.Exists(context):if dep not in dependenciesToBuild:dependenciesToBuild.append(dep)# Verify toolchain needed to build required dependencies
if (not which("g++") andnot which("clang") andnot GetXcodeDeveloperDirectory() andnot GetVisualStudioCompilerAndVersion()):PrintError("C++ compiler not found -- please install a compiler")sys.exit(1)# Error out if a 64bit version of python interpreter is not being used
isPython64Bit = (ctypes.sizeof(ctypes.c_voidp) == 8)
if not isPython64Bit:PrintError("64bit python not found -- please install it and adjust your""PATH")sys.exit(1)if which("cmake"):# Check cmake minimum version requirementsif MacOS() and context.buildTarget == apple_utils.TARGET_VISIONOS:# visionOS support was added in CMake 3.28cmake_required_version = (3, 28)else:# OpenUSD requires CMake 3.26+cmake_required_version = (3, 26)cmake_version = GetCMakeVersion()if not cmake_version:PrintError("Failed to determine CMake version")sys.exit(1)if cmake_version < cmake_required_version:def _JoinVersion(v):return ".".join(str(n) for n in v)PrintError("CMake version {req} or later required to build USD, ""but version found was {found}".format(req=_JoinVersion(cmake_required_version),found=_JoinVersion(cmake_version)))sys.exit(1)
else:PrintError("CMake not found -- please install it and adjust your PATH")sys.exit(1)if context.buildDocs:if not which("doxygen"):PrintError("doxygen not found -- please install it and adjust your PATH")sys.exit(1)if context.buildHtmlDocs:if not which("dot"):PrintError("dot not found -- please install graphviz and adjust your ""PATH")sys.exit(1)# Require having built both Python support and Doxygen docs before we can 
# build Python docs
if context.buildPythonDocs:if not context.buildDocs:PrintError("Cannot build Python docs when doxygen docs are disabled.")sys.exit(1)if not context.buildPython:PrintError("Cannot build Python docs when Python support is disabled.")sys.exit(1)        if PYSIDE in requiredDependencies:# Special case - we are given the PYSIDEUICBINARY as cmake arg.usdBuildArgs = context.GetBuildArguments(USD)given_pysideUic = 'PYSIDEUICBINARY' in " ".join(usdBuildArgs)# The USD build will skip building usdview if pyside6-uic or pyside2-uic is# not found, so check for it here to avoid confusing users. This list of # PySide executable names comes from cmake/modules/FindPySide.cmakepyside6Uic = ["pyside6-uic"]found_pyside6Uic = any([which(p) for p in pyside6Uic])pyside2Uic = ["pyside2-uic"]found_pyside2Uic = any([which(p) for p in pyside2Uic])if not given_pysideUic and not found_pyside2Uic and not found_pyside6Uic:PrintError("PySide's user interface compiler was not found -- please"" install PySide2 or PySide6 and adjust your PATH. (Note"" that this program may be named {0} depending on your"" platform)".format(" or ".join(set(pyside2Uic+pyside6Uic))))sys.exit(1)if context.buildMayapyTests:if not context.buildPython:PrintError("--mayapy-tests requires --python")sys.exit(1)if not context.buildTests:PrintError("--mayapy-tests requires --tests")sys.exit(1)if not context.mayapyLocation:PrintError("--mayapy-tests requires --mayapy-location")sys.exit(1)if context.buildAnimXTests:if not context.buildTests:PrintError("--animx-tests requires --tests")sys.exit(1)# Summarize
summaryMsg = """
Building with settings:USD source directory          {usdSrcDir}USD install directory         {usdInstDir}3rd-party source directory    {srcDir}3rd-party install directory   {instDir}Build directory               {buildDir}CMake generator               {cmakeGenerator}CMake toolset                 {cmakeToolset}Downloader                    {downloader}Building                      {buildType}
""" if context.useCXX11ABI is not None:summaryMsg += """\Use C++11 ABI               {useCXX11ABI}
"""summaryMsg += """\Variant                     {buildVariant}Target                      {buildTarget}UsdValidation               {buildUsdValidation}Imaging                     {buildImaging}Ptex support:             {enablePtex}OpenVDB support:          {enableOpenVDB}OpenImageIO support:      {buildOIIO} OpenColorIO support:      {buildOCIO} PRMan support:            {buildPrman}Vulkan support:           {enableVulkan}UsdImaging                  {buildUsdImaging}usdview:                  {buildUsdview}MaterialX support           {buildMaterialX}Python support              {buildPython}Python Debug:             {debugPython}Python docs:              {buildPythonDocs}Documentation               {buildHtmlDocs}Tests                       {buildTests}Mayapy Tests:             {buildMayapyTests}AnimX Tests:              {buildAnimXTests}Examples                    {buildExamples}Tutorials                   {buildTutorials}Tools                       {buildTools}Alembic Plugin              {buildAlembic}HDF5 support:             {enableHDF5}Draco Plugin                {buildDraco}Dependencies                  {dependencies}"""if context.buildArgs:summaryMsg += """Build arguments               {buildArgs}"""def FormatBuildArguments(buildArgs):s = ""for depName in sorted(buildArgs.keys()):args = buildArgs[depName]s += """{name}: {args}""".format(name=AllDependenciesByName[depName].name,args=" ".join(args))return s.lstrip()summaryMsg = summaryMsg.format(usdSrcDir=context.usdSrcDir,usdInstDir=context.usdInstDir,srcDir=context.srcDir,buildDir=context.buildDir,instDir=context.instDir,cmakeGenerator=("Default" if not context.cmakeGeneratorelse context.cmakeGenerator),cmakeToolset=("Default" if not context.cmakeToolsetelse context.cmakeToolset),downloader=(context.downloaderName),dependencies=("None" if not dependenciesToBuild else ", ".join([d.name for d in dependenciesToBuild])),buildArgs=FormatBuildArguments(context.buildArgs),useCXX11ABI=("On" if context.useCXX11ABI else "Off"),buildType=("Shared libraries" if context.buildSharedelse "Monolithic shared library" if context.buildMonolithicelse ""),buildVariant=("Release" if context.buildReleaseelse "Debug" if context.buildDebugelse "Release w/ Debug Info" if context.buildRelWithDebugelse ""),buildTarget=(apple_utils.GetTargetName(context) if context.buildTargetelse ""),buildImaging=("On" if context.buildImaging else "Off"),enablePtex=("On" if context.enablePtex else "Off"),enableOpenVDB=("On" if context.enableOpenVDB else "Off"),buildOIIO=("On" if context.buildOIIO else "Off"),buildOCIO=("On" if context.buildOCIO else "Off"),buildPrman=("On" if context.buildPrman else "Off"),buildUsdImaging=("On" if context.buildUsdImaging else "Off"),buildUsdview=("On" if context.buildUsdview else "Off"),buildPython=("On" if context.buildPython else "Off"),debugPython=("On" if context.debugPython else "Off"),buildPythonDocs=("On" if context.buildPythonDocs else "Off"),buildHtmlDocs=("On" if context.buildHtmlDocs else "Off"),buildTests=("On" if context.buildTests else "Off"),buildExamples=("On" if context.buildExamples else "Off"),buildTutorials=("On" if context.buildTutorials else "Off"),enableVulkan=("On" if context.enableVulkan else "Off"),buildTools=("On" if context.buildTools else "Off"),buildUsdValidation=("On" if context.buildUsdValidation else "Off"),buildAlembic=("On" if context.buildAlembic else "Off"),buildDraco=("On" if context.buildDraco else "Off"),buildMaterialX=("On" if context.buildMaterialX else "Off"),buildMayapyTests=("On" if context.buildMayapyTests else "Off"),buildAnimXTests=("On" if context.buildAnimXTests else "Off"),enableHDF5=("On" if context.enableHDF5 else "Off"))Print(summaryMsg)if args.dry_run:sys.exit(0)# Scan for any dependencies that the user is required to install themselves
# and print those instructions first.
pythonDependencies = \[dep for dep in dependenciesToBuild if type(dep) is PythonDependency]
if pythonDependencies:for dep in pythonDependencies:Print(dep.getInstructions())sys.exit(1)# Ensure directory structure is created and is writable.
for dir in [context.usdInstDir, context.instDir, context.srcDir, context.buildDir]:try:if os.path.isdir(dir):testFile = os.path.join(dir, "canwrite")open(testFile, "w").close()os.remove(testFile)else:os.makedirs(dir)except Exception as e:PrintError("Could not write to directory {dir}. Change permissions ""or choose a different location to install to.".format(dir=dir))sys.exit(1)try:# Download and install 3rd-party dependencies, followed by USD.for dep in dependenciesToBuild + [USD]:PrintStatus("Installing {dep}...".format(dep=dep.name))dep.installer(context, buildArgs=context.GetBuildArguments(dep),force=context.ForceBuildDependency(dep))
except Exception as e:PrintError(str(e))sys.exit(1)# Done. Print out a final status message.
requiredInPythonPath = set([os.path.join(context.usdInstDir, "lib", "python")
])
requiredInPythonPath.update(extraPythonPaths)requiredInPath = set([os.path.join(context.usdInstDir, "bin")
])
requiredInPath.update(extraPaths)if Windows():requiredInPath.update([os.path.join(context.usdInstDir, "lib"),os.path.join(context.instDir, "bin"),os.path.join(context.instDir, "lib")])if MacOS():if context.macOSCodesign:apple_utils.Codesign(context.usdInstDir, verbosity > 1)additionalInstructions = any([context.buildPython, context.buildTools, context.buildPrman])
if additionalInstructions:Print("\nSuccess! To use USD, please ensure that you have:")
else:Print("\nSuccess! USD libraries were built.")if context.buildPython:Print("""The following in your PYTHONPATH environment variable:{requiredInPythonPath}""".format(requiredInPythonPath="\n    ".join(sorted(requiredInPythonPath))))if context.buildPython or context.buildTools:Print("""The following in your PATH environment variable:{requiredInPath}""".format(requiredInPath="\n    ".join(sorted(requiredInPath))))if context.buildPrman:Print("See documentation at http://openusd.org/docs/RenderMan-USD-Imaging-Plugin.html ""for setting up the RenderMan plugin.\n")

3.在pycharm运行脚本如下图:
请添加图片描述
4.格式: python.exe环境路径 要运行的脚本 参数名=给入的参数值

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/84359.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/84359.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/84359.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习资料搜集-ARMv8 cache 操作

【ARM64】【cache/MMU】学习总结_arm64 mmu-CSDN博客 [mmu/cache]-ARMV8的cache的维护指令介绍_data cache set allocation-CSDN博客 https://download.csdn.net/blog/column/12036969/139483584 验证码_哔哩哔哩 【ARM Cache 与 MMU 系列文章 2 -- Cache Coherence及内存顺…

Flutter快速上手,入门教程

目录 一、参考文档 二、准备工作 下载Flutter SDK&#xff1a; 配置环境 解决环境报错 zsh:command not found:flutter 执行【flutter doctor】测试效果 安装Xcode IOS环境 需要安装brew&#xff0c;通过brew安装CocoaPods. 复制命令行&#xff0c;打开终端 分别执行…

八股文——JVM

1. JVM组成 1.1 JVM由哪些部分组成&#xff1f;运行流程&#xff1f; Java Virtual Machine&#xff1a;Java 虚拟机&#xff0c;Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09;好处&#xff1a;一次编写&#xff0c;到处运行&#xff1b;自动内存管理…

在Pnetlab6上绕过TPM、安全启动和 RAM 检查安装windows 11笔记

笔者本次安装的windows11的镜像为: zh-cn_windows_11_enterprise_ltsc_2024_x64_dvd_cff9cd2d.iso 1、创建镜像目录并上传iso文件 mkdir /opt/unetlab/addons/qemu/win-win11x64-2024-LTSC //目录名称务必按照官方文档格式,否则无法识别 目录创建完成后,将.iso格式镜像上…

PCL点云库入门(第18讲)——PCL库点云特征之3DSC特征描述3D shape context descriptor

一、3DSC&#xff08;3D Shape Context&#xff09;特征算法原理 1. 背景 3DSC 是一种描述三维点云局部形状的特征描述子&#xff0c;受二维 Shape Context 的启发。它用于捕捉点云某一点局部的几何分布信息&#xff0c;对点云配准、识别等任务非常有效。 2. 基本思想 3DSC…

SpringBoot+Mysql校园跑腿服务平台系统源码

&#x1f497;博主介绍&#x1f497;&#xff1a;✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示&#xff1a;文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

分库分表的取舍

文章目录 大数据量下采用**水平分表**的缺点**1. 跨表查询复杂性与性能下降****2. 数据分布不均衡****3. 分布式事务与一致性问题****4. 扩展性受限****5. 查询条件限制与索引管理复杂****6. 数据迁移与维护成本高****7. 业务逻辑复杂度增加****总结** shardingJdbc分片策略**1…

Vue3解决“找不到模块@/components/xxx.vue或其相应的类型声明ts文件(2307)”

问题 1&#xff1a;如果没有这个env.d.ts文件&#xff0c;就新建 declare module "*.vue" {import { DefineComponent } from "vue";const component: DefineComponent<{}, {}, any>;export default component; }2&#xff1a;如果有tsconfig.json文…

计算机视觉与深度学习 | 基于MATLAB的图像特征提取与匹配算法总结

基于MATLAB的图像特征提取与匹配算法全面指南 图像特征提取与匹配 基于MATLAB的图像特征提取与匹配算法全面指南一、图像特征提取基础特征类型分类二、点特征提取算法1. Harris角点检测2. SIFT (尺度不变特征变换)3. SURF (加速鲁棒特征)4. FAST角点检测5. ORB (Oriented FAST …

如何通过API接口获取淘宝商品列表?操作详解

一、准备工作 注册开发者账号 访问淘宝开放平台官网/万邦开放平台&#xff0c;完成企业开发者认证&#xff08;个人账号权限受限&#xff09;&#xff0c;使用已有淘宝账号可直接登录。创建应用并填写基本信息&#xff08;如应用名称、类型等&#xff09;&#xff0c;系统生成A…

大数据驱动企业决策智能化的路径与实践

&#x1f4dd;个人主页&#x1f339;&#xff1a;慌ZHANG-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 一、引言&#xff1a;数据驱动的企业竞争力重构 在这个瞬息万变的商业时代&#xff0c;“快者胜”的竞争逻辑愈发明显。企业如何在复杂环…

DataGridView关闭默认第一列及表头居中设置

1、关闭默认第一列 如上图所示&#xff0c;C#和VB.net中的DataGridView控件都是有一个默认的第一列&#xff08;虽然是空白&#xff09;的&#xff0c;如何关闭这个默认列呢&#xff1f; 把“RowHeadersVisible”的值设置成“false”就可以了&#xff1a; 2、表头居中显示 如上…

nodejs express 打包部署

当前文件路径 webpack.config.js const path require(path); module.exports {entry: ./app.js, // Express 入口文件target: node, // 指定 Node.js 环境output: {path: path.resolve(__dirname, dist),filename: bundle.js},mode: production };打包命令 npx webpac…

CentOS 7 修改为静态 IP 地址完整指南

在企业网络环境中,服务器通常需要配置静态 IP 地址以确保网络连接的稳定性和可管理性。以下是使用 NetworkManager 工具在 CentOS 7 系统中将动态 IP 配置修改为静态 IP 的完整指南: 一、检查当前网络配置 查看网络连接状态: 使用 nmcli connection show 命令列出所有网络连…

微信小程序动态组件加载的应用场景与实现方式

动态组件加载的应用场景与实现方式 你提供的代码展示了微信小程序中动态加载组件的方法&#xff0c;但这种方式在实际开发中需要注意使用场景和实现细节。下面我来详细说明如何应用&#xff1a; 应用场景 按需加载组件&#xff1a;在某些条件满足时才加载组件动态配置组件&a…

学习记录: 使用react-router-dom

假设有一个vite创建的react项目,先npm install react-router-dom. 在app中: import { RouterProvider, createBrowserRouter } from "react-router-dom"; import Login from "./comm/Login"; import Home from "./comm/Home"; import TotalMan…

Angular中Webpack与ngx-build-plus 浅学

Webpack 在 Angular 中的概念 Webpack 是一个模块打包工具&#xff0c;用于将多个模块和资源打包成一个或多个文件。在 Angular 项目中&#xff0c;Webpack 负责将 TypeScript、HTML、CSS 等文件打包成浏览器可以理解的 JavaScript 文件。Angular CLI 默认使用 Webpack 进行项目…

java中word快速转pdf

java中word快速转pdf 网上其他方法转pdf要不转的太慢&#xff0c;要不就是损失格式&#xff0c;故而留下此方法留作备用。 文章目录 java中word快速转pdf一、依赖二、依赖包三、代码 一、依赖 <dependency><groupId>com.aspose</groupId><artifactId>…

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…

Unity使用代码分析Roslyn Analyzers

一、创建项目&#xff08;注意这里不要选netstandard2.1会有报错&#xff09; 二、NuGet上安装Microsoft.CodeAnalysis.CSharp 三、实现[Partial]特性标注的类&#xff0c;结构体&#xff0c;record必须要partial关键字修饰 需要继承DiagnosticAnalyzer 注意一定要加特性Diagn…