Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
f76d767
Add an empty metatomic-core python package, re-exporting metatomic-torch
Luthaf May 12, 2026
391d1b4
Use pathlib for all path manipulations
Luthaf May 21, 2026
8e6ffd8
Switch main test runner from tox to cargo
Luthaf May 12, 2026
bc09ce9
Scaffold a new metatomic-core package
Luthaf May 13, 2026
04689ee
Draft the C API for metatomic-core
Luthaf May 27, 2026
beaabc1
Implement PairListOptions json serialization
sofiia-chorna May 28, 2026
c502033
Implement JSON serialization for `Quantity`
GardevoirX May 28, 2026
463d6df
Validate quantities names
Luthaf May 29, 2026
5f8b095
Implement JSON serialization for ModelMetadata
alessandroforina May 28, 2026
69fc87a
Add error handling based on metatensor
RMeli May 28, 2026
b6ab89c
Implement mta_string_t in the C API
johannes-spies May 28, 2026
6e90157
Port unit parsing from metatomic-torch
Luthaf May 29, 2026
2ff84c4
document mta_model_t and related functions in C API
sofiia-chorna May 30, 2026
609a11a
Add ModelCapabilities to the JSON structs
Luthaf May 31, 2026
54f60de
Implement plugin registration and loading, model loading
frostedoyster Jun 1, 2026
450c208
Add a C model registration test
frostedoyster May 29, 2026
2bc7288
Implement System in metatomic-core
Luthaf Jun 1, 2026
3ed143a
Implement `mta_format_metadata`
GardevoirX Jun 3, 2026
6cac6ea
Add unit conversion and error handling to C++
RMeli Jun 2, 2026
5d0e574
Add C++ documentation
Luthaf Jun 3, 2026
c8c21fd
Expose mta_model_t function in rust's Model struct
alessandroforina Jun 11, 2026
4c1a2ba
Cleanup CMake code calling cargo
Luthaf Jun 16, 2026
8bf4fd3
C++ API to format model metadata (#266)
RMeli Jun 23, 2026
f0657a3
Add C++ API for loading plugins
RMeli Jun 24, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 10 additions & 1 deletion .github/workflows/build-wheels.yml
Original file line number Diff line number Diff line change
Expand Up @@ -100,8 +100,17 @@ jobs:
CIBW_BUILD_VERBOSITY: 1
CIBW_MANYLINUX_X86_64_IMAGE: gcc11-manylinux_2_28_x86_64
CIBW_MANYLINUX_AARCH64_IMAGE: gcc11-manylinux_2_28_aarch64
# METATOMIC_NO_LOCAL_DEPS is set to 1 when building a tag of
# metatomic-torch, which will force to use the version of
# metatomic-core already released on PyPI. Otherwise, this will use
# the version of metatomic-core from git checkout (in case there are
# unreleased breaking changes).
#
# This means that when releasing a breaking change in metatomic-core,
# the full release should be available on PyPI before pushing the new
# metatomic-torch tag.
CIBW_ENVIRONMENT: >
METATOMIC_NO_LOCAL_DEPS=1
METATOMIC_NO_LOCAL_DEPS=${{ startsWith(github.ref, 'refs/tags/metatomic-torch-v') && '1' || '0' }}
METATOMIC_TORCH_BUILD_WITH_TORCH_VERSION=${{ matrix.torch-version }}.*
PIP_EXTRA_INDEX_URL=https://download.pytorch.org/whl/cpu
MACOSX_DEPLOYMENT_TARGET=11
Expand Down
96 changes: 96 additions & 0 deletions .github/workflows/python-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
name: Python tests

on:
push:
branches: [main]
pull_request:
# Check all PR

concurrency:
group: python-tests-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}

jobs:
python-tests:
runs-on: ${{ matrix.os }}
name: ${{ matrix.os }} / Python ${{ matrix.python-version }} / Torch ${{ matrix.torch-version }}
strategy:
matrix:
include:
- os: ubuntu-24.04
python-version: "3.10"
torch-version: "2.3"
numpy-version-pin: "<2.0"
# Do not run docs-tests with python 3.10 since torch-sim-atomistic
# is not available for this version of python
tox-envs: lint,torch-tests
- os: ubuntu-24.04
python-version: "3.10"
torch-version: "2.12"
# See above
tox-envs: lint,torch-tests
- os: ubuntu-24.04
# TorchScript is no longer supported in Python 3.14
# so we keep a test with 3.13 to make sure this doesn't break
python-version: "3.13"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: ubuntu-24.04
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: macos-15
Comment thread
RMeli marked this conversation as resolved.
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: windows-2022
Comment thread
RMeli marked this conversation as resolved.
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
steps:
- uses: actions/checkout@v6
with:
fetch-depth: 0

- name: setup Python
uses: actions/setup-python@v6
with:
python-version: ${{ matrix.python-version }}

- name: setup rust
uses: dtolnay/rust-toolchain@master
with:
toolchain: stable

- name: Cache Rust dependencies
uses: Leafwing-Studios/cargo-cache@v2.6.1
with:
sweep-cache: true

- name: Setup sccache
if: ${{ !env.ACT }}
uses: mozilla-actions/sccache-action@v0.0.10
with:
version: "v0.10.0"
Comment thread
RMeli marked this conversation as resolved.

- name: setup MSVC command prompt
uses: ilammy/msvc-dev-cmd@v1

- name: Setup sccache environnement variables
if: ${{ !env.ACT }}
run: |
echo "SCCACHE_GHA_ENABLED=true" >> $GITHUB_ENV
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV
echo "CMAKE_C_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV
echo "CMAKE_CXX_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV

- name: install tests dependencies
run: |
python -m pip install --upgrade pip
python -m pip install tox coverage

