diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile new file mode 100644 index 00000000..3e138db4 --- /dev/null +++ b/.devcontainer/Dockerfile @@ -0,0 +1,30 @@ +#------------------------------------------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See https://go.microsoft.com/fwlink/?linkid=2090316 for license information. +#------------------------------------------------------------------------------------------------------------- + +# To fully customize the contents of this image, use the following Dockerfile instead: +# https://github.com/microsoft/vscode-dev-containers/tree/v0.117.1/containers/codespaces-linux/.devcontainer/Dockerfile +FROM mcr.microsoft.com/vscode/devcontainers/universal:0-linux + +# ** [Optional] Uncomment this section to install additional packages. ** +# +ENV DEBIAN_FRONTEND=noninteractive +RUN sudo apt-get update \ + && sudo apt-get -y install --no-install-recommends \ + build-essential gfortran gcc g++ quantum-espresso \ + gfortran quantum-espresso quantum-espresso-data libopenmpi-dev \ + make git cmake ninja-build \ + # + # Clean up + && sudo apt-get autoremove -y \ + && sudo apt-get clean -y \ + && sudo rm -rf /var/lib/apt/lists/* +ARG pyver=3.6 +RUN /opt/python/${pyver}/bin/python -m venv /home/codespace/venv +RUN . /home/codespace/venv/bin/activate \ + && pip install --upgrade pip \ + && pip install setuptools wheel scikit-build "cmake!=3.16.3" ninja \ + && pip install cython numpy flake8 mypy black pytest \ + && pip install sphinx sphinx-autobuild rstcheck +ENV DEBIAN_FRONTEND=dialog diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 00000000..bdef3cb4 --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,41 @@ +// For format details, see https://aka.ms/vscode-remote/devcontainer.json or this file's README at: +// https://github.com/microsoft/vscode-dev-containers/tree/v0.117.1/containers/codespaces-linux +{ + "name": "Codespaces", + "dockerFile": "Dockerfile", + "remoteUser": "codespace", + "workspaceMount": "source=${localWorkspaceFolder},target=/home/codespace/workspace,type=bind,consistency=cached", + "workspaceFolder": "/home/codespace/workspace", + "runArgs": [ + "--cap-add=SYS_PTRACE", + "--security-opt", + "seccomp=unconfined" + ], + // Add the IDs of extensions you want installed when the container is created. + "extensions": [ + "ms-vsonline.vsonline", + "GitHub.vscode-pull-request-github", + "MS-vsliveshare.vsliveshare", + "VisualStudioExptTeam.vscodeintellicode", + "ms-python.python", + "lextudio.restructuredtext", + "tcwalther.cython", + "twxs.cmake" + ], + // Set *default* container specific settings.json values on container create. + "settings": { + "python.formatting.provider": "black", + "python.linting.pylintEnabled": false, + "python.linting.flake8Enabled": true, + "python.testing.pytestEnabled": true, + "python.pythonPath": "/home/codespace/venv/bin/python", + "python.venvFolders": [ + "venv" + ], + "cmake.cmakePath": "/home/codespace/venv/lib/python3.6/site-packages/cmake/data/bin/cmake" + }, + // Use 'forwardPorts' to make a list of ports inside the container available locally. + // "forwardPorts": [], + // Use 'postCreateCommand' to run commands after the container is created. + // "postCreateCommand": "uname -a" +} \ No newline at end of file diff --git a/.devcontainer/symlinkDotNetCore.sh b/.devcontainer/symlinkDotNetCore.sh new file mode 100644 index 00000000..dad6a920 --- /dev/null +++ b/.devcontainer/symlinkDotNetCore.sh @@ -0,0 +1,47 @@ +#!/nix/store/iqak4y6kxnjzz37idsffd2jha52wz31x-bash-4.4-p23/bin/bash +#-------------------------------------------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See https://go.microsoft.com/fwlink/?linkid=2090316 for license information. +#-------------------------------------------------------------------------------------------------------------- + +set -ex + +splitSdksDir="/opt/dotnet/sdks" + +allSdksDir="/home/codespace/.dotnet" +mkdir -p "$allSdksDir" + +# Copy latest muxer and license files +cp -f "$splitSdksDir/3/dotnet" "$allSdksDir" +cp -f "$splitSdksDir/3/LICENSE.txt" "$allSdksDir" +cp -f "$splitSdksDir/3/ThirdPartyNotices.txt" "$allSdksDir" + +function createLinks() { + local sdkVersion="$1" + local runtimeVersion="$2" + + cd "$splitSdksDir/$sdkVersion" + + # Find folders with name as sdk or runtime version + find . -name "$sdkVersion" -o -name "$runtimeVersion" | while read subPath; do + # Trim beginning 2 characters from the line which currently looks like, for example, './sdk/2.2.402' + subPath="${subPath:2}" + + linkFrom="$allSdksDir/$subPath" + linkFromParentDir=$(dirname $linkFrom) + mkdir -p "$linkFromParentDir" + + linkTo="$splitSdksDir/$sdkVersion/$subPath" + ln -s $linkTo $linkFrom + done +} + +createLinks "3.1.201" "3.1.3" +echo +createLinks "3.0.103" "3.0.3" +echo +createLinks "2.2.402" "2.2.7" +echo +createLinks "2.1.805" "2.1.17" +echo +createLinks "1.1.14" "1.1.13" \ No newline at end of file diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..fb527b75 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,3 @@ +.venv/ +.direnv/ +_skbuild/ \ No newline at end of file diff --git a/.gitignore b/.gitignore index 2dc13637..b824340e 100644 --- a/.gitignore +++ b/.gitignore @@ -146,4 +146,4 @@ shell.nix .local/ .vim/ .direnv/ -.clang +.clang \ No newline at end of file diff --git a/CMakeLists.txt b/CMakeLists.txt index 43151613..612387e4 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -61,14 +61,8 @@ if(NOT Python3_FOUND AND NOT Python2_FOUND) endif() if(Python3_FOUND) - function(Python_add_library) - Python3_add_library(${ARGV}) - endfunction() set(PYVER PY3) else() - function(Python_add_library) - Python2_add_library(${ARGV}) - endfunction() set(PYVER PY2) endif() diff --git a/README.rst b/README.rst index e3187bad..76396907 100644 --- a/README.rst +++ b/README.rst @@ -47,10 +47,10 @@ The simplest approach is to install via .. code:: bash - mkvirtualenv --system-site-packages pylada + python -m venv pylada source pylada/bin/activate pip install git+https://github.com/pylada/pylada-light - + This last approach is recommended since it keeps the pylada environment isolated from the rest of the system. Susbsequently, this environment can be accessed by running the second line. @@ -62,19 +62,20 @@ Installation for development .. code:: bash - mkvirtualenv --system-site-packages pylada + python -m venv pylada source pylada/bin/activate git clone https://github.com/pylada/pylada-light cd pylada-light - pip install cython setuptools wheel scikit-build cmake ninja numpy - python setup.py develop + python -m pip install cython setuptools wheel scikit-build cmake ninja numpy + python -m pip install -e .[dev] python setup.py test - + ln -s src/pylada . # because https://github.com/scikit-build/scikit-build/issues/363 + The above creates a virtual environment and installs pylada inside it in development mode. This means that the virtual environment will know about the pylada flavor in development. It is possible to edit a file, do - :bash:`make`, launch python and debug. One just needs to active the virtual - environment once per session. + :bash:`make`, launch python and debug. One just needs to active the + virtual environment once per session. - When modifying files that are built (`.pyx`, `.cc`, `.h`), it is necessary to run `python - setup.py develop` again. + When modifying files that are built (`.pyx`, `.cc`, `.h`), it may be + necessary to run `python setup.py develop` again. diff --git a/setup.py b/setup.py index 3a4c2b00..694ecd78 100644 --- a/setup.py +++ b/setup.py @@ -31,6 +31,7 @@ def wrapped_setup(*args, **kwargs): "nbformat", "ipykernel", "IPython", + "black", ] if version_info[0] == 2: tests_require.append("mock") diff --git a/src/pylada/CMakeLists.txt b/src/pylada/CMakeLists.txt index a72e0423..7bccf299 100644 --- a/src/pylada/CMakeLists.txt +++ b/src/pylada/CMakeLists.txt @@ -8,6 +8,7 @@ file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/_version.py" ) install(FILES "${CMAKE_CURRENT_BINARY_DIR}/_version.py" DESTINATION ${PY_ROOT_DIR}) +include_directories("${PYTHON_INCLUDE_DIR}") add_subdirectory(crystal) add_subdirectory(decorations) add_subdirectory(ewald) diff --git a/src/pylada/crystal/CMakeLists.txt b/src/pylada/crystal/CMakeLists.txt index 3d05cb40..bfc272db 100644 --- a/src/pylada/crystal/CMakeLists.txt +++ b/src/pylada/crystal/CMakeLists.txt @@ -30,16 +30,18 @@ set(cython_sources foreach(filename ${cython_sources}) get_filename_component(name "${filename}" NAME_WE) add_cython_target(cython_${name} ${filename} CXX ${PYVER}}) - Python_add_library(${name} MODULE ${cython_${name}}) - target_link_libraries(${name} PRIVATE Eigen3::Eigen) + add_library(${name} MODULE ${cython_${name}}) + python_extension_module(${name}) + target_link_libraries(${name} Eigen3::Eigen) target_include_directories(${name} PRIVATE "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}") install(TARGETS ${name} LIBRARY DESTINATION ${PY_ROOT_DIR}/crystal) endforeach() add_cython_target(cython_cutilities cutilities.pyx CXX ${PYVER}) -Python_add_library(cutilities MODULE ${cython_cutilities} smith_normal_form.cc gruber.cc noopt.cc) +add_library(cutilities MODULE ${cython_cutilities} smith_normal_form.cc gruber.cc noopt.cc) +python_extension_module(cutilities) target_include_directories(cutilities PRIVATE "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}") -target_link_libraries(cutilities PRIVATE Eigen3::Eigen) +target_link_libraries(cutilities Eigen3::Eigen) install(TARGETS cutilities LIBRARY DESTINATION ${PY_ROOT_DIR}/crystal) add_subdirectory(defects) diff --git a/src/pylada/crystal/defects/CMakeLists.txt b/src/pylada/crystal/defects/CMakeLists.txt index c09a03c6..0c54f549 100644 --- a/src/pylada/crystal/defects/CMakeLists.txt +++ b/src/pylada/crystal/defects/CMakeLists.txt @@ -24,7 +24,11 @@ ############################### add_cython_target(defects_cython _defects.pyx CXX ${PYVER}) -Python_add_library(_defects MODULE ${defects_cython} third_order.cc) -target_link_libraries(_defects PRIVATE Eigen3::Eigen) -target_include_directories(_defects PRIVATE "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}") +add_library(_defects MODULE ${defects_cython} third_order.cc) +python_extension_module(_defects) +target_link_libraries(_defects Eigen3::Eigen) +target_include_directories( + _defects PRIVATE + "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}" "${PYTHON_INCLUDE_DIR}" +) install(TARGETS _defects LIBRARY DESTINATION ${PY_ROOT_DIR}/crystal/defects) diff --git a/src/pylada/decorations/CMakeLists.txt b/src/pylada/decorations/CMakeLists.txt index 14e47848..06d3124a 100644 --- a/src/pylada/decorations/CMakeLists.txt +++ b/src/pylada/decorations/CMakeLists.txt @@ -21,6 +21,10 @@ ############################### add_cython_target(decorations_cython _decorations.pyx CXX ${PYVER}}) -Python_add_library(_decorations MODULE ${decorations_cython}) -target_include_directories(_decorations PRIVATE "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}") +add_library(_decorations MODULE ${decorations_cython}) +python_extension_module(_decorations) +target_include_directories( + _decorations PRIVATE + "${PY_HEADER_DIR}" "${NumPy_INCLUDE_DIRS}" "${PYTHON_INCLUDE_DIR}" +) install(TARGETS _decorations LIBRARY DESTINATION ${PY_ROOT_DIR}/decorations) diff --git a/src/pylada/ewald/CMakeLists.txt b/src/pylada/ewald/CMakeLists.txt index 3b851d97..f07a93e5 100644 --- a/src/pylada/ewald/CMakeLists.txt +++ b/src/pylada/ewald/CMakeLists.txt @@ -20,7 +20,8 @@ # . ############################### add_cython_target(ewald_cython ewald.pyx CXX ${PYVER}) -Python_add_library(ewald MODULE +add_library(ewald MODULE ${ewald_cython} ep_com.f90 erfc.cc ewaldf.f90 ewald.cc) +python_extension_module(ewald) target_include_directories(ewald PRIVATE "${PY_HEADER_DIR}") install(TARGETS ewald LIBRARY DESTINATION ${PY_ROOT_DIR}/ewald)