当前位置: 首页 > article >正文

PyCharm中运行.py脚本程序

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环境路径 要运行的脚本 参数名=给入的参数值

相关文章:

PyCharm中运行.py脚本程序

1.最近在弄一个python脚本程序&#xff0c;记录下运行过程。 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 …...

吴恩达MCP课程(5):research_server_prompt_resource.py

代码 import arxiv import json import os from typing import List from mcp.server.fastmcp import FastMCPPAPER_DIR "papers"# Initialize FastMCP server mcp FastMCP("research")mcp.tool() def search_papers(topic: str, max_results: int 5) …...

[论文阅读] 人工智能+项目管理 | 当 PMBOK 遇见 AI:传统项目管理框架的破局之路

当PMBOK遇见AI&#xff1a;传统项目管理框架的“AI适配指南” 论文信息 arXiv:2506.02214 Is PMBOK Guide the Right Fit for AI? Re-evaluating Project Management in the Face of Artificial Intelligence Projects Alexey Burdakov, Max Jaihyun Ahn Subjects: Software …...

Gateway 搭建

1.创建 moudle 命名为 gateway 2,pom中引入依赖 网关依赖&#xff1b;注册中心依赖等 <!-- 网关依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></d…...

pytorch基本运算-导数和f-string

引言 在前序对机器学习的探究过程中&#xff0c;我们已经深刻体会到人工智能到处都有微分求导运算&#xff0c;相关文章链接包括且不限于&#xff1a; BP神经网络 逻辑回归 对于pytorch张量&#xff0c;求导运算必不可少&#xff0c;所以本次就专门来学习一下。 f-string的用…...

impala中更改公网ip为内网ip

实际有时候需求中需要将公网的impala监听ip改为内网的ip 步骤 1&#xff0c;更改配置文件中的ip 1&#xff0c;更改/etc/default/impala中的ip配置重启服务即可在hive元数据同一个节点上要启动sudo service impala-state-store restartsudo service impala-catalog restart所有…...

5.RV1126-OPENCV 图形计算面积

一.图形面积、弧长计算介绍 前面我们已经把图形轮廓的检测、画框等功能讲解了一遍。这次主要结合轮廓检测的 API 去计算图形的面积&#xff0c;这些面积可以是矩形、圆形等等。图形面积计算和弧长计算常用于车辆识别、桥梁识别等重要功能&#xff0c;常用的 API 如 contourArea…...

一键净化Excel数据:高性能Python脚本实现多核并行清理

摘要 本文分享两个基于Python的Excel数据净化脚本&#xff0c;通过多进程并行技术清除工作表内不可见字符、批注、单元格样式等冗余内容&#xff0c;利用OpenPyXL实现底层操作&#xff0c;结合tqdm进度条和进程级任务分配&#xff0c;可快速处理百万级单元格数据。适用于数据分…...

【Android基础回顾】一:Binder机制是什么?有什么用?

Android中的Binder机制是Android系统中最核心和最基础的进程间通讯机制。 1 什么是进程间通讯机制(IPC)&#xff1f; 众所周知&#xff0c;Android系统基于Linux开发&#xff0c;Linux系统里面本来就有进程间通讯机制。 1.1 Linux的IPC(Inter-Process Communication)概览 它…...

LeetCode 高频 SQL 50 题(基础版) 之 【高级查询和连接】· 上

题目&#xff1a;1731. 每位经理的下属员工数量 题解&#xff1a; select employee_id,name,reports_count,average_age from Employees t1,(select reports_to,count(*) reports_count,round(avg(age)) average_agefrom Employeeswhere reports_to is not nullgroup by repor…...

资产智慧管理安全监测中心

在数字经济高速发展的今天&#xff0c;资产管理的智能化已成为企业降本增效的核心竞争力。从智慧园区到古建筑群&#xff0c;从交通枢纽到城市电网&#xff0c;资产智慧管理安全监测中心正以物联网、人工智能、数字孪生等技术为支撑&#xff0c;构建起资产全生命周期的“智慧大…...

