Metadata-Version: 2.1
Name: pymmcore-nano
Version: 12.2.0.75.0
Summary: Alternative python bindings for MMCore, Micro-Manager's device control layer
Author: Micro-Manager Team
Author-Email: Mark Tsuchida <marktsuchida@gmail.com>, Talley Lambert <talley.lambert@gmail.com>
License: LGPL-2.1-only
Classifier: Development Status :: 4 - Beta
Classifier: License :: OSI Approved :: BSD License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Typing :: Typed
Requires-Python: >=3.9
Requires-Dist: numpy>=1.25
Provides-Extra: test-devices
Requires-Dist: mm-test-adapters~=75.0; extra == "test-devices"
Description-Content-Type: text/markdown

# pymmcore-nano

[![License](https://img.shields.io/pypi/l/pymmcore-nano.svg?color=green)](https://github.com/pymmcore-plus/pymmcore-nano/raw/main/LICENSE)
[![PyPI](https://img.shields.io/pypi/v/pymmcore-nano.svg?color=green)](https://pypi.org/project/pymmcore-nano)
[![Python Version](https://img.shields.io/pypi/pyversions/pymmcore-nano.svg?color=green)](https://python.org)
[![CI](https://github.com/pymmcore-plus/pymmcore-nano/actions/workflows/ci.yml/badge.svg)](https://github.com/pymmcore-plus/pymmcore-nano/actions/workflows/ci.yml)
[![codecov](https://codecov.io/gh/pymmcore-plus/pymmcore-nano/branch/main/graph/badge.svg)](https://codecov.io/gh/pymmcore-plus/pymmcore-nano)

Experimental python bindings for
[CMMCore](https://github.com/micro-manager/mmCoreAndDevices) (the device
abstraction layer for micro-manager) using
[nanobind](https://nanobind.readthedocs.io/en/latest/) instead of SWIG.

This package can be used as a drop-in replacement for
[`pymmcore`](https://pypi.org/project/pymmcore/). There are a few slight
differences in behavior.  You are encouraged to try it where you might use
pymmcore; and [let us
know](https://github.com/pymmcore-plus/pymmcore-nano/issues) if you run into any
issues!

## Installation

```sh
pip install pymmcore-nano

# optionally include device adapters commonly used for demos and testing
# (DemoCamera, Utilities, etc...)
pip install 'pymmcore-nano[test-devices]'
```

Versioning is the same as for pymmcore.  

```txt
MMCoreMajor.MMCoreMinor.MMCorePatch.DeviceInterface.pymmcore-nano-build
```

For example, the version `11.3.0.71.2` refers to:

- MMCore version 11.3.0
- Device interface 71
- pymmcore-nano build number of 2 (this is a zero indexed version that resets
  each time the MMCore or Device Interface versions increment)

## For Developers

### Clone repo

```sh
git clone https://github.com/pymmcore-plus/pymmcore-nano.git
cd pymmcore-nano
```

### Setup dev environment (editable install)

Make sure you have uv installed:
<https://docs.astral.sh/uv/getting-started/installation/>

This project uses `just` as a task runner. If you have `just` installed (e.g.
`brew install just`), you can fully setup the project with:

```sh
just install
```

If you prefer not to install `just` globally, you can install it with the rest
of the project dependencies using uv.  Then activate the environment and call
`just install`

```sh
uv sync --no-install-project
. .venv/bin/activate  # Windows: .venv\Scripts\activate
just install
```

Note that one of the dev dependencies is
[`mm-test-adapters`](https://pypi.org/project/mm-test-adapters/), this brings in
a few device adapters that are useful for testing purposes. (The version of
`mm-test-adapters` should match the device interface version you are building
against.)

### Test

Regardless of whether the environment is active, you can run:

```sh
just test
```

or, if the environment is active and you have already run `just install`

```sh
pytest
```

### Releasing

To release a new version:

- update the `PYMMCORE_NANO_VERSION` value in [`_pymmcore_nano.cc`](./src/_pymmcore_nano.cc)
- run `just version`
- commit changes to main
- run `just release`

### Updating `MMCore` and `MMDevice`

The versions of `MMCore` and `MMDevice` that this project builds against are
pinned in the `subprojects/mmcore.wrap` and `subprojects/mmdevice.wrap` files,
respectively.  To build against a new version, update the `revision` field in
the appropriate wrap file and re-run `just install`.

For version changes that bump the Device Interface version, you will also want
to update the version of `mm-test-adapters` in the `pyproject.toml` file.
