Source code for covalent._workflow.deps

# Copyright 2021 Agnostiq Inc.
#
# This file is part of Covalent.
#
# Licensed under the GNU Affero General Public License 3.0 (the "License").
# A copy of the License may be obtained with this software package or at
#
#      https://www.gnu.org/licenses/agpl-3.0.en.html
#
# Use of this file is prohibited except in compliance with the License. Any
# modifications or derivative works of this file must retain this copyright
# notice, and modified files must contain a notice indicating that they have
# been altered from the originals.
#
# Covalent is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the License for more details.
#
# Relief from the License may be granted by purchasing a commercial license.

from abc import ABC, abstractmethod
from typing import Tuple

from .transport import TransportableObject


[docs]class Deps(ABC): """Generic dependency class used in specifying any kind of dependency for an electron. Attributes: apply_fn: function to be executed in the backend environment apply_args: list of arguments to be applied in the backend environment apply_kwargs: dictionary of keyword arguments to be applied in the backend environment """ def __init__(self, apply_fn=None, apply_args=[], apply_kwargs={}, *, retval_keyword=""): self.apply_fn = TransportableObject(apply_fn) self.apply_args = TransportableObject(apply_args) self.apply_kwargs = TransportableObject(apply_kwargs) self.retval_keyword = retval_keyword
[docs] def apply(self) -> Tuple[TransportableObject, TransportableObject, TransportableObject, str]: """ Encapsulates the exact function and args/kwargs to be executed in the backend environment. Args: None Returns: A tuple of transportable objects containing the function and optional args/kwargs """ return (self.apply_fn, self.apply_args, self.apply_kwargs, self.retval_keyword)
def short_name(self): return self.__module__.split("/")[-1].split(".")[-1] @abstractmethod def to_dict(self): raise NotImplementedError @abstractmethod def from_dict(self, object_dict): raise NotImplementedError