You can launch the Unity Editor from the command line and pass in arguments to change how the Editor launches. You can also use the command line to execute specific methods from your project’s C# scriptsA piece of code that allows you to create your own Components, trigger game events, modify Component properties over time and respond to user input in any way you like. More info
See in Glossary at launch (see Example script for executing methods at launch).
Note: To use the information on this page, you need to know how to use your operating system’s command-line interface to launch applications and run command-line arguments.
When launching the Unity Editor, the delimiter for a command-line argument value is a single space. For example, to set the window mode to borderless, use -window-mode borderless.
To launch a Unity project via the command prompt or Terminal, enter the directory path for the Unity application, followed by -projectPath and the directory path for the target project. 
The following instructions assume that the Unity Editor is installed in the default location through the Unity Hub.
On macOS, type the following into the Terminal to launch Unity:
/Applications/Unity/Hub/Editor/<version>/Unity.app/Contents/MacOS/Unity -projectPath <project path>
On Linux, type the following into the Terminal to launch Unity:
/home/<user>/Unity/Hub/Editor/<version>/Editor/Unity -projectPath <project path>
On Windows, type the following into the Command Prompt to launch Unity:
"C:\Program Files\Unity\Hub\Editor\<version>\Editor\Unity.exe" -projectPath "<project path>"
When you launch Unity like this, it receives commands and information on startup, which can be useful for test suites, automated builds and other production tasks.
Notes:
Adjust the path in the command if you use Unity Editor installed in a different location. For more information about how to find your Editor’s location path, refer to Install and uninstall Editor versions.
When passing arguments on the Windows platform, make sure the directory path doesn’t end with a single backslash to prevent syntax errors. Use either double backslashes (\\) or no backslash. For example,
"C:\Program Files\Unity\Hub\Editor\<version>\Editor\Unity.exe" -projectPath "C:\MyUnityProjects\MyProject""C:\Program Files\Unity\Hub\Editor\<version>\Editor\Unity.exe" -createProject "C:\MyUnityProjects\MyProject\\"You can run the Unity Editor and build Unity applications with additional commands and information on startup. This page lists the command line arguments you can use to launch and configure Unity Editor and Unity Player instances.
| Command | Details: | 
|---|---|
| -createProject <pathname> | Create an empty project at the given path. | 
| -disable-assembly-updater <assembly1 assembly2> | Specify a space-separated list of assembly names as parameters for Unity to ignore on automatic updates. The space-separated list of assembly names is optional: pass the command line options without any assembly names to ignore all assemblies, as in example 1. Example 1 unity.exe -disable-assembly-updaterExample 2 unity.exe -disable-assembly-updater A1.dll subfolder/A2.dllExample 2 has two assembly names, one with a pathname. Example 2 ignores A1.dll, no matter what folder it is stored in, and ignoresA2.dllonly if it is stored undersubfolderfolder:If you list an assembly in the -disable-assembly-updatercommand line parameter (or if you don’t specify assemblies), Unity logs the following message to Editor.log:[Assembly Updater] warning: Ignoring assembly [assembly_path] as requested by command line parameter.”).Use this to avoid unnecessary API Updater overhead when you import assemblies. This argument is useful if you want to import assemblies that access a Unity API which doesn’t need updating. It’s also useful when you import assemblies which don’t access any Unity APIs (for example, if you have built some or all of your source code outside of Unity, and you want to import the resulting assemblies into your Unity project). Note: If you disable the update of any assembly that needs updating, you might get errors at compile time, run time, or both, that are hard to track. | 
| -disable-gpu-skinning | Disable Graphics Processing Unit (GPU) skinningThe process of binding bone joints to the vertices of a character’s mesh or ‘skin’. Performed with an external tool, such as Blender or Autodesk Maya. More info See in Glossary at startup. | 
| -executeMethod <ClassName.MethodName>or-executeMethod <NamespaceName.ClassName.MethodName> | Execute the static method as soon as Unity opens the project, and after the optional Asset server update is complete. You can use this for tasks such as continuous integration, performing Unit Tests, making builds or preparing data. To return an error from the command line process, either throw an exception which causes Unity to exit with return code 1, or call EditorApplication.Exit with a non-zero return code. To pass parameters, add them to the command line and retrieve them inside the function using System.Environment.GetCommandLineArgs. To use-executeMethod, you need to place the enclosing script in an Editor folder. The method you execute must be defined as static. | 
| -exportPackage <exportAssetPath1 exportAssetPath2 ExportAssetPath3 exportFileName> | Export a package, given a path (or set of given paths). In this example, exportAssetPathis a folder (relative to the Unity project root) to export from the Unity project, andexportFileNameis the package name. This option only exports whole folders at a time. You normally need to use this command with the-projectPathargument. | 
| -importPackage <pathname> | Import the given asset packageA collection of files and data from Unity projects, or elements of projects, which are compressed and stored in one file, similar to Zip files, with the .unitypackageextension. Asset packages are a handy way of sharing and re-using Unity projects and collections of assets. More infoSee in Glossary. Unity doesn’t display any import dialog. | 
| -job-worker-count <N> | Specify the maximum thread count for the Unity JobQueue Job Worker Count. You can also set this value as job-worker-count=<N>inboot.configfor the Unity Standalone Player. | 
| -logFile <pathname> | Specify where Unity writes the Editor or operating system’s standalone log file. To output to the console, specify -for the path name. On Windows, use-logfileto direct the output tostdout, which by default isn’t the console. Also refer to-upmLogFile. | 
| -noUpm | Disables the Unity Package Manager. | 
| -openfile <path> | Open the project from a path to a scene or package file. Alternatively, you can use the -projectPathargument | 
| -password <password> | Enter a password into the log-in form during the activation of the Unity Editor. | 
| -projectPath <pathname> | Open the project at the given path. If the pathname contains spaces, enclose it in quotes. | 
| -quit | Quit the Unity Editor after other commands have finished executing. This can cause error messages to be hidden (but they still appear in the Editor.logfile).If Unity is also connected to the AcceleratorThe Unity Accelerator is an external tool that provides an asset cache that keeps copies of a team’s imported assets. The goal of the Accelerator is to speed up teamwork and reduce iteration time by coordinating asset sharing so that you don’t need to reimport portions of your project. More info See in Glossary Cache Server, then the command line argument -cacheServerWaitForUploadCompletionis required to prevent Unity quitting before any pending cache uploads have completed. | 
| -releaseCodeOptimization | Enables release code optimization mode, overriding the current default code optimization mode for the session. | 
| -setDefaultPlatformTextureFormat(Android only) | Set the default texture compressionA method of storing data that reduces the amount of storage space it requires. See Texture Compression, Animation Compression, Audio Compression, Build Compression. See in Glossary to the desired format before you import a texture or build the project. This is so you don’t have to import the texture again with the format you want. The available formats are dxt, pvrtc, atc, etc, etc2, and astc. This argument is ignored when texture compression targeting is enabled. | 
| -overrideTextureCompression | Override the texture compression3D Graphics hardware requires Textures to be compressed in specialized formats which are optimized for fast Texture sampling. More info See in Glossary settings that Unity uses when it imports assets. This is particularly useful during local development, to speed up texture importing or build target switching. For details, see API reference documentation on EditorUserBuildSettings.overrideTextureCompression. | 
| -silent-crashes | Prevent Unity from displaying the dialog that appears when a Standalone Player crashes. This argument is useful when you want to run the Player in automated builds or tests, where you don’t want a dialog prompt to obstruct automation. | 
| -upmLogFile <pathname> | Specify the path and file name where Unity writes the log file for the UPM background application, which runs independently of the Editor. You can specify -upmLogFileand-logFilein the same command. If you include both arguments, you can specify independent paths for the two log files. | 
| -username <username> | Enter a username into the log-in form during the activation of the Unity Editor. | 
| -vcsMode <mode> | Set the version control mode. Available modes are "Visible Meta Files","Hidden Meta Files",Perforce, andPlasticSCM. You can use additional flags to fill out the configuration fields for the given version control mode. These flags are based on the Provider.GetActiveConfigFields method. For example, you can use the-vcPerforceUsername,-vcPerforcePassword,-vcPerforceWorkspaceand-vcPerforceServerto set the Perforce username, workspace and server fields.Note: <mode>arguments that contain spaces must be wrapped in double quotes (“).|
|-vcsModeSession <mode>|Set the version control mode for this session. Available modes are"Visible Meta Files","Hidden Meta Files",Perforce, andPlasticSCM. You can use additional flags to fill out the configuration fields for the given version control mode. These flags are based on the Provider.GetActiveConfigFields method. For example, you can use the-vcPerforceUsername,-vcPerforcePassword,-vcPerforceWorkspaceand-vcPerforceServerto set the Perforce username, workspace and server fields.Note: <mode>arguments that contain spaces must be wrapped in double quotes (”). | 
| -version | Print the version number of the Unity Editor in the command line, without launching the Editor. | 
| -timestamps | Prefixes every Editor.log message with the current timestamp and thread ID. | 
Use the following arguments to configure Unity’s batch mode. Batch mode enables Unity to run predefined tasks without user input, which makes batch mode useful for automated tasks like testing. For more information, see Batch mode and built-in coroutine compatibility.
| Command | Details: | 
|---|---|
| -accept-apiupdate | Use this command line option to specify that APIUpdater should run when Unity is launched in batch mode. Example: unity.exe -accept-apiupdate -batchmode [other params]The APIUpdater doesn’t run if you omit this command line argument when you launch Unity in batch mode. This might lead to compiler errors. | 
| -batchmode | Run Unity in batch mode. In batch mode, Unity runs command line arguments without the need for human interaction. It also suppresses pop-up windows that require human interaction (such as the Save Scene window). You should always run Unity in batch mode when using command line arguments, because it allows automation to run without interruption. When an exception occurs during execution of the script code, the Asset server updates fail, or other operations fail, Unity immediately exits with return code 1. In batch mode, Unity sends a minimal version of its log output to the console. However, the Log Files still contain the full log information. You can’t open a project in batch mode while the Editor has the same project open; only a single instance of Unity can run at a time. To check whether the Editor or Standalone Player is running in batch mode, use the Application.isBatchMode operator. If the project has not yet been imported when using -batchmode, the target platform is the default one. To force a different platform, use the-buildTargetoption. | 
| ‑ignorecompilererrors | When you use this argument, Unity continues to start your application even if there are compilation errors. | 
| -nographics | When you run this in batch mode, Unity doesn’t initialize the graphics device. You can then run automated workflows on machines that don’t have a GPU. Automated workflows only work when you have a window in focus, otherwise you can’t send simulated input commands. -nographicsdoes not allow you to bake GI, because Enlighten Realtime Global Illumination requires a GPU for Meta Pass rendering (See the Meta Pass section of the Lightmapping and Shaders page for more information).Note: Output logs are turned off in this mode. To enable the creation of output logs, specify a file location using the command -logFile. | 
Use the following arguments to build players for various platforms from the command line. For more information about building players with command line arguments, refer to Unity Standalone Player command line arguments.
| Command | Details: | 
|---|---|
| -activeBuildProfile <pathname> | Set the build profile saved at the given path as an active build profile (for example, -activeBuildProfile "Assets/Settings/Build Profiles/WindowsDemo.asset").Note: -activeBuildProfile <pathname>applies custom scripting defines found in the Build data section of the active build profile before compilation. These scripting defines are additive and don’t override other scripting defines in your project. | 
| -build <pathName> | Build a Player from activeBuildProfile <pathname>to the specified target path. For some platforms, the path must end with a file extension specific to the target platform. For example,-build path/to/your/build.exe. For information on which platforms require the extensions, refer to Build path requirements for target platforms. | 
| -buildLinux64Player <pathname> | Build a 64-bit standalone Linux player (for example, -buildLinux64Player path/to/your/build). | 
| -buildLinuxHeadlessSimulation <pathname> | Build a 64-bit Linux headless simulation player (for example, -buildLinuxHeadlessSimulation path/to/your/build). | 
| -buildOSXUniversalPlayer <pathname> | Build a 64-bit standalone macOS player (for example, -buildOSXUniversalPlayer path/to/your/build.app). | 
| -buildTarget <name> | Select an active build target to launch the Editor in. The options available to you depend on which build targets you have enabled in the Editor. These options correspond to the options available to you via the API enumeration BuildTarget. Possible options include:• win64• win• osxuniversal• linux64• android• ios• webgl• tvos• windowsstoreapps• cloudrendering• visionosIf you are a developer with access to Closed platforms, you might have other -buildTargetoptions available. For details, see the documentation for your target platform. | 
| -standaloneBuildSubtarget <name> | Select an active build subtarget for the Standalone platforms before loading a project. Possible options are: • Player • Server | 
| -buildWindowsPlayer <pathname> | Build a 32-bit standalone Windows player (for example, -buildWindowsPlayer path/to/your/build.exe). | 
| -buildWindows64Player <pathname> | Build a 64-bit standalone Windows player (for example, -buildWindows64Player path/to/your/build.exe). | 
Use the following arguments to configure Unity’s use of the Unity Accelerator Cache Server. These arguments override any corresponding configuration stored in the Editor Preferences.
| Command | Details: | 
|---|---|
| -EnableCacheServer | Enable the Accelerator Cache Server. You must also use -cacheServerEndpoint <host:port>to specify the address of the cache server. | 
| -cacheServerEndpoint <host:port> | Specifies the endpoint address of the Accelerator Cache Server. Example: -cacheServerEndpoint 127.0.0.1:10080 | 
| -cacheServerNamespacePrefix <prefix> | Set the namespace prefix for the Accelerator Cache Server. Use this argument with a namespace name to partition data on the cache server, for example to isolate cache data for different projects or Unity versions. Example: -cacheServerNamespacePrefix MyProject_Unity23LTSA prefix that contains spaces must be wrapped in double quotes ( ").The supplied name is used as the prefix for up to 3 namespaces in the cache which separate data by type - metadata, artifact data and shader cache data. | 
| -cacheServerEnableDownload <true|false> | Enable or disable downloading from the Accelerator Cache Server. Example: -cacheServerEnableDownload true | 
| -cacheServerEnableUpload <true|false> | Enable or disable uploading to the Accelerator Cache Server. Example: -cacheServerEnableUpload true | 
| -cacheServerWaitForConnection <ms> | Specify the time in milliseconds that Unity will wait for a connection to the Accelerator Cache Server while loading a project, before starting the initial project refresh. Example: -cacheServerWaitForConnection 5000 | 
| -cacheServerWaitForUploadCompletion | Prevent Unity from closing until any pending Accelerator Cache Server uploads are complete. This is recommended when the Accelerator is used in combination with the command line argument -quit, which closes the Unity Editor after other scripted commands have finished executing. | 
| -cacheServerDownloadBatchSize <batchSize> | Set the number of artifacts in individual Accelerator Cache Server download batches. Download batches are an optimization used to reduce the number of download operations by grouping individual downloads into larger batches. Example: -cacheServerDownloadBatchSize 256Default value is 128. | 
| -cacheServerUploadExistingImports | Upload any existing imports that haven’t been previously uploaded when Unity begins to upload new imports to the Accelerator Cache Server. Imports that have been previously uploaded are not re-uploaded. | 
| -cacheServerUploadAllRevisions | Upload any existing imports including all previous revisions known to the Asset Database that have not previously been uploaded when Unity begins to upload new imports to the Accelerator Cache Server. Import revisions that have been previously uploaded, are not re-uploaded. | 
| -cacheServerUploadExistingShaderCache | Upload any existing shaderA program that runs on the GPU. More info See in Glossary cache imports that have not previously been uploaded when Unity begins to upload new imports to the Accelerator Cache Server. Shader imports that have been previously uploaded, are not re-uploaded. | 
| Command | Details: | 
|---|---|
| -disableManagedDebugger | Disables the debugger listen socket. | 
| -diag-debug-shader-compiler | Unity launches only one instance of the Shader Compiler, and forces its timeout to be one hour. Useful for debugging Shader Compiler issues. | 
| -debugCodeOptimization | Enables debug code optimization mode, overriding the current default code optimization mode for the session. | 
| -enableCodeCoverage | Enables code coverage and allows access to the Coverage API. | 
| -force-d3d12-debug | Enables the DX12 validation layer. This is useful for working on XRAn umbrella term encompassing Virtual Reality (VR), Augmented Reality (AR) and Mixed Reality (MR) applications. Devices supporting these forms of interactive applications can be referred to as XR devices. More info See in Glossary plugins or native plugins. | 
| -force-d3d12-debug-gbv | Enables the DX12 GPU-based validation. This is useful for working on XR plugins or native plugins. | 
| -force-vulkan-layers | Enables the Vulkan validation layer. This is useful for working on XR plugins or native plugins. | 
| -stackTraceLogType | Allow detailed debugging. All settings allow None, Script Only and Full to be selected (for example, -stackTraceLogType Full). | 
| -log-memory-performance-stats | Adds detailed memory and performance reports to the main Unity Editor log file when closing the editor. | 
Use the following arguments to force the Unity Editor to use a specific graphics API.
| Command | Details: | 
|---|---|
| -force-d3d11(Windows only) | Make the Editor use Direct3D 11 for rendering. Normally the graphics API depends on Player SettingsSettings that let you set various player-specific options for the final game built by Unity. More info See in Glossary (typically defaults to D3D11). | 
| -force-d3d12(Windows only) | Make the Editor use Direct3D 12 for rendering. Normally the graphics API depends on Player Settings. | 
| -force-opengl | Make the Editor use the legacy OpenGL back end. | 
| -force-glcore | Make the Editor use OpenGL 3/4 core profile for rendering. The Editor tries to use the best OpenGL version available and all OpenGL extensions exposed by the OpenGL drivers. If the platform isn’t supported, the editor uses Direct3D. | 
| -force-glcoreXY | Similar to -force-glcore, but requests a specific OpenGL context version. Accepted values for XY: 32, 33, 40, 41, 42, 43, 44, or 45. If the platform doesn’t support a specific version of OpenGL, Unity will fallback to a supported version. | 
| -force-gles(Windows only) | Make the Editor use OpenGL for Embedded Systems for rendering. The Editor tries to use the best OpenGL ES version available, and all OpenGL ES extensions exposed by the OpenGL drivers. | 
| -force-glesXY(Windows only) | Similar to -force-gles, but requests a specific OpenGL ES context version. Accepted values for XY: 30, 31, 31aep, or 32. If the platform doesn’t support a specific version of OpenGL ES, Unity will fallback to a supported version. If the platform doesn’t support OpenGL ES, Unity will fallback to another graphics API. | 
| -force-vulkan | Make the Editor use Vulkan for rendering. Normally the graphics API depends on Player Settings. | 
| -force-clamped | Use this with -force-glcoreXYto prevent Unity from checking for additional OpenGL extensions, allowing it to run between platforms with the same code paths. This approach helps to determine if an issue is platform-specific. For example, a driver bug. | 
Use the following arguments to process a Unity license or run the Unity Editor with different license options.
| Command | Details: | 
|---|---|
| -createManualActivationFile | Step one of a three-step process to manually activate a Unity license. For more information, refer to Generate a license activation file (.alf) from the command line. | 
| -manualLicenseFile <yourulffile> | Step three of a three-step process to manually activate a Unity license. For more information, refer to Generate a license activation file (.alf) from the command line. | 
| -returnlicense | Return the currently active serial-based or named user license. Do not use -returnlicenseto return a floating license. For more information, refer to Returning your license. For more information about licensing models, refer to Licensing overview. | 
| -serial <serial-key> | Activate your paid Unity license. Include the <serial-key>value to activate a serial-based license, or to activate a named user license and its serial key simultaneously. Exclude the<serial-key>value to activate a named user license without activating its serial key. For more information, refer to Activate a license from the command line. For more information about licensing models, refer to Licensing overview.Note: When you use the -serialargument, you must also use the-batchmodeargument. It’s also good practice to specify the-quitargument. | 
Use the following arguments to configure Unity’s use of the Metal graphics API for Apple devices.
| Command | Details: | 
|---|---|
| -force-device-index | When using Metal, make the Editor use a particular GPU device by passing it the index of that GPU (macOS only). | 
| -force-low-power-device(macOS only) | If you use Metal, make the Editor use a low power device. | 
| -force-metal | Make the Editor use Metal as the default graphics API (macOS only). | 
| -enable-metal-capture | Enable the ability to take Metal captures from inside the Editor. | 
Use the following arguments to configure Unity’s use of the ProfilerA window that helps you to optimize your game. It shows how much time is spent in the various areas of your game. For example, it can report the percentage of time spent rendering, animating, or in your game logic. More info
See in Glossary.
| Command | Details: | 
|---|---|
| -deepprofiling | Enable Deep Profiling option for the CPU profiler. | 
| -profiler-enable | Profile the start-up of a Player or the Editor. When you use this argument with a Player, it has the same effect as building the Player with the Autoconnect Profiler option enabled in Build ProfilesA set of customizable configuration settings to use when creating a build for your target platform. More info See in Glossary. When you use this argument with the Editor, it starts collecting and displaying Profiler information in the Profiler window on start-up of the Editor. | 
| -profiler-log-file <Path/To/Log/File.raw> | This argument sets up the Unity Profiler to stream the profile data to a .raw file on startup. It works for both Players and the Editor. | 
| -profiler-capture-frame-count <NumberOfFrames> | This argument sets how many frames the Profiler should capture in a profile when streaming to a .raw file on start-up. It only works on Players. | 
| -profiler-maxusedmemory | By default, maxUsedMemoryfor the Unity Profiler is 16MB for Players and 256MB for the Editor. You can use this argument to set themaxUsedMemoryparameter to a custom size at start-up (for example,-profiler-maxusedmemory 16777216). The size is set in bytes. | 
You should only use these under special circumstances, or when directed by Unity Support.
| Command | Details: | 
|---|---|
| -enableIncompatibleAssetDowngrade | Use this when you have Assets made by a newer, incompatible version of Unity, that you want to downgrade to work with your current version of Unity. When you enable this, Unity presents you with a dialog asking for confirmation of this downgrade if you attempt to open a project that would require it. Note: This procedure is unsupported and highly risky, and should only be used as a last resort. | 
| -giCustomCacheLocation | Use this to set a custom location for the Global Illumination (GI) cache folder. Note: When you close the Editor, giCustomCacheLocationreverts to the default location for the GI cache, or to a custom location if you have previously set one. | 
You should only use these under special circumstances, or when directed by Unity Support. These arguments are used in versions of the Unity Editor that do not use the Unity Hub by default.
| Command | Details: | 
|---|---|
| -useHub | Launch the Unity Editor with Hub integration. | 
| -hubIPC | Enable communication and interaction between the Unity Editor and the Unity Hub. | 
| -hubSessionId | Specify a unique identifier for a Unity Hub session. | 
In all supported versions of the Unity Editor, these arguments are already set by default.
Additional Editor command line arguments are available when these packages are installed.
| Package | Details: | 
|---|---|
| Burst | See Burst package documentation. | 
| Test Framework | See Unity Test Framework package documentation. | 
| Code Coverage | See Code Coverage package documentation. | 
You can use the command line to execute specific methods from your project’s C# scripts at launch. The following examples demonstrate a C# script, and the command line arguments that execute methods from that script at launch.
An example C# script in the project:
using UnityEditor;
class MyEditorScript
{
     static void PerformBuild ()
     {
        BuildPlayerOptions buildPlayerOptions = new BuildPlayerOptions();
        buildPlayerOptions.scenes = new[] { "Assets/Scene1.unity", "Assets/Scene2.unity" };
        BuildPipeline.BuildPlayer(buildPlayerOptions);
     }
}
The following command executes Unity in batch mode, executes the MyEditorScript.PerformBuild method from the above script, and then quits upon completion.
Windows:
"C:\Program Files\Unity\Hub\Editor\<version>\Editor\Unity.exe" -quit -batchmode -projectPath "C:\Users\UserName\Documents\MyProject" -executeMethod
MyEditorScript.PerformBuild
macOS:
/Applications/Unity/Hub/Editor/<version>/Unity.app/Contents/MacOS/Unity -quit -batchmode -projectPath ~/UnityProjects/MyProject -executeMethod
MyEditorScript.PerformBuild
Note: In the Editor path, replace <version> with the version of Unity you want to launch, or replace the path entirely if your Unity Editor path is not the default.