从零开始的云计算——番外实战,iptables防火墙项目

目录 一网络规划 二项目要求 三环境准备 1防火墙设置 2PC1设置 3PC2设置 4服务器S1设置 四环境检测 1内网链接 2外网连接 五防火墙配置及测试 1内部网络中的pc1采用SNAT访问外部互联网&#xff0c;但是无法ping到内部网关。 ​编辑​编辑 2内部网络服务器s1通过DN…...

移动网页调试的多元路径:WebDebugX 与其他调试工具的组合使用策略

在移动端网页开发中&#xff0c;仅靠一款工具很难覆盖所有调试场景。不同问题类型需要不同的调试维度——有时是网络请求&#xff0c;有时是 DOM 样式&#xff0c;有时是 JS 状态&#xff0c;有时是性能瓶颈。 本文以“多工具协作”为核心思想&#xff0c;结合多个项目经验&am…...

【基于阿里云搭建数据仓库(离线)】IDEA导出Jar包(包括第三方依赖)

目录 方法一&#xff1a; 方法二 1.双击"package”即可进行打包呈jar 2.双击后就会自动打包生成jar了&#xff0c; 生成的jar在这个目录下 3.右击&#xff0c;点击“复制路径/引用”&#xff0c;即可获得“绝对路径”、“根路径”等相关信息 前提&#xff1a; 在pop.…...

【HarmonyOS 5】鸿蒙HarmonyOS —(cordova)研发方案详解

Android、Ios 和 HarmonyOS APP研发分析 Android研发语言Java、Ios研发语言objective-c, HarmonOS研发语言ArkTs和C/C&#xff0c;写了第一句&#xff0c;就会有人反驳&#xff0c;Android和Ios也支持C/C语言&#xff0c;封装成动态库so&#xff0c;然后调用就可以了&#xff0…...

Linux程序运行日志总结

