| """The original Context Switch."""
|
| from .constants import get_category, get_name
|
| from .context_utils import (ORIG_CTX_RETURN_TYPES, ORIG_CTX_RETURN_NAMES, is_context_empty,
|
| get_orig_context_return_tuple)
|
| from .utils import FlexibleOptionalInputType
|
|
|
|
|
| class RgthreeContextSwitch:
|
| """The (original) Context Switch node."""
|
|
|
| NAME = get_name("Context Switch")
|
| CATEGORY = get_category()
|
|
|
| @classmethod
|
| def INPUT_TYPES(cls):
|
| return {
|
| "required": {},
|
| "optional": FlexibleOptionalInputType("RGTHREE_CONTEXT"),
|
| }
|
|
|
| RETURN_TYPES = ORIG_CTX_RETURN_TYPES
|
| RETURN_NAMES = ORIG_CTX_RETURN_NAMES
|
| FUNCTION = "switch"
|
|
|
| def get_return_tuple(self, ctx):
|
| """Returns the context data. Separated so it can be overridden."""
|
| return get_orig_context_return_tuple(ctx)
|
|
|
| def switch(self, **kwargs):
|
| """Chooses the first non-empty Context to output."""
|
| ctx = None
|
| for key, value in kwargs.items():
|
| if key.startswith('ctx_') and not is_context_empty(value):
|
| ctx = value
|
| break
|
| return self.get_return_tuple(ctx)
|
|
|