- name: run tests
run: tox -e ${{ matrix.tox-envs }}
env:
PIP_EXTRA_INDEX_URL: https://download.pytorch.org/whl/cpu
METATOMIC_TESTS_TORCH_VERSION: ${{ matrix.torch-version }}
186 changes: 186 additions & 0 deletions .github/workflows/rust-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,186 @@
name: Rust tests

on:
push:
branches: [main]
pull_request:
# Check all PR

concurrency:
group: rust-tests-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}

jobs:
rust-tests:
name: ${{ matrix.os }} / Rust ${{ matrix.rust-version }}${{ matrix.extra-name }}
runs-on: ${{ matrix.os }}
container: ${{ matrix.container }}
defaults:
run:
shell: "bash"
env:
CMAKE_CXX_COMPILER: ${{ matrix.cxx }}
CMAKE_C_COMPILER: ${{ matrix.cc }}
CMAKE_GENERATOR: ${{ matrix.cmake-generator }}
strategy:
matrix:
include:
- os: ubuntu-24.04
rust-version: stable
rust-target: x86_64-unknown-linux-gnu
cxx: g++
cc: gcc
cmake-generator: Unix Makefiles

# check the build on a stock Ubuntu 22.04, which uses cmake 3.22, and
# with our minimal supported rust version
- os: ubuntu-24.04
rust-version: 1.74
container: ubuntu:22.04
rust-target: x86_64-unknown-linux-gnu
extra-name: ", cmake 3.22"
cxx: g++
cc: gcc
cmake-generator: Unix Makefiles

- os: macos-15
Comment thread
RMeli marked this conversation as resolved.
rust-version: stable
rust-target: aarch64-apple-darwin
extra-name: ""
cxx: clang++
cc: clang
cmake-generator: Unix Makefiles

# - os: windows-2022
# rust-version: stable
# rust-target: x86_64-pc-windows-msvc
# extra-name: " / MSVC"
# cxx: cl.exe
# cc: cl.exe
# cmake-generator: Visual Studio 17 2022

# - os: windows-2022
# rust-version: stable
# rust-target: x86_64-pc-windows-gnu
# extra-name: " / MinGW"
# cxx: g++.exe
# cc: gcc.exe
# cmake-generator: MinGW Makefiles
steps:
- name: install dependencies in container
if: matrix.container == 'ubuntu:22.04'
run: |
apt update
apt install -y software-properties-common
apt install -y cmake make gcc g++ git curl python3-venv

- uses: actions/checkout@v6
with:
fetch-depth: 0

- name: Configure git safe directory
if: matrix.container == 'ubuntu:22.04'
run: git config --global --add safe.directory /__w/metatomic/metatomic

- name: setup rust
uses: dtolnay/rust-toolchain@master
with:
toolchain: ${{ matrix.rust-version }}
target: ${{ matrix.rust-target }}

- name: setup Python
uses: actions/setup-python@v6
if: matrix.container == null
with:
# Python 3.14.5 fails with "No module named pip.__main__; 'pip' is a
# package and cannot be directly executed" when using a venv, so we
# use 3.14.4 for now
python-version: "3.14.4"
Comment thread
Luthaf marked this conversation as resolved.

- name: Cache Rust dependencies
uses: Leafwing-Studios/cargo-cache@v2.6.1
with:
sweep-cache: true

- name: install valgrind
if: matrix.do-valgrind
run: |
sudo apt-get install -y valgrind

- name: Setup sccache
if: ${{ !env.ACT }}
uses: mozilla-actions/sccache-action@v0.0.10
with:
version: "v0.15.0"

- name: Setup sccache environnement variables
if: ${{ !env.ACT }}
run: |
echo "SCCACHE_GHA_ENABLED=true" >> $GITHUB_ENV
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV
echo "CMAKE_C_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV
echo "CMAKE_CXX_COMPILER_LAUNCHER=sccache" >> $GITHUB_ENV

- name: run tests
run: |
cargo test --package metatomic-core --target ${{ matrix.rust-target }}
env:
RUST_BACKTRACE: full

- name: check that the header was already up to date
run: |
git diff --exit-code

# check that the C API declarations are correctly documented and used
prevent-bitrot:
runs-on: ubuntu-24.04
name: check C API declarations
steps:
- uses: actions/checkout@v6

- name: setup Python
uses: actions/setup-python@v6
with:
python-version: "3.14"

- name: install python dependencies
run: |
pip install pycparser

- name: check that C API functions are all documented
run: |
python scripts/check-c-api-docs.py

# make sure no debug print stays in the code
check-debug-prints:
runs-on: ubuntu-24.04
name: check leftover debug print

steps:
- uses: actions/checkout@v6

- name: install ripgrep
run: |
wget https://github.com/BurntSushi/ripgrep/releases/download/13.0.0/ripgrep-13.0.0-x86_64-unknown-linux-musl.tar.gz
tar xf ripgrep-13.0.0-x86_64-unknown-linux-musl.tar.gz
echo "$(pwd)/ripgrep-13.0.0-x86_64-unknown-linux-musl" >> $GITHUB_PATH

- name: check for leftover dbg!
run: |
# use ripgrep (rg) to check for instances of `dbg!` in rust files.
# rg will return 1 if it fails to find a match, so we invert it again
# with the `!` builtin to get the error/success in CI

! rg "dbg!" --type=rust --quiet

- name: check for leftover \#include <iostream>
run: |
! rg "<iostream>" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet

- name: check for leftover std::cout
run: |
! rg "cout" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet

- name: check for leftover std::cerr
run: |
! rg "cerr" --iglob "\!metatomic-core/tests/cpp/external/catch/catch.hpp" --quiet
Loading
Loading