在Linux系统中,程序运行时产生的日志记录主要通过以下几种方式实现,这些日志有助于排查问题、监控系统行为或审计安全事件: 1. 系统日志(System Logs) 存放路径:通常位于 /var/log/ 目录下。常见日志文件: /var/log/syslog 或 /var/log/messages:通用系统日志(取决于发…...

【物联网-TCP/IP】

物联网-TCP/IP ■ TCP/IP■■■ 添加链接描述 ■ TCP/IP ■ ■ ■...

SAP ECC 与 SAP S/4HANA 技术架构全面对比

SAP ECC 是过去几十年众多企业核心业务系统的基石&#xff0c;涵盖财务、物流、制造等关键领域。然而&#xff0c;随着数字化转型的加速和企业需求的增长&#xff0c;其架构日益显现局限。因此&#xff0c;SAP 推出了新一代 ERP 解决方案——SAP S/4HANA。它不仅在功能上做出优…...

Halcon光度立体法

1、光度立体法&#xff0c;可用于将对象的三维形状与其二维纹理&#xff08;例如打印图像&#xff09;分离。需要用不同方向而且已知照明方向的多个光源&#xff0c;拍摄同一物体的至少三张图像。请注意&#xff0c;所有图像的相机视角必须相同。 物体的三维形状主要被计算为三…...

cocos3.X的oops框架oops-plugin-excel-to-json改进兼容多表单导出功能

在使用oops框架的过程中&#xff0c;它的导出数据并生成数据结构的插件oops-plugin-excel-to-json有些小的坑点&#xff0c;为满足我个人习惯&#xff0c;对此部分进行了一个小的修改&#xff0c;有需要的拿去用&#xff0c;记录下供大家参考&#xff1b; 一、配置&#xff1a;…...

Spring Boot + OpenAI 构建基于RAG的智能问答系统

一、技术架构设计 1.1 系统架构图 [前端]│▼ (HTTP/REST) [Spring Boot Controller]│▼ (Service Call) [问答处理服务层]├─▶ [知识库检索模块] ──▶ [向量数据库]└─▶ [OpenAI集成模块] ──▶ [OpenAI API]│▼ [结果组装与返回] 1.2 技术选型 组件技术栈版本要求…...

开源量子模拟引擎:Quantum ESPRESSO本地部署教程,第一性原理计算轻松入门!

一、介绍 Quantum ESPRESSO 是一个用于电子结构计算和纳米尺度材料建模的开源计算机代码集成套件&#xff0c;专门用于进行第一性原理&#xff08;第一性原理&#xff09;计算&#xff0c;涵盖了电子结构、晶体学和材料性能的模拟。 Quantum ESPRESSO GPU 版本支持GPU加速&am…...

算法blog合集

https://zhuanlan.zhihu.com/p/600245782 https://zhuanlan.zhihu.com/p/696212679 https://zhuanlan.zhihu.com/p/291406172 【推荐系统】DSSM双塔召回2_pair-wise训练和推理-CSDN博客 精通推荐算法1&#xff1a;为什么需要推荐系统&#xff08;系列文章&#xff0c;建议收…...

每日八股文6.3

每日八股-6.3 Mysql1.COUNT 作用于主键列和非主键列时&#xff0c;结果会有不同吗&#xff1f;2.MySQL 中的内连接&#xff08;INNER JOIN&#xff09;和外连接&#xff08;OUTER JOIN&#xff09;有什么主要的区别&#xff1f;3.能详细描述一下 MySQL 执行一条查询 SQL 语句的…...

Kubernetes (k8s)版本发布情况

Kubernetes (k8s)版本发布情况 代码放在 GitHub - kubernetes/kubernetes: Production-Grade Container Scheduling and Management https://github.com/kubernetes/kubernetes/releases 文档放在 kubernetes.io各个版本变更等: https://github.com/kubernetes/kubernet…...

QT 5.9.2+VTK8.0实现等高线绘制

项目下载链接&#xff1a;QT5.9.2VTK8.0实现等高线绘制资源-CSDN文库 示例如下&#xff1a; 主要代码如下&#xff1a; #include "vtkRenderer.h" #include "vtkRenderWindow.h" #include "vtkRenderWindowInteractor.h" #include "vtkPo…...

CppCon 2015 学习:3D Face Tracking and Reconstruction using Modern C++

1. 3D面部追踪和重建是什么&#xff1f; 3D面部追踪&#xff08;3D Face Tracking&#xff09;&#xff1a; 实时检测并追踪人脸在三维空间中的位置和姿态&#xff08;如转头、点头、表情变化等&#xff09;&#xff0c;通常基于摄像头捕获的视频帧。3D面部重建&#xff08;3D…...

Three.js进阶之音频处理与展示

引擎在对音频处理提供了丰富的接口&#xff0c;本文展示两个音频处理示例。 一、声音可视化 Three.js中的声音可视化是以视觉为核心&#xff0c;以音乐为载体&#xff0c;为音乐提供直观的视觉呈现。通过对音乐数据的分析并结合开发需求&#xff0c;能实现酷炫的视觉效果。在…...

4.2 HarmonyOS NEXT分布式AI应用实践:联邦学习、跨设备协作与个性化推荐实战

HarmonyOS NEXT分布式AI应用实践&#xff1a;联邦学习、跨设备协作与个性化推荐实战 在HarmonyOS NEXT的全场景分布式架构下&#xff0c;AI能力突破设备边界&#xff0c;通过联邦学习保护数据隐私、跨设备任务协作释放算力潜能、个性化推荐实现服务主动化。本文结合华为分布式…...

兼容老设备!EtherNet/IP转DeviceNet网关解决储能产线通讯难题

在新能源行业飞速发展的当下&#xff0c;工业自动化水平的高低直接影响着企业的生产效率与产品质量。JH-EIP-DVN疆鸿智能ETHERNET/IP和DEVICENET作为工业领域常用的通信协议&#xff0c;它们之间的转换应用在新能源生产线上发挥着关键作用。本文重点探讨ETHERNETIP从站转DEVICE…...