PEP 561 type stubs for MaterialX
Project description
MaterialX Type Stub Generator
Logic to create PEP 561 compliant type stubs for MaterialX
- Enables IntelliSense, autocomplete, and type checking for MaterialX in Python IDEs.
- The sample stubs are based on head of version
1.39.5. - The repo can be cloned to create stubs for the desired MaterialX install.
- Stubs are generated as
MaterialX-stubs/package to provide types for your installed MaterialX package (PEP 561 compliant).
How It Works
This package follows PEP 561 for distributing type information:
- The package is named
types-MaterialX(standard naming for stub-only packages) - Stubs are installed in
MaterialX-stubs/directory - When you import
MaterialXin your code, type checkers (mypy, Pylance, etc.) automatically discover and use the stubs fromMaterialX-stubs/ - This works alongside your regular MaterialX installation without conflicts
Installation
Standard Installation
For MaterialX versions available on PyPI (1.39.5 and earlier):
pip install .
Installation with Local MaterialX (1.39.6+)
If you have a locally built MaterialX version (e.g., 1.39.6) that's not yet on PyPI:
# First, ensure your local MaterialX is installed
pip install /path/to/your/MaterialX
# Then install types-MaterialX without build isolation
pip install --no-build-isolation .
Note: The --no-build-isolation flag tells pip to use your current environment's MaterialX installation during the build process, rather than creating an isolated build environment with only PyPI packages.
VS Code Setup
pip install .
# Reload VS Code: Ctrl+Shift+P → "Developer: Reload Window"
Requirements: Python and Pylance extension
Included Modules
The following have been built using the PyPi 1.39.5 MaterialX Package
- PyMaterialXCore
- PyMaterialXFormat
- PyMaterialXGenShader
- PyMaterialXGenGlsl
- PyMaterialXGenOsl
- PyMaterialXGenMsl
- PyMaterialXGenMdl
- PyMaterialXGenSlang
- PyMaterialXRender
- PyMaterialXRenderGlsl
- PyMaterialXRenderOsl
- colorspace
- datatype
- main
Development
Building Stubs
Stubs can be rebuild using:
./setup.sh # Generate stubs, build wheel, and install
Then installed using again using pip
Clean Up
This will remove all build artifacts including generated stubs:
cleanup.sh # Clean build and stubs
Build distribution
./build_dist.sh
If build and / or twine are not found, install using
pip install ".[dev]"
Test
A small test for stub installation and discovery is included in the test_stub_discovery.py script. Discovery uses the mypy package.
The results will look something like this:
======================================================================
MaterialX Type Stub Discovery Test
======================================================================
1. Site-packages locations:
- C:\Users\home\AppData\Local\Programs\Python\Python311
- C:\Users\home\AppData\Local\Programs\Python\Python311\Lib\site-packages
2. MaterialX package:
- MaterialX installed at: C:\Users\home\AppData\Local\Programs\Python\Python311\Lib\site-packages\MaterialX\__init__.py
- MaterialX version: 1.39.5
3. MaterialX-stubs directory:
- Found at: C:\Users\home\AppData\Local\Programs\Python\Python311\Lib\site-packages\MaterialX-stubs
- Contains 14 .pyi files
- py.typed marker present
- Sample stub files:
- __init__.pyi
- datatype.pyi
- main.pyi
- PyMaterialXCore.pyi
- PyMaterialXFormat.pyi
- Sample type signatures from stubs:
Document class methods:
- addAttributeDef(self, arg0: str) -> AttributeDef:
- addCollection(self, name: str = ...) -> Collection:
- addGeomInfo(self, name: str = ..., geom: str = ...) -> GeomInfo:
- addGeomPropDef(self, arg0: str, arg1: str) -> GeomPropDef:
- addImplementation(self, name: str = ...) -> Implementation:
- addLook(self, name: str = ...) -> Look:
4. Mypy compatibility:
- Mypy is installed (version: unknown)
INFO: Programmatic stub discovery test in section 5 below
5. Sample API type information:
- createDocument: Available (stub types in .pyi files)
- Element.getName: Available (stub types in .pyi files)
- Element.setName: Available (stub types in .pyi files)
- Document.addNodeGraph: Available (stub types in .pyi files)
6. Type checking test:
Creating test file...
- Mypy type checking passed
- Mypy is using MaterialX-stubs
Example: ...a\Local\Programs\Python\Python311\Lib\site-packages\MaterialX-stubs\__init__.pyi
======================================================================
Summary:
- MaterialX type stubs are properly installed and discoverable!
- Location: C:\Users\home\AppData\Local\Programs\Python\Python311\Lib\site-packages\MaterialX-stubs
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file types_materialx-0.1.39.5.tar.gz.
File metadata
- Download URL: types_materialx-0.1.39.5.tar.gz
- Upload date:
- Size: 59.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1c28d96bded29948a3973cf0a365353ccb0a2621637f80ada967ab487bd57630
|
|
| MD5 |
f8109462e8e14dc7680f6500928fe7aa
|
|
| BLAKE2b-256 |
d80a7e0245c8fe2653c6d17497a81e7bafe8731d555afc3fc8c9f6b4ab5c58c0
|
File details
Details for the file types_materialx-0.1.39.5-py3-none-any.whl.
File metadata
- Download URL: types_materialx-0.1.39.5-py3-none-any.whl
- Upload date:
- Size: 67.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d0afdd3f358b169dd9f7a6f6bcdf1e186f95b872e52705ca2a038deabf76e153
|
|
| MD5 |
1bdbe21c88e38486245e649ff94401a3
|
|
| BLAKE2b-256 |
d322b8efccd9682d0f25c96c31815101b65c6a92b6a983c15ce62e40440a0150
|