-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #161 from pyiron/pyproject_toml
Switch to pyproject.toml
- Loading branch information
Showing
16 changed files
with
149 additions
and
2,363 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
def get_setup_version_and_pattern(setup_content): | ||
depend_lst, version_lst = [], [] | ||
for l in setup_content: | ||
if '==' in l: | ||
lst = l.split('[')[-1].split(']')[0].replace(' ', '').replace('"', '').replace("'", '').split(',') | ||
for dep in lst: | ||
if dep != '\n': | ||
version_lst.append(dep.split('==')[1]) | ||
depend_lst.append(dep.split('==')[0]) | ||
|
||
version_high_dict = {d: v for d, v in zip(depend_lst, version_lst)} | ||
return version_high_dict | ||
|
||
|
||
def get_env_version(env_content): | ||
read_flag = False | ||
depend_lst, version_lst = [], [] | ||
for l in env_content: | ||
if 'dependencies:' in l: | ||
read_flag = True | ||
elif read_flag: | ||
lst = l.replace('-', '').replace(' ', '').replace('\n', '').split("=") | ||
if len(lst) == 2: | ||
depend_lst.append(lst[0]) | ||
version_lst.append(lst[1]) | ||
return {d:v for d, v in zip(depend_lst, version_lst)} | ||
|
||
|
||
def update_dependencies(setup_content, version_low_dict, version_high_dict): | ||
version_combo_dict = {} | ||
for dep, ver in version_high_dict.items(): | ||
if dep in version_low_dict.keys() and version_low_dict[dep] != ver: | ||
version_combo_dict[dep] = dep + ">=" + version_low_dict[dep] + ",<=" + ver | ||
else: | ||
version_combo_dict[dep] = dep + "==" + ver | ||
|
||
setup_content_new = "" | ||
pattern_dict = {d:d + "==" + v for d, v in version_high_dict.items()} | ||
for l in setup_content: | ||
for k, v in pattern_dict.items(): | ||
if v in l: | ||
l = l.replace(v, version_combo_dict[k]) | ||
setup_content_new +=l | ||
return setup_content_new | ||
|
||
|
||
if __name__ == "__main__": | ||
with open('pyproject.toml', "r") as f: | ||
setup_content = f.readlines() | ||
|
||
with open('environment.yml', "r") as f: | ||
env_content = f.readlines() | ||
|
||
setup_content_new = update_dependencies( | ||
setup_content=setup_content[2:], | ||
version_low_dict=get_env_version(env_content=env_content), | ||
version_high_dict=get_setup_version_and_pattern(setup_content=setup_content[2:]), | ||
) | ||
|
||
with open('pyproject.toml', "w") as f: | ||
f.writelines("".join(setup_content[:2]) + setup_content_new) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1 @@ | ||
include LICENSE | ||
include versioneer.py | ||
include pylammpsmpi/_version.py | ||
include LICENSE |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,14 +1,12 @@ | ||
from pylammpsmpi.wrapper.extended import LammpsLibrary | ||
from pylammpsmpi.wrapper.concurrent import LammpsConcurrent | ||
from pylammpsmpi.wrapper.base import LammpsBase | ||
|
||
from ._version import get_versions | ||
|
||
try: | ||
from pylammpsmpi.wrapper.extended import LammpsLibrary | ||
from pylammpsmpi.wrapper.concurrent import LammpsConcurrent | ||
from pylammpsmpi.wrapper.base import LammpsBase | ||
from pylammpsmpi.wrapper.ase import LammpsASELibrary | ||
except ImportError: | ||
pass | ||
|
||
|
||
__version__ = get_versions()["version"] | ||
del get_versions |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
[build-system] | ||
requires = ["setuptools", "versioneer[toml]==0.29"] | ||
build-backend = "setuptools.build_meta" | ||
|
||
[project] | ||
name = "pylammpsmpi" | ||
description = "Parallel Lammps Python interface - control a mpi4py parallel LAMMPS instance from a serial python process or a Jupyter notebook" | ||
authors = [ | ||
{ name = "Jan Janssen", email = "[email protected]" }, | ||
] | ||
readme = "README.md" | ||
license = { file = "LICENSE" } | ||
keywords = ["pyiron"] | ||
requires-python = ">=3.8" | ||
classifiers = [ | ||
"Development Status :: 5 - Production/Stable", | ||
"Topic :: Scientific/Engineering :: Physics", | ||
"License :: OSI Approved :: BSD License", | ||
"Intended Audience :: Science/Research", | ||
"Operating System :: OS Independent", | ||
"Programming Language :: Python :: 3.8", | ||
"Programming Language :: Python :: 3.9", | ||
"Programming Language :: Python :: 3.10", | ||
"Programming Language :: Python :: 3.11", | ||
] | ||
dependencies = [ | ||
"mpi4py==3.1.5", | ||
"pympipool==0.7.5", | ||
"numpy==1.26.2", | ||
] | ||
dynamic = ["version"] | ||
|
||
[project.urls] | ||
Homepage = "https://github.com/pyiron/pylammpsmpi" | ||
Documentation = "https://github.com/pyiron/pylammpsmpi" | ||
Repository = "https://github.com/pyiron/pylammpsmpi" | ||
|
||
[project.optional-dependencies] | ||
ase = [ | ||
"ase==3.22.1", | ||
"scipy==1.11.4", | ||
] | ||
|
||
[tool.setuptools.packages.find] | ||
include = ["pylammpsmpi*"] | ||
|
||
[tool.setuptools.dynamic] | ||
version = {attr = "pylammpsmpi.__version__"} | ||
|
||
[tool.versioneer] | ||
VCS = "git" | ||
style = "pep440-pre" | ||
versionfile_source = "pylammpsmpi/_version.py" | ||
parentdir_prefix = "pylammpsmpi" | ||
tag_prefix = "pylammpsmpi-" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,36 +1,8 @@ | ||
from setuptools import setup, find_packages | ||
from setuptools import setup | ||
|
||
import versioneer | ||
|
||
setup( | ||
name="pylammpsmpi", | ||
version=versioneer.get_version(), | ||
description="Parallel Lammps Python interface", | ||
long_description="PylammpsMPI couples a serial python process to an MPI parallel LAMMPS libary.", | ||
url='https://github.com/pyiron/pylammpsmpi', | ||
author='Jan Janssen', | ||
author_email='[email protected]', | ||
license='BSD', | ||
|
||
classifiers=[ | ||
'Development Status :: 5 - Production/Stable', | ||
'Topic :: Scientific/Engineering :: Physics', | ||
'License :: OSI Approved :: BSD License', | ||
'Intended Audience :: Science/Research', | ||
'Operating System :: OS Independent', | ||
'Programming Language :: Python :: 3.7', | ||
'Programming Language :: Python :: 3.8', | ||
'Programming Language :: Python :: 3.9', | ||
'Programming Language :: Python :: 3.10', | ||
'Programming Language :: Python :: 3.11', | ||
], | ||
|
||
keywords='lammps, mpi4py', | ||
packages=find_packages(exclude=["*tests*"]), | ||
install_requires=[ | ||
"mpi4py==3.1.5", "pympipool==0.7.5", "numpy==1.26.2" | ||
], | ||
extras_require={ | ||
"ase": ["ase==3.22.1", "scipy==1.11.4"], | ||
}, | ||
cmdclass=versioneer.get_cmdclass(), | ||
) | ||
) |
Oops, something went wrong.