from setuptools import find_packages, setup

with open("README.md", "r", encoding="utf-8") as fh:
    long_description = fh.read()

setup(
    name="scp_dr",
    version="0.1.0",
    description="Python implementation of the methods introduced in the paper: Provably Protecting Fine-Tuned LLMs from Training Data Extraction",
    long_description=long_description,
    long_description_content_type="text/markdown",
    package_dir={"": "scp_dr"},
    packages=find_packages(where="scp_dr"),
    classifiers=[
        "Programming Language :: Python :: 3",
        "License :: OSI Approved :: MIT License",
        "Operating System :: OS Independent",
    ],
    keywords="machine learning, language models, data extraction, relative probabilities",
    python_requires=">=3.12.3",
    install_requires=[
        "torch>=2.3.0",
        "peft>=0.10.0",
        "transformers>=4.40.0",
        "datasets>=2.19.1",
        "pynvml>=11.5.0",
        "numpy>=1.26.4",
        "pandas>=2.2.2",
        "accelerate>=0.30.1",
        "huggingface-hub>=0.23.4",
        "bitsandbytes>=0.44.1",
    ],
    entry_points={
        "console_scripts": [
            "train=examples.train:main",
            "evaluate=examples.evaluate:main",
            "logit_compare = logit_compare.logit_compare:main",
            "attack = attack.attack:main",
        ],
    },
    extras_require={
        "tests": ["pytest>=7.4.4", "pytest-mock>=3.10.0"],  
    },
)
