Skip to content

Commit

Permalink
feat(python): support python 3.13
Browse files Browse the repository at this point in the history
  • Loading branch information
cpcloud committed Dec 16, 2024
1 parent 80a185c commit 8c83136
Show file tree
Hide file tree
Showing 8 changed files with 210 additions and 133 deletions.
4 changes: 4 additions & 0 deletions .github/workflows/nix-skip-helper.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,11 @@ jobs:
include:
- os: ubuntu-arm64-24.04
python-version: "3.12"
- os: ubuntu-arm64-24.04
python-version: "3.13"
- os: macos-14
python-version: "3.12"
- os: macos-14
python-version: "3.13"
steps:
- run: echo "No build required"
7 changes: 5 additions & 2 deletions .github/workflows/nix.yml
Original file line number Diff line number Diff line change
Expand Up @@ -38,11 +38,16 @@ jobs:
- "3.10"
- "3.11"
- "3.12"
- "3.13"
include:
- os: ubuntu-arm64-24.04 # aarch64-linux
python-version: "3.12"
- os: ubuntu-arm64-24.04 # aarch64-linux
python-version: "3.13"
- os: macos-14 # aarch64-darwin
python-version: "3.12"
- os: macos-14 # aarch64-darwin
python-version: "3.13"
steps:
- name: checkout
uses: actions/checkout@v4
Expand Down Expand Up @@ -76,8 +81,6 @@ jobs:
nix build ".#ibis${version//./}.passthru.tests.pytest" --fallback --keep-going --print-build-logs
- name: nix build devShell
# TODO: dev shell doesn't yet build on macos-14 (aarch64-darwin)
continue-on-error: ${{ matrix.os == 'macos-14' }}
run: |
set -euo pipefail
Expand Down
9 changes: 6 additions & 3 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -148,30 +148,33 @@
'';

GDAL_DATA = "${pkgs.gdal}/share/gdal";
PROJ_DATA = "${pkgs.proj}/share/proj";

__darwinAllowLocalNetworking = true;
};
in
rec {
packages = {
default = packages.ibis312;
default = packages.ibis313;

inherit (pkgs) ibis310 ibis311 ibis312
inherit (pkgs) ibis310 ibis311 ibis312 ibis313
update-lock-files check-release-notes-spelling;
};

checks = {
ibis310-pytest = pkgs.ibis310.passthru.tests.pytest;
ibis311-pytest = pkgs.ibis311.passthru.tests.pytest;
ibis312-pytest = pkgs.ibis312.passthru.tests.pytest;
ibis313-pytest = pkgs.ibis313.passthru.tests.pytest;
};

devShells = rec {
ibis310 = mkDevShell pkgs.ibisDevEnv310;
ibis311 = mkDevShell pkgs.ibisDevEnv311;
ibis312 = mkDevShell pkgs.ibisDevEnv312;
ibis313 = mkDevShell pkgs.ibisDevEnv313;

default = ibis312;
default = ibis313;

preCommit = pkgs.mkShell {
name = "preCommit";
Expand Down
2 changes: 1 addition & 1 deletion ibis/backends/sql/compilers/bigquery/udf/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ def rewrite_len(node):
return ast.Attribute(value=node.args[0], attr="length", ctx=ast.Load())


@rewrite.register(ast.Call(func=ast.Attribute(attr="append")))
@rewrite.register(ast.Call(func=ast.Attribute(attr="append", value=None)))
def rewrite_append(node):
return ast.Call(
func=ast.Attribute(value=node.func.value, attr="push", ctx=ast.Load()),
Expand Down
11 changes: 9 additions & 2 deletions nix/overlay.nix
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,11 @@ let
# Use base package set from pyproject.nix builders
(pkgs.callPackage pyproject-nix.build.packages {
inherit python;
stdenv = pkgs.stdenv.override {
targetPlatform = pkgs.stdenv.targetPlatform // {
darwinSdkVersion = "12.0";
};
};
}).overrideScope
(lib.composeManyExtensions ([
pyproject-build-systems.overlays.default
Expand Down Expand Up @@ -96,10 +101,12 @@ in
ibis310 = mkEnv pkgs.python310;
ibis311 = mkEnv pkgs.python311;
ibis312 = mkEnv pkgs.python312;
ibis313 = mkEnv pkgs.python313;

ibisDevEnv310 = mkDevEnv pkgs.python310;
ibisDevEnv311 = mkDevEnv pkgs.python311;
ibisDevEnv312 = mkDevEnv pkgs.python312;
ibisDevEnv313 = mkDevEnv pkgs.python313;

ibisSmallDevEnv = mkEnv'
{
Expand All @@ -108,7 +115,7 @@ in
};
editable = false;
}
pkgs.python312;
pkgs.python313;

duckdb = super.duckdb.overrideAttrs (
_: lib.optionalAttrs (stdenv.isAarch64 && stdenv.isLinux) {
Expand Down Expand Up @@ -149,7 +156,7 @@ in
gen-examples = pkgs.writeShellApplication {
name = "gen-examples";
runtimeInputs = [
pkgs.ibisDevEnv312
pkgs.ibisDevEnv313
(pkgs.rWrapper.override {
packages = with pkgs.rPackages; [
Lahman
Expand Down
21 changes: 16 additions & 5 deletions nix/pyproject-overrides.nix
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,9 @@ let
toolz.setuptools = [ ];
typing-extensions.flit-core = [ ];
debugpy.setuptools = [ ];
google-crc32c.setuptools = [ ];
lz4.setuptools = [ ];
snowflake-connector-python.setuptools = [ ];
} // lib.optionalAttrs stdenv.hostPlatform.isDarwin {
duckdb = {
setuptools = [ ];
Expand All @@ -39,15 +42,23 @@ let
};
in
(lib.optionalAttrs stdenv.hostPlatform.isDarwin {
pyarrow = prev.pyarrow.overrideAttrs (attrs: {
pyproj = prev.pyproj.overrideAttrs (attrs: {
nativeBuildInputs = attrs.nativeBuildInputs or [ ] ++ [
final.setuptools
final.setuptools-scm
final.cython
final.numpy
pkgs.cmake
pkgs.arrow-cpp
pkgs.proj
];
PROJ_DIR = "${lib.getBin pkgs.proj}";
PROJ_INCDIR = "${lib.getDev pkgs.proj}";
});

psygnal = prev.psygnal.overrideAttrs (_: {
src = pkgs.fetchFromGitHub {
owner = "pyapp-kit";
repo = prev.psygnal.pname;
rev = "refs/tags/v${prev.psygnal.version}";
hash = "sha256-eGJWtmw2Ps3jII4T8E6s3djzxfqcSdyPemvejal0cn4=";
};
});
}) // lib.mapAttrs (name: spec: addBuildSystems prev.${name} spec) buildSystemOverrides // {
mysqlclient = prev.mysqlclient.overrideAttrs (attrs: {
Expand Down
8 changes: 4 additions & 4 deletions requirements-dev.txt

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit 8c83136

Please sign in to comment.