Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add env variable and pre kernel launch logic #40

Open
wants to merge 6 commits into
base: main
Choose a base branch
from
Open
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 34 additions & 8 deletions condacolab.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@ def install_from_url(
installer_url: AnyStr,
prefix: os.PathLike = PREFIX,
env: Dict[AnyStr, AnyStr] = None,
pre_kernel_launch_script: str = None,
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved
run_checks: bool = True,
restart_kernel: bool = True,
):
Expand All @@ -114,6 +115,9 @@ def install_from_url(
For example, a value with spaces should be passed as::

env={"VAR": '"a value with spaces"'}
pre_kernel_launch_script
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved
Path to a bash file or a string with bash script that you
want to run before activating conda base environment.
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved
run_checks
Run checks to see if installation was run previously.
Change to False to ignore checks and always attempt
Expand Down Expand Up @@ -198,13 +202,23 @@ def install_from_url(

env = env or {}
bin_path = f"{prefix}/bin"

if env and pre_kernel_launch_script :
contents = "".join(f'export {key}={value}\n' for key, value in env.items())

if os.path.isfile(pre_kernel_launch_script):
with open(pre_kernel_launch_script, "r") as f:
contents += f.read()
else:
contents += pre_kernel_launch_script
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved

os.rename(sys.executable, f"{sys.executable}.renamed_by_condacolab.bak")
with open(sys.executable, "w") as f:
f.write(
dedent(
f"""
#!/bin/bash
{contents}
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved
source {prefix}/etc/profile.d/conda.sh
ssurbhi560 marked this conversation as resolved.
Show resolved Hide resolved
conda activate
unset PYTHONPATH
Expand All @@ -231,7 +245,7 @@ def install_from_url(
print("🔁 Please restart kernel by clicking on Runtime > Restart runtime.")

def install_mambaforge(
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, run_checks: bool = True, restart_kernel: bool = True,
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, pre_kernel_launch_script: str = None, run_checks: bool = True, restart_kernel: bool = True,
):
"""
Install Mambaforge, built for Python 3.7.
Expand All @@ -256,21 +270,24 @@ def install_mambaforge(
For example, a value with spaces should be passed as::

env={"VAR": '"a value with spaces"'}
pre_kernel_launch_script
Path to a bash file or a string with bash script that you
want to run before activating conda base environment.
run_checks
Run checks to see if installation was run previously.
Change to False to ignore checks and always attempt
to run the installation.
"""
installer_url = r"https://github.com/jaimergp/miniforge/releases/latest/download/Mambaforge-colab-Linux-x86_64.sh"
install_from_url(installer_url, prefix=prefix, env=env, run_checks=run_checks, restart_kernel=restart_kernel)
install_from_url(installer_url, prefix=prefix, env=env, pre_kernel_launch_script=pre_kernel_launch_script, run_checks=run_checks, restart_kernel=restart_kernel)


# Make mambaforge the default
install = install_mambaforge


def install_miniforge(
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, run_checks: bool = True, restart_kernel: bool = True,
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, pre_kernel_launch_script: str = None, run_checks: bool = True, restart_kernel: bool = True,
):
"""
Install Mambaforge, built for Python 3.7.
Expand All @@ -294,17 +311,20 @@ def install_miniforge(
For example, a value with spaces should be passed as::

env={"VAR": '"a value with spaces"'}
pre_kernel_launch_script
Path to a bash file or a string with bash script that you
want to run before activating conda base environment.
run_checks
Run checks to see if installation was run previously.
Change to False to ignore checks and always attempt
to run the installation.
"""
installer_url = r"https://github.com/jaimergp/miniforge/releases/latest/download/Miniforge-colab-Linux-x86_64.sh"
install_from_url(installer_url, prefix=prefix, env=env, run_checks=run_checks, restart_kernel=restart_kernel)
install_from_url(installer_url, prefix=prefix, env=env, pre_kernel_launch_script=pre_kernel_launch_script, run_checks=run_checks, restart_kernel=restart_kernel)


def install_miniconda(
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, run_checks: bool = True, restart_kernel: bool = True,
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, pre_kernel_launch_script: str = None, run_checks: bool = True, restart_kernel: bool = True,
):
"""
Install Miniconda 4.12.0 for Python 3.7.
Expand All @@ -323,17 +343,20 @@ def install_miniconda(
For example, a value with spaces should be passed as::

env={"VAR": '"a value with spaces"'}
pre_kernel_launch_script
Path to a bash file or a string with bash script that you
want to run before activating conda base environment.
run_checks
Run checks to see if installation was run previously.
Change to False to ignore checks and always attempt
to run the installation.
"""
installer_url = r"https://repo.anaconda.com/miniconda/Miniconda3-py37_4.12.0-Linux-x86_64.sh"
install_from_url(installer_url, prefix=prefix, env=env, run_checks=run_checks, restart_kernel=restart_kernel)
install_from_url(installer_url, prefix=prefix, env=env, pre_kernel_launch_script=pre_kernel_launch_script, run_checks=run_checks, restart_kernel=restart_kernel)


def install_anaconda(
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, run_checks: bool = True, restart_kernel: bool = True,
prefix: os.PathLike = PREFIX, env: Dict[AnyStr, AnyStr] = None, pre_kernel_launch_script: str = None, run_checks: bool = True, restart_kernel: bool = True,
):
"""
Install Anaconda 2022.05, the latest version built
Expand All @@ -353,13 +376,16 @@ def install_anaconda(
For example, a value with spaces should be passed as::

env={"VAR": '"a value with spaces"'}
pre_kernel_launch_script
Path to a bash file or a string with bash script that you
want to run before activating conda base environment.
run_checks
Run checks to see if installation was run previously.
Change to False to ignore checks and always attempt
to run the installation.
"""
installer_url = r"https://repo.anaconda.com/archive/Anaconda3-2022.05-Linux-x86_64.sh"
install_from_url(installer_url, prefix=prefix, env=env, run_checks=run_checks, restart_kernel=restart_kernel)
install_from_url(installer_url, prefix=prefix, env=env, pre_kernel_launch_script=pre_kernel_launch_script, run_checks=run_checks, restart_kernel=restart_kernel)


def check(prefix: os.PathLike = PREFIX, verbose: bool = True):
Expand Down