Source code for qbraid.transpiler.annotations
# Copyright (C) 2024 qBraid
#
# This file is part of the qBraid-SDK
#
# The qBraid-SDK is free software released under the GNU General Public License v3
# or later. You can redistribute and/or modify it under the terms of the GPL v3.
# See the LICENSE file in the project root or <https://www.gnu.org/licenses/gpl-3.0.html>.
#
# THERE IS NO WARRANTY for the qBraid-SDK, as per Section 15 of the GPL v3.
"""
Module defining function annotations (e.g. decorators) used in the transpiler.
"""
from typing import Callable
[docs]
def requires_extras(dependency: str) -> Callable[[Callable], Callable]:
"""
Decorator factory to mark conversion functions that require additional dependencies
beyond their "{source}_to_{target}" naming convention. It adds a specified dependency
as an attribute to the function.
Args:
dependency (str): The name of the required additional dependency.
Returns:
Callable: A decorator that marks a function with the required dependency.
"""
def decorator(func: Callable) -> Callable:
if hasattr(func, "requires_extras"):
func.requires_extras.append(dependency)
else:
func.requires_extras = [dependency]
return func
return decorator