Skip to main content

Build Blender extensions.

Project description

blender-extension-builder

A builder for blender extensions.

Blender allows you to add dependencies via packaging wheels with the extension, however you have to manually grab the wheels and put the filenames in the blender_manifest.toml file. This can be cumbersome, especially with many dependencies, and dependencies of dependencies that you don't control. This project aims to aid in that, and make it all a lot easier.

Installation

Install via pip

pip install blender-extension-builder

You also need Blender available on the PATH in order to build the extension.

Usage

You can use the command

build-blender-extension -h

Or

python -m build_blender_extension -h

Setting up blender_manifest.toml

Since this aims to make managing dependencies easier, there are a couple things added to the blender_manifest.toml file. The file will be structured like any blender_manifest.toml file, just with a few new options.

schema_version = "1.0.0"
id = "my_example_extension"
version = "1.0.0"
name = "My Example Extension"
tagline = "This is another extension"
maintainer = "Developer name <email@address.com>"
type = "add-on"
blender_version_min = "4.2.0"
license = [
  "SPDX:GPL-3.0-or-later",
]

# Place dependencies here. They can be in any format that pip supports.
dependencies = [
    'numpy'
]
# Folder to store the wheels in the addon.
wheel-path = './wheels'

# If you would like to manually specify the wheels, you still can.
# This If you also specify dependencies, those will be appended into this.
wheels = [
  './wheels/pillow-10.3.0-cp311-cp311-win_amd64.whl',
]

[build]
# Some optional extra options were added to this table

# Folder containing the source code of the extension. Defaults to the current directory
source = './src'
# Folder for where the extension will be stored with all the files (to build the extension). Defaults to ./build
build = './build'
# Output folder for the built addon in the .zip file.
dist = './dist'

# This contains a list of files or folders to keep in the built extension.
paths_include = [
  'LICENSE',
  'README.md',
]

All you have to do is now run

build-blender-extension -m blender_manifest.toml

Note: if you don't specify any arguments, it will try to use blender_manifest.toml.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

blender_extension_builder-1.0.1.tar.gz (40.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

blender_extension_builder-1.0.1-py3-none-any.whl (29.0 kB view details)

Uploaded Python 3

File details

Details for the file blender_extension_builder-1.0.1.tar.gz.

File metadata

File hashes

Hashes for blender_extension_builder-1.0.1.tar.gz
Algorithm Hash digest
SHA256 140b6f7e91dd297eb8f5e7e2bbefa7be2ccdc763304b1fcfafc2f8c60d6b195e
MD5 6997ff17e3cf1e2c34618543f81938d5
BLAKE2b-256 7400c8887a7d44ba106bb86ec55bbf57b07807d339a9f29d80ba6c81055d0a01

See more details on using hashes here.

Provenance

The following attestation bundles were made for blender_extension_builder-1.0.1.tar.gz:

Publisher: python-publish.yml on ego-lay-atman-bay/blender-extension-builder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file blender_extension_builder-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for blender_extension_builder-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7c5e29c8ca310cb680b5981b19f1ed4d53a02d94a77d0851322b1c597daa6deb
MD5 2403c09f727f43f534929d3ac460ed36
BLAKE2b-256 d8e5b89f000c6bbf0e54ab57909e8febbb2c825f76c5ae850ed72610725e0cd8

See more details on using hashes here.

Provenance

The following attestation bundles were made for blender_extension_builder-1.0.1-py3-none-any.whl:

Publisher: python-publish.yml on ego-lay-atman-bay/blender-extension-builder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page