Application Data (bpy.app)

This module contains application values that remain unchanged during runtime.

bpy.app.autoexec_fail

Undocumented, consider contributing.

bpy.app.autoexec_fail_message

Undocumented, consider contributing.

bpy.app.autoexec_fail_quiet

Undocumented, consider contributing.

bpy.app.binary_path

The location of Blender’s executable, useful for utilities that open new instances. Read-only unless Blender is built as a Python module - in this case the value is an empty string which script authors may point to a Blender binary.

bpy.app.debug

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph_build

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph_eval

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph_pretty

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph_tag

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_depsgraph_time

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_events

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_ffmpeg

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_freestyle

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_handlers

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_io

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_python

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_simdata

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.debug_value

Short, number which can be set to non-zero values for testing purposes

bpy.app.debug_wm

Boolean, for debug info (started with --debug / --debug-* matching this attribute name)

bpy.app.driver_namespace

Dictionary for drivers namespace, editable in-place, reset on file load (read-only)

File Loading & Order of Initialization

Since drivers may be evaluated immediately after loading a blend-file it is necessary to ensure the driver name-space is initialized beforehand.

This can be done by registering text data-blocks to execute on startup, which executes the scripts before drivers are evaluated. See Text -> Register from Blender’s text editor.

Hint

You may prefer to use external files instead of Blender’s text-blocks. This can be done using a text-block which executes an external file.

This example runs driver_namespace.py located in the same directory as the text-blocks blend-file:

import os
import bpy
blend_dir = os.path.normalize(os.path.join(__file__, "..", ".."))
bpy.utils.execfile(os.path.join(blend_dir, "driver_namespace.py"))

Using __file__ ensures the text resolves to the expected path even when library-linked from another file.

Other methods of populating the drivers name-space can be made to work but tend to be error prone:

Using The --python command line argument to populate name-space often fails to achieve the desired goal because the initial evaluation will lookup a function that doesn’t exist yet, marking the driver as invalid - preventing further evaluation.

Populating the driver name-space before the blend-file loads also doesn’t work since opening a file clears the name-space.

It is possible to run a script via the --python command line argument, before the blend file. This can register a load-post handler (bpy.app.handlers.load_post) that initialized the name-space. While this works for background tasks it has the downside that opening the file from the file selector won’t setup the name-space.

bpy.app.online_access

Boolean, true when internet access is allowed by Blender & 3rd party scripts (read-only)

bpy.app.online_access_override

Boolean, true when internet access preference is overridden by the command line (read-only)

bpy.app.python_args

Leading arguments to use when calling Python directly (via sys.executable). These arguments match settings Blender uses to ensure Python runs with a compatible environment (read-only).

bpy.app.render_icon_size

Reference size for icon/preview renders (read-only)

bpy.app.render_preview_size

Reference size for icon/preview renders (read-only)

bpy.app.tempdir

String, the temp directory used by blender (read-only)

bpy.app.use_event_simulate

Boolean, for application behavior (started with --enable-* matching this attribute name)

bpy.app.use_userpref_skip_save_on_exit

Boolean, for application behavior (started with --enable-* matching this attribute name)

bpy.app.background

Boolean, True when blender is running without a user interface (started with -b)

bpy.app.factory_startup

Boolean, True when blender is running with –factory-startup)

bpy.app.module

Boolean, True when running Blender as a python module

bpy.app.portable

Boolean, True unless blender was built to reference absolute paths (on UNIX).

bpy.app.build_branch

The branch this blender instance was built from

bpy.app.build_cflags

C compiler flags

bpy.app.build_commit_date

The date of commit this blender instance was built

bpy.app.build_commit_time

The time of commit this blender instance was built

bpy.app.build_cxxflags

C++ compiler flags

bpy.app.build_date

The date this blender instance was built

bpy.app.build_hash

The commit hash this blender instance was built with

bpy.app.build_linkflags

Binary linking flags

bpy.app.build_platform

The platform this blender instance was built for

bpy.app.build_system

Build system used

bpy.app.build_time

The time this blender instance was built

bpy.app.build_type

The type of build (Release, Debug)

bpy.app.build_commit_timestamp

The unix timestamp of commit this blender instance was built

bpy.app.version_cycle

The release status of this build alpha/beta/rc/release

bpy.app.version_string

The Blender version formatted as a string

bpy.app.version

The Blender version as a tuple of 3 numbers (major, minor, micro). eg. (4, 3, 1)

bpy.app.version_file

The Blender File version, as a tuple of 3 numbers (major, minor, file sub-version), that will be used to save a .blend file. The last item in this tuple indicates the file sub-version, which is different from the release micro version (the last item of the bpy.app.version tuple). The file sub-version can be incremented multiple times while a Blender version is under development. This value is, and should be, used for handling compatibility changes between Blender versions

bpy.app.alembic

Constant value bpy.app.alembic(supported=True, version=(1, 8, 3), version_string=’ 1, 8, 3’)

bpy.app.build_options

Constant value bpy.app.build_options(bullet=True, codec_avi=False, codec_ffmpeg=True, codec_sndfile=True, compositor_cpu=True, cycles=False, cycles_osl=False, freestyle=True, gameengine=True, image_cineon=True, image_dds=True, image_hdr=True, image_openexr=True, image_openjpeg=True, image_tiff=True, input_ndof=True, audaspace=True, international=True, openal=True, opensubdiv=True, sdl=True, coreaudio=False, jack=False, pulseaudio=False, wasapi=False, libmv=False, mod_oceansim=False, mod_remesh=True, player=True, collada=True, io_wavefront_obj=True, io_ply=True, io_stl=True, io_gpencil=True, opencolorio=False, openmp=True, openvdb=True, alembic=True, usd=True, fluid=True, xr_openxr=True, potrace=True, pugixml=True, haru=True)

bpy.app.ffmpeg

Constant value bpy.app.ffmpeg(supported=True, avcodec_version=(60, 31, 102), avcodec_version_string=’60, 31, 102’, avdevice_version=(60, 3, 100), avdevice_version_string=’60, 3, 100’, avformat_version=(60, 16, 100), avformat_version_string=’60, 16, 100’, avutil_version=(58, 29, 100), avutil_version_string=’58, 29, 100’, swscale_version=(7, 5, 100), swscale_version_string=’ 7, 5, 100’)

bpy.app.ocio

Constant value bpy.app.ocio(supported=True, version=(2, 3, 2), version_string=’ 2, 3, 2’)

bpy.app.oiio

Constant value bpy.app.oiio(supported=True, version=(2, 5, 11), version_string=’ 2, 5, 11’)

bpy.app.opensubdiv

Constant value bpy.app.opensubdiv(supported=True, version=(3, 6, 0), version_string=’ 3, 6, 0’)

bpy.app.openvdb

Constant value bpy.app.openvdb(supported=True, version=(11, 0, 0), version_string=’11, 0, 0’)

bpy.app.sdl

Constant value bpy.app.sdl(supported=True, version=(2, 28, 2), version_string=’2.28.2’)

bpy.app.usd

Constant value bpy.app.usd(supported=True, version=(0, 24, 5), version_string=’ 0, 24, 5’)

static bpy.app.help_text(all=False)

Return the help text as a string.

Parameters:

all (bool) – Return all arguments, even those which aren’t available for the current platform.

static bpy.app.is_job_running(job_type)

Check whether a job of the given type is running.

Parameters:

job_type (str) – job type in Wm Job Type Items.

Returns:

Whether a job of the given type is currently running.

Return type:

bool.