Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
88b77ae
Add an empty metatomic-core python package, re-exporting metatomic-torch
Luthaf May 12, 2026
0423b7a
Use pathlib for all path manipulations
Luthaf May 21, 2026
0f18b70
Switch main test runner from tox to cargo
Luthaf May 12, 2026
63b9118
Scaffold a new metatomic-core package
Luthaf May 13, 2026
6400c69
Draft the C API for metatomic-core
Luthaf May 27, 2026
743aae3
Implement PairListOptions json serialization
sofiia-chorna May 28, 2026
e02fe0b
Implement JSON serialization for `Quantity`
GardevoirX May 28, 2026
36e9f33
Validate quantities names
Luthaf May 29, 2026
e9d9555
Implement JSON serialization for ModelMetadata
alessandroforina May 28, 2026
b39f675
Add error handling based on metatensor
RMeli May 28, 2026
bfdda0a
Implement mta_string_t in the C API
johannes-spies May 28, 2026
f04c6c0
Port unit parsing from metatomic-torch
Luthaf May 29, 2026
49ce8af
document mta_model_t and related functions in C API
sofiia-chorna May 30, 2026
4a4484a
Add ModelCapabilities to the JSON structs
Luthaf May 31, 2026
d35b62b
Implement plugin registration and loading, model loading
frostedoyster Jun 1, 2026
272d06c
Add a C model registration test
frostedoyster May 29, 2026
5a0882c
Implement System in metatomic-core
Luthaf Jun 1, 2026
f56f2ab
Implement `mta_format_metadata`
GardevoirX Jun 3, 2026
890c0c9
Add unit conversion and error handling to C++
RMeli Jun 2, 2026
0dbcd7c
Add C++ documentation
Luthaf Jun 3, 2026
3a34b6c
Implement Model query methods and Drop
alessandroforina Jun 4, 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
python-version: "3.14"
torch-version: "2.12"
tox-envs: lint,torch-tests,docs-tests
- os: windows-2022
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"

- 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
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"

- 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