cirq.alternative
A decorator indicating an abstract method with an alternative default implementation.
cirq.alternative(
*, requires: str, implementation: T
) -> Callable[[T], T]
This decorator may be used multiple times on the same function to specify
multiple alternatives. If multiple alternatives are available, the
outermost (lowest line number) alternative is used.
Usage |
class Parent(metaclass=ABCMetaImplementAnyOneOf):
def _default_do_a_using_b(self, ...):
...
def _default_do_a_using_c(self, ...):
...
# Abstract method with alternatives
@alternative(requires='do_b', implementation=_default_do_a_using_b)
@alternative(requires='do_c', implementation=_default_do_a_using_c)
def do_a(self, ...):
'''Method docstring.'''
# Abstract or concrete methods `do_b` and `do_c`:
...
class Child(Parent):
def do_b(self):
...
child = Child()
child.do_a(...)
|
Arguments |
requires
|
The name of another abstract method in the same class that
implementation needs to be implemented.
|
implementation
|
A function that uses the method named by requires to
implement the default behavior of the wrapped abstract method. This
function must have the same signature as the decorated function.
|
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2024-06-27 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2024-06-27 UTC."],[],[]]