Skip to main content

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 MaterialX in your code, type checkers (mypy, Pylance, etc.) automatically discover and use the stubs from MaterialX-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


Download files

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

Source Distribution

types_materialx-0.1.39.5.tar.gz (59.0 kB view details)

Uploaded Source

Built Distribution

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

types_materialx-0.1.39.5-py3-none-any.whl (67.7 kB view details)

Uploaded Python 3

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

Hashes for types_materialx-0.1.39.5.tar.gz
Algorithm Hash digest
SHA256 1c28d96bded29948a3973cf0a365353ccb0a2621637f80ada967ab487bd57630
MD5 f8109462e8e14dc7680f6500928fe7aa
BLAKE2b-256 d80a7e0245c8fe2653c6d17497a81e7bafe8731d555afc3fc8c9f6b4ab5c58c0

See more details on using hashes here.

File details

Details for the file types_materialx-0.1.39.5-py3-none-any.whl.

File metadata

File hashes

Hashes for types_materialx-0.1.39.5-py3-none-any.whl
Algorithm Hash digest
SHA256 d0afdd3f358b169dd9f7a6f6bcdf1e186f95b872e52705ca2a038deabf76e153
MD5 1bdbe21c88e38486245e649ff94401a3
BLAKE2b-256 d322b8efccd9682d0f25c96c31815101b65c6a92b6a983c15ce62e40440a0150

See more details on using hashes here.

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