python3Packages.nocturne: init at unstable-2022-10-15

This commit is contained in:
Samuel Ainsworth 2023-01-08 04:18:18 +00:00
parent ecf05f1c15
commit 0fb94ef0d8
2 changed files with 88 additions and 0 deletions

View File

@ -0,0 +1,61 @@
{ buildPythonPackage
, cmake
, fetchFromGitHub
, gtest
, hydra-core
, lib
, nlohmann_json
, pybind11
, PyVirtualDisplay
, sfml
, substituteAll
}:
buildPythonPackage rec {
pname = "nocturne";
version = "unstable-2022-10-15";
format = "setuptools";
src = fetchFromGitHub {
owner = "facebookresearch";
repo = pname;
rev = "ae0a4e361457caf6b7e397675cc86f46161405ed";
hash = "sha256-pFVbl4m7qX1mJgleNabRboS9klDDsbzUa4PYL5+Jupc=";
};
# Simulate the git submodules but with nixpkgs dependencies
postUnpack = ''
rm -rf $sourceRoot/third_party/*
ln -s ${nlohmann_json.src} $sourceRoot/third_party/json
ln -s ${pybind11.src} $sourceRoot/third_party/pybind11
'';
patches = [
(substituteAll {
src = ./dependencies.patch;
gtest_src = gtest.src;
})
];
nativeBuildInputs = [ cmake ];
dontUseCmakeConfigure = true;
buildInputs = [ sfml ];
# hydra-core and PyVirtualDisplay are not declared as dependences but they are requirements
propagatedBuildInputs = [ hydra-core PyVirtualDisplay ];
# Test suite requires hydra-submitit-launcher which is not packaged as of 2022-01-02
doCheck = false;
pythonImportsCheck = [
"nocturne"
];
meta = with lib; {
description = "A data-driven, fast driving simulator for multi-agent coordination under partial observability";
homepage = "https://github.com/facebookresearch/nocturne";
license = licenses.mit;
maintainers = with maintainers; [ samuela ];
};
}

View File

@ -0,0 +1,27 @@
diff --git a/nocturne/cpp/CMakeLists.txt b/nocturne/cpp/CMakeLists.txt
index c67815f..e1f825b 100644
--- a/nocturne/cpp/CMakeLists.txt
+++ b/nocturne/cpp/CMakeLists.txt
@@ -62,8 +62,7 @@ include(FetchContent)
FetchContent_Declare(
googletest
- GIT_REPOSITORY https://github.com/google/googletest.git
- GIT_TAG main
+ SOURCE_DIR @gtest_src@
)
set(gtest_force_shared_crt ON CACHE BOOL "" FORCE)
diff --git a/setup.py b/setup.py
index 4863ae6..b5d3545 100644
--- a/setup.py
+++ b/setup.py
@@ -92,6 +92,8 @@ def main():
# with open("./requirements.txt", "r") as f:
# requires = f.read().splitlines()
setup(
+ # Adding `packages=` is necessary to get `python setup.py install` to work
+ packages=["nocturne", "cfgs"],
ext_modules=[CMakeExtension("nocturne", "./nocturne")],
cmdclass=dict(build_ext=CMakeBuild